NetBSD/sys/dev/scsipi
ozaki-r 9c4cd06355 Introduce softint-based if_input
This change intends to run the whole network stack in softint context
(or normal LWP), not hardware interrupt context. Note that the work is
still incomplete by this change; to that end, we also have to softint-ify
if_link_state_change (and bpf) which can still run in hardware interrupt.

This change softint-ifies at ifp->if_input that is called from
each device driver (and ieee80211_input) to ensure Layer 2 runs
in softint (e.g., ether_input and bridge_input). To this end,
we provide a framework (called percpuq) that utlizes softint(9)
and percpu ifqueues. With this patch, rxintr of most drivers just
queues received packets and schedules a softint, and the softint
dequeues packets and does rest packet processing.

To minimize changes to each driver, percpuq is allocated in struct
ifnet for now and that is initialized by default (in if_attach).
We probably have to move percpuq to softc of each driver, but it's
future work. At this point, only wm(4) has percpuq in its softc
as a reference implementation.

Additional information including performance numbers can be found
in the thread at tech-kern@ and tech-net@:
http://mail-index.netbsd.org/tech-kern/2016/01/14/msg019997.html

Acknowledgment: riastradh@ greatly helped this work.
Thank you very much!
2016-02-09 08:32:07 +00:00
..
atapi_base.c src is too big these days to tolerate superfluous apostrophes. It's 2014-10-18 08:33:23 +00:00
atapi_tape.h
atapi_wdc.c
atapiconf.c Don't probe beyond chan_ntargets in atapi_probe_bus in the "all" case. 2014-03-05 08:45:13 +00:00
atapiconf.h
cd.c Use C99-style initializers for struct dkdriver. 2015-04-26 15:15:19 +00:00
cdvar.h Include <sys/rndsource.h> where it is actually used. 2015-04-14 20:32:35 +00:00
ch.c Add d_discard to all struct cdevsw instances I could find. 2014-07-25 08:10:31 +00:00
files.scsipi
if_se.c Introduce softint-based if_input 2016-02-09 08:32:07 +00:00
Makefile
scsi_all.h
scsi_base.c
scsi_changer.h
scsi_ctron_ether.h
scsi_disk.h
scsi_iu.h
scsi_message.h
scsi_scanner.h
scsi_spc.h
scsi_tape.h
scsiconf.c Add d_discard to all struct cdevsw instances I could find. 2014-07-25 08:10:31 +00:00
scsiconf.h
scsipi_all.h
scsipi_base.c would you like some freshly ground _KERNEL_OPT with that? 2015-08-24 23:13:15 +00:00
scsipi_base.h
scsipi_cd.h
scsipi_debug.h
scsipi_disk.h
scsipi_ioctl.c to garnish, dust with _KERNEL_OPT 2015-08-24 22:50:32 +00:00
scsipi_verbose.c
scsipiconf.c
scsipiconf.h "peripheral", not "peripherial". 2014-07-13 17:12:23 +00:00
sd.c would you like some freshly ground _KERNEL_OPT with that? 2015-08-24 23:13:15 +00:00
sdvar.h would you like some freshly ground _KERNEL_OPT with that? 2015-08-24 23:13:15 +00:00
ses.c would you like some freshly ground _KERNEL_OPT with that? 2015-08-24 23:13:15 +00:00
ses.h More on PR 41200: headers that declare ioctls should include sys/ioccom.h. 2015-09-06 06:00:59 +00:00
ss_mustek.c Mark a diagnostic-only variable 2013-10-25 16:01:56 +00:00
ss_mustek.h
ss_scanjet.c Mark a diagnostic-only variable 2013-10-25 16:01:56 +00:00
ss.c Add d_discard to all struct cdevsw instances I could find. 2014-07-25 08:10:31 +00:00
ssvar.h
st_atapi.c would you like some freshly ground _KERNEL_OPT with that? 2015-08-24 23:13:15 +00:00
st_scsi.c would you like some freshly ground _KERNEL_OPT with that? 2015-08-24 23:13:15 +00:00
st.c would you like some freshly ground _KERNEL_OPT with that? 2015-08-24 23:13:15 +00:00
stvar.h Convert sys/dev to use <sys/rndsource.h>. 2015-04-13 16:33:23 +00:00
uk.c Add d_discard to all struct cdevsw instances I could find. 2014-07-25 08:10:31 +00:00