summaryrefslogtreecommitdiff
path: root/sys/netatalk/at_control.c
diff options
context:
space:
mode:
authorDavid Gwynne <dlg@cvs.openbsd.org>2010-07-15 23:52:33 +0000
committerDavid Gwynne <dlg@cvs.openbsd.org>2010-07-15 23:52:33 +0000
commit4f5b39c7187d91dfbc71e26f4fe45d09137a0303 (patch)
tree8aa6b4778d5da65e059408ff28f6ed9ce6229a54 /sys/netatalk/at_control.c
parent6ca03fb8fa4ec62ccf43542e292ff1d1efbe0e74 (diff)
when mpii(4) gets an async event (ie, sas topology change or
integrated raid has changed state) that needs an acknowledgement, it currently goes scsi_io_get. because events are handled at interrupt time it cannot wait for ccbs, so if the ccb pool is empty, it wont get a ccb to ack the event with. this cuts the code over to using iohandlers to ack these events. when an ack is required, it shoves the rcb onto a queue and schedules an iohandler to be run whenever a ccb becomes available. the majority of the time the ccb will be there and the reply will happen immediately. however, if the hba is busy we might be deferred until some other command completes and gives its ccb back to the pool. because it looks like we can now receive many events at a time (rather than just one at a time like in mpi), im using a queue to store the events in. the alternative was an iohandler per rcb, but that struck me as a bit too heavy. mikeb is really impressed no objection from krw@
Diffstat (limited to 'sys/netatalk/at_control.c')
0 files changed, 0 insertions, 0 deletions