[sane-devel] Signal-Handling-Question ( OS/2)

abel deuring a.deuring@satzbau-gmbh.de
Mon, 24 Nov 2003 15:16:21 +0100


Henning Meier-Geinitz wrote:

>>but anei_scsi_flush_all() looks like a dummy-function for me.
> 
> 
> Huh? At least for Linux, it calls flush_all_extended (fd) which stops
> all running SCSI requests.

Only the Linux part of sanei_scsi.c has more or less(*) real queueing 
capabilities. For all other implemetations, the SCSI system of the OS is 
"executing" at most one command, so there is no need to stop 
not-yet-finished commands in sanei_scsi_req_flush_all(_extended). But 
sanei_scsi_req_flush_all might be the right place to fix issues with 
signal handling, because this function is called from the signal 
handlers of many backends. I am though not sure that I understood the 
signal handling problem described by Franz for OS/2 -- so it's possible 
that this suggestion is nonsense...

Abel

(*) many SCSI disks have real queueing capabilities (called tagged 
queueing): A host can issue more than one READ or WRITE command, and the 
disk can return commands in any order. In contrast, I haven't heard 
about a SCSI scanner which supports this type of queueing. But the 
"queueing implementation" in sanei_scsi.c for Linux can nevertheless be 
very useful. The SCSI system of the kernel can queue two or more SCSI 
commands and can thus reduce the latency between two commands. For 
certain scanners, this reduced latency can avoid some or all scanhead stops.