NAME
CD_ADDFRAMEINT -- add a CD-frame software interrupt handler.
IO REQUEST
io_Device preset by the call to opendevice()
io_Unit preset by the call to opendevice()
io_Command CD_ADDFRAMEINT
io_Length sizeof(struct Interrupt)
io_Data pointer to interrupt structure
RESULTS
io_Error 0 for success, or an error code as defined in
<devices/cd.h>
FUNCTION
This command lets you add a software interrupt handler to the
disk device that gets invoked whenever a new frame is encountered
while CD audio is being played.
You must pass in a properly initialized Exec interrupt structure
and be prepared to deal with frame interrupts immediately.
The interrupt is generated by the exec cause function, so you must
preserve A6.
To set up the handler, an interrupt structure must be initialized.
This structure is supplied in io_Data of the CD_ADDFRAMEINT
command. The handler then gets linked into the handler chain and
gets invoked whenever a frame event occurs. You must eventually
remove the handler before you exit.
This command only returns when the handler is removed. That is,
the device holds onto the IO request until the cd_remframeint command
is executed with that same IO request. Hence, you must use sendio()
with this command.
NOTES
The interrupt handler can be added before or after a play command is
sent. Interrupts will only be generated while CD audio is playing.
Interrupts will not be generated when audio is paused.
SEE ALSO
cd_remframeint, <devices/cd.h>, <exec/interrupts.h>,
exec.library/cause()