NAME AddTimerInt -- adds an interrupt that is executed at regular intervals. (V40) SYNOPSIS intHandle = AddTimerInt(intRoutine, intData); D0 A0 A1 aptr addtimerint(aptr, aptr); FUNCTION Calling this routine causes the system to allocate a cia timer and set up 'intRoutine' to service any interrupts caused by the timer. Although the timer is allocated it is neither running, nor enabled. StartIntTimer() must be called to establish the time interval and start the timer. The routine is called from within an interrupt, so normal restrictions apply. The routine must preserve the following registers: A2, A3, A4, A7, D2-D7. Other registers are scratch, except for D0, which MUST BE SET TO 0 upon exit. On entry to the routine, A1 holds 'intData' and A5 holds 'intRoutine'. Only a single cia timer will be allocated by this routine. so this routine may only be called once without an intervening call to remtimerint(). The cia timer used by this routine is not guaranteed to always be the same. This routine utilizes the cia resource and uses an unallocated cia timer. If your program is to exit without reboot, you MUST match all calls to this function with calls to remtimerint() before exiting. Even if you only use the function once in your program; checking the return value will make your program more tolerant for mulititasking on the Amiga computer platforms. INPUTS intRoutine - the routine to invoke upon timer interrupts. This routine should be as short as possible to minimize its effect on overall system performance. intData - data passed to the routine in register A1. If more than one long word of data is required this should be a pointer to a structure that contains the required data. RESULT intHandle - a handle used to manipulate the interrupt, or NULL if it was not possible to attach the routine. SEE ALSO remtimerint(), stoptimerint(), starttimerint()