/* * QuickThreads -- Threads-building toolkit. * Copyright (c) 1993 by David Keppel * * Permission to use, copy, modify and distribute this software and * its documentation for any purpose and without fee is hereby * granted, provided that the above copyright notice and this notice * appear in all copies. This software is provided as a * proof-of-concept and for demonstration purposes; there is no * representation about the suitability of this software for any * purpose. */ .text .globl _qt_abort .globl _qt_block .globl _qt_blocki .globl _qt_start .globl _qt_vstart /* // Calls to these routines have the signature // // void *block (func, arg1, arg2, newsp) // // Since the prologue saves 5 registers, nargs, pc, fp, ap, mask, and // a condition handler (at sp+0), the first argument is 40=4*10 bytes // offset from the stack pointer. */ _qt_block: _qt_blocki: _qt_abort: .word 0x7c0 /* Callee-save mask: 5 registers. */ movl 56(sp),r1 /* Get stack pointer of new thread. */ movl 52(sp),-(r1) /* Push arg2 */ movl 48(sp),-(r1) /* Push arg1 */ movl sp,-(r1) /* Push arg0 */ movl 44(sp),r0 /* Get helper to call. */ movl r1,sp /* Move to new thread's stack. */ addl3 sp,$12,fp /* .. including the frame pointer. */ calls $3,(r0) /* Call helper. */ ret _qt_start: movl (sp)+,r0 /* Get `only'. */ calls $3,(r0) /* Call `only'. */ calls $0,_qt_error /* `only' erroniously returned. */ _qt_vstart: movl (sp)+,r10 /* Get `pt'. */ movl (sp)+,r9 /* Get `startup'. */ movl (sp)+,r8 /* Get `vuserf'. */ movl (sp)+,r7 /* Get `cleanup'. */ pushl r10 /* Push `qt'. */ calls $1,(r9) /* Call `startup', pop `qt' on return. */ calls (sp)+,(r8) /* Call user's function. */ pushl r0 /* Push `vuserf_retval'. */ pushl r10 /* Push `qt'. */ calls $2,(r7) /* Call `cleanup', never return. */ calls $0,_qt_error /* `cleanup' erroniously returned. */