Elliot Nunn 4325cdcc78 Bring in CubeE sources
Resource forks are included only for .rsrc files. These are DeRezzed into their data fork. 'ckid' resources, from the Projector VCS, are not included.

The Tools directory, containing mostly junk, is also excluded.
2017-12-26 09:52:23 +08:00

1461 lines
37 KiB
Plaintext

;
; File: MemMgrGlue.a
;
; Contains: 68xxx assembly language glue for Memory Manager traps.
;
; Written by: Jeff Crawford
;
; Copyright: © 1993 by Apple Computer, Inc., all rights reserved.
;
; Change History (most recent first):
;
; <29> 8/5/93 BT <BT, JC> We came, we saw, we initialed...
; <28> 7/9/93 JC Fixed HSetStateQ interface bug #1095338.
; <27> 7/7/93 BT <EPT> Continuation of Radar #1095398. I forgot to put in D1 trap
; parameter for native glue calling conventions some time back,
; now that it is used it needs to be there. This file needs the
; proper naming convention to do the right thing.
; <26> 6/9/93 JC Removed outdated comments.
; <25> 6/9/93 JC Rearranged _HeapDispatchSelectors to be in order. This requires
; a change to the ProcessMgr. Took out extra save and restore of
; A0 for GetHandleSize and EmptyHandle.
; <24> 6/4/93 JC Cleaned up Glue for ReallocHandle & SetHandleSize.
; <23> 5/25/93 BT Change routines named "_Å" to "__Å". This supports native
; naming conventions for shared libraries.
; <22> 5/21/93 JC Support for QuickTime 1.6 now worked. Fixed but where error
; code was return when any QT routine was called.
; <21> 5/20/93 JC Cleaned up call back procs. Removed c_MoreMastersHi. Added
; c_RegisterDisposeProc API for ProcessMgr.
; <20> 5/20/93 JC Added support for QuickTime 1.6. QT 1.6 does not work
; yet until I get some initialization info from Peter.
; <19> 5/19/93 JC Added comment for ReallocHandle. The interface to ReallocHandle
; needs to be fixed later.
; <18> 5/18/93 BT Added prefix "FIG_" to all trap entry points to distinguish
; between old and new heap managers.
; <17> 5/2/93 JC Added 2 new calls, GetZoneCompatibilityFlags and
; SetZoneCompatibilityFlags.
;
;
;
;
; Notes:
; 1) Since C sign extends all chars and shorts to 32 bit values, we always push
; longwords on the stack.
;
;
;
; for Most MM calls:
;
; 1) Receive stuff from trap dispatched
; 2) Reorganize to C calling conventions
; 3) Jump To it.
; 4) Put parameters back for trap dispatcher
;
; for new MM calls: (ie.- NewHandleHi)
; 1) check to the select to see if its in my range
; 2) if not return paramErr
; 3) get routine address from selector
; 4) adjust parameters to call C routine
; 5) jump to it.
; 6) Put parameters back for trap dispatcher
CASE ON
MACHINE MC68020
INCLUDE 'SysEqu.a'
INCLUDE 'SysErr.a'
INCLUDE 'Traps.a'
IF PATCHEDIN THEN
SEG 'Figment'
ENDIF
MMGlueCode PROC
import c_InitZone
import c_SetApplLimit
import c_MaxApplZone
import c_MoreMasters
import c_GetZone
import c_SetZone
import c_NewHandle
import c_NewEmptyHandle
import c_DisposeHandle
import c_GetHandleSize
import c_GetHandleSize
import c_HandleZone
import c_SetHandleSize
import c_RecoverHandle
import c_ReallocHandle
import c_NewPtr
import c_DisposePtr
import c_GetPtrSize
import c_SetPtrSize
import c_PtrZone
import c_FreeMem
import c_MaxMem
import c_CompactMem
import c_ReserveMem
import c_PurgeMem
import c_EmptyHandle
import c_HLock
import c_HUnlock
import c_HPurge
import c_HNoPurge
import c_SetGrowZone
import c_MoveHHi
import c_MoveHLow
import c_MaxBlock
import c_PurgeSpace
import c_StackSpace
import c_HSetRBit
import c_HClrRBit
import c_HGetState
import c_HSetState
import c_InitProcessMgrHeap
import c_ShrinkSysHeap
import c_LowerProcessMgrZoneBottom
import c_ShrinkProcessMgrZone
import c_ExtendSystemZone
import c_ReclaimSpaceIfSysHeapLow
import c_StraddleBlockSize
import c_ProcessMgrMaxBlock
import c_GetProcessMgrLoFreeBytes
import c_GetSystemHiFreeBytes
import c_RegisterDisposeProc
import c_NewHandleHi
import c_GetNextBlockInHeap
import c_DisposeZone
import c_SetZoneCompatibilityFlags
import c_GetZoneCompatibilityFlags
import c_RegisterHandleTrashNotification
import c_UnregisterHandleTrashNotification
import c_TrashZone
import c_TrashProcess
import c_TrashMemoryArea
import c_NewHandleSystemSafe
import c_NewPtrSystemSafe
import c_EnoughSystemHeapSlop
IF PATCHEDIN THEN
export a_InitZone
export a_SetApplLimit
export a_MaxApplZone
export a_MoreMasters
export a_GetZone
export a_SetZone
export a_NewHandle
export a_NewEmptyHandle
export a_DisposeHandle
export a_GetHandleSize
export a_SetHandleSize
export a_HandleZone
export a_RecoverHandle
export a_ReallocHandle
export a_NewPtr
export a_DisposePtr
export a_GetPtrSize
export a_SetPtrSize
export a_PtrZone
export a_FreeMem
export a_MaxMem
export a_CompactMem
export a_ReserveMem
export a_PurgeMem
export a_EmptyHandle
export a_HLock
export a_HUnlock
export a_HPurge
export a_HNoPurge
export a_SetGrowZone
export a_MoveHHi
export a_MoveHLow
export a_MaxBlock
export a_PurgeSpace
export a_StackSpace
export a_HSetRBit
export a_HClrRBit
export a_HGetState
export a_HSetState
export a_MemoryDispatch
ELSE
export FIG_INITZONETRAP
export FIG_SETAPPLLIMIT
export FIG_MAXAPPLZONE
export FIG_MOREMASTERS
export FIG_GETZONE
export FIG_SETZONE
export FIG_NWHANDLE
export FIG_NEWEMPTYHANDLETRAP
export FIG_DSPOSEHANDLE
export FIG___GETHANDLESIZE
export FIG_SETHANDLESIZETRAP
export FIG_HANDLEZONETRAP
export FIG_RECOVERHANDLETRAP
export FIG_REALLOCHANDLETRAP
export FIG_NEWPTRTRAP
export FIG_DISPOSEPTR
export FIG_GETPTRSIZETRAP
export FIG_SETPTRSIZETRAP
export FIG_PTRZONETRAP
export FIG_FREEMEM
export FIG_MAXMEMTRAP
export FIG_COMPACTMEMTRAP
export FIG_RESRVMEM
export FIG_PURGEMEM
export FIG_EMPTYHANDLE
export FIG_HLOCK
export FIG_HUNLOCK
export FIG_HPURGE
export FIG_HNOPURGE
export FIG_SETGROWZONE
export FIG_MOVEHHI
export FIG_MOVEHLOW
export FIG_MAXBLOCKTRAP
export FIG_PURGESPACETRAP
export FIG_STACKSPACETRAP
export FIG_HRSRC
export FIG_HNORSRC
export FIG_HGETFLAGS
export FIG_HSETFLAGS
export HEAPDISPATCH
ENDIF
; ** offsets for new MM calls **
PreTable
dc.l $6a656666
Table
; This is the selector range for the QT compatibility traps.
dc.w a_HLockQ-Table ; $0 = HLockQ
dc.w a_HUnlockQ-Table ; $1 = HUnlockQ
dc.w a_HPurgeQ-Table ; $2 = HPurgeQ
dc.w a_HNoPurgeQ-Table ; $3 = HNoPurgeQ
dc.w a_HGetStateQ-Table ; $4 = HGetStateQ
dc.w a_HSetStateQ-Table ; $5 = HSetStateQ
dc.w a_RegisterHandleTrashNotification-Table ; $6
dc.w a_RegisterPtrTrashNotification-Table ; $7
dc.w a_UnregisterHandleTrashNotification-Table ; $8
dc.w a_UnregisterPtrTrashNotification-Table ; $9
dc.w a_TrashZone-Table ; $A = TrashZone
dc.w a_TrashMemoryArea-Table ; $B = TrashMemoryArea
dc.w a_TrashProcess-Table ; $C = TrashProcess
dc.w a_NewHandleSystemSafe-Table ; $D = NewHandleSystemSafe
dc.w a_EnoughSystemHeapSlop-Table ; $E = EnoughSystemHeapSlop
dc.w a_NewPtrSystemSafe-Table ; $F = NewPtrSystemSafe
; This is the table for Traps provided by the new heap manager. Most but not
; all of these traps are to support the ProcessMgr....
dc.w a_InitProcessMgrHeap-Table ; $10 = InitProcessMgrHeap (internal use only)
dc.w a_ShrinkSysHeap-Table ; $11 = ShrinkSysHeap (internal use only)
dc.w a_LowerProcessMgrZoneBottom-Table ; $12 = LowerProcessMgrZoneBottom (internal use only)
dc.w a_ShrinkProcessMgrZone-Table ; $13 = ShrinkProcessMgrZone (internal use only)
dc.w a_ExtendSystemZone-Table ; $14 = ExtendSystemZone (internal use only)
dc.w a_ReclaimSpaceIfSysHeapLow-Table ; $15 = ReclaimSpaceIfSysHeapLow (internal use only)
dc.w a_StraddleBlockSize-Table ; $16 = StraddleBlockSize (internal use only)
dc.w a_ProcessMgrMaxBlock-Table ; $17 = ProcessMgrMaxBlock (internal use only)
dc.w a_GetProcessMgrLoFreeBytes-Table ; $18 = GetProcessMgrLoFreeBytes (internal use only)
dc.w a_GetSystemHiFreeBytes-Table ; $19 = GetSystemHiFreeBytes (internal use only)
dc.w a_NewHandleHi-Table ; $1A = NewHandleHi
dc.w a_GetNextBlock-Table ; $1B = GetNextBlock
dc.w a_RegisterDisposeProc-Table ; $1C = RegisterDisposeProc
dc.w a_DisposeZone-Table ; $1D = DisposeZone
dc.w a_SetZoneCompatibilityFlags-Table ; $1E = SetZoneCompatibilityFlags
dc.w a_GetZoneCompatibilityFlags-Table ; $1F = GetZoneCompatibilityFlags
TableSize equ *-Table ; table size in bytes
PostTable
dc.l $6a656666
;-------------------------------------------------------------------------------
; a_InitZone. Interface for InitZone
;
; Input A0 = pointer to parameter block,
; Output D0 = result code (word)
;
; Comment: This is not the most efficient implementation, but it allows
; a similar calling convention
;
IF PATCHEDIN THEN
a_InitZone
ELSE
FIG_INITZONETRAP
ENDIF
move.l (A0),-(SP) ; put zone start on the stack
move.l 4(A0),-(SP) ; put zone limit on the stack
sub.l D0,D0 ; make MP count a 32 bit value
move.w 8(A0),D0 ; for C calling conventions
move.l D0,-(SP) ; put MP count on the stack
move.l $A(A0),-(SP) ; put grow zone ptr on the stack
jsr c_InitZone ; call C implementation
lea $10(SP),SP ; clean up 16 bytes off the stack
rts
;-------------------------------------------------------------------------------
; a_SetApplLimit. Interface for SetApplLimit
;
; Input A0 = Zone limit
; Output D0 = result code (word)
;
IF PATCHEDIN THEN
a_SetApplLimit
ELSE
FIG_SETAPPLLIMIT
ENDIF
move.l A0,-(sp) ; put parameter block ptr on stack
jsr c_SetApplLimit ; call C implementation
addq #4,sp ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_MaxApplZone. Interface for MaxApplZone
;
; Inputs none;
; Output D0 = result code (word)
;
IF PATCHEDIN THEN
a_MaxApplZone
ELSE
FIG_MAXAPPLZONE
ENDIF
jsr c_MaxApplZone ; call C implementation
rts
;-------------------------------------------------------------------------------
; a_MoreMasters. Interface for MoreMasters
;
; Input none;
; Output D0 = result code (word)
;
IF PATCHEDIN THEN
a_MoreMasters
ELSE
FIG_MOREMASTERS
ENDIF
jsr c_MoreMasters ; call C implementation
rts
;-------------------------------------------------------------------------------
; a_GetZone. Interface for GetZone
;
; Input none;
; Outputs D0 = result code (word)
; A0 = the zone (long)
;
IF PATCHEDIN THEN
a_GetZone
ELSE
FIG_GETZONE
ENDIF
jsr c_GetZone ; call C implementation
move.l D0,A0 ; move result into A0
sub.l D0,D0 ; result = noErr
rts
;-------------------------------------------------------------------------------
; a_SetZone. Interface for SetZone
;
; Input A0 = the zone (long)
; Output D0 = result code (word)
;
IF PATCHEDIN THEN
a_SetZone
ELSE
FIG_SETZONE
ENDIF
move.l A0,-(SP) ; put new zone ptr on the stack
jsr c_SetZone ; call C implementation
addq #4,SP ; cleanup 4 bytes from the stack
rts
;-------------------------------------------------------------------------------
; a_NewHandle. Interface for NewHandle
;
; Inputs D0 = size (long)
; D1 = trap word (word)
; Outputs D0 = result code (word)
; A0 = the handle (long)
;
IF PATCHEDIN THEN
a_NewHandle
ELSE
FIG_NWHANDLE
ENDIF
subq #4,SP ; make space for handle
move.l D0,-(SP) ; put size on the stack
move.l D1,-(SP) ; put trap word on the stack
pea 8(SP) ; push pointer to handle on stack
jsr c_NewHandle ; call C implementation
lea 12(SP),SP ; cleanup 12 bytes from the stack
move.l (SP)+,A0 ; put handle in A0
rts
;-------------------------------------------------------------------------------
; a_NewEmptyHandle. Interface for NewEmptyHandle
;
; Inputs D1 = trap word (word)
; Outputs D0 = result code (word)
; A0 = the handle (long)
;
IF PATCHEDIN THEN
a_NewEmptyHandle
ELSE
FIG_NEWEMPTYHANDLETRAP
ENDIF
subq #4,SP ; make space for handle
move.l D1,-(SP) ; put trap word on the stack (C requires long)
pea 4(SP) ; push pointer to handle on stack
jsr c_NewEmptyHandle ; call C implementation
addq #8,SP ; cleanup 8 bytes from the stack
move.l (SP)+,A0 ; put handle in A0
rts
;-------------------------------------------------------------------------------
; a_DisposeHandle. Interface for DisposeHandle
;
; Input A0 = handle to dispose
; Output D0 = result code (word)
;
IF PATCHEDIN THEN
a_DisposeHandle
ELSE
FIG_DSPOSEHANDLE
ENDIF
move.l A0,-(SP) ; put handle on stack
jsr c_DisposeHandle ; call C implementation
addq #4,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_GetHandleSize. Interface for GetHandleSize
;
; Input A0 = handle to get
; Output D0 = if >= 0, size of handle (long), this is handled by c_GetHandleSize
; if < 0, result code (word)
;
; Note: The extra note in IM about GetHandleSize returning 0 is handled in the
; the MPW glue to this routine. We can't do it here.
;
;
IF PATCHEDIN THEN
a_GetHandleSize
ELSE
FIG___GETHANDLESIZE
ENDIF
move.l A0,-(SP) ; put handle on stack
jsr c_GetHandleSize ; call C implementation
addq #4,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_SetHandleSize. Interface for SetHandleSize
;
; Inputs D0 = requested size
; A0 = handle to set
; Output D0 = result code (word)
;
;
;
IF PATCHEDIN THEN
a_SetHandleSize
ELSE
FIG_SETHANDLESIZETRAP
ENDIF
move.l D0,-(SP) ; put size on stack
move.l A0,-(SP) ; put handle on stack
jsr c_SetHandleSize ; call C implementation
addq #8,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_HandleZone. Interface for c_HandleZone
;
; Inputs A0 = handle (long)
; Outputs D0 = result code (word)
; A0 = the handle (long)
;
IF PATCHEDIN THEN
a_HandleZone
ELSE
FIG_HANDLEZONETRAP
ENDIF
subq #4,SP ; make space for the zone
move.l A0,-(SP) ; put handle on the stack
pea 4(SP) ; push pointer to the zone on stack
jsr c_HandleZone ; call C implementation
addq #8,SP ; cleanup 8 bytes from the stack
move.l (SP)+,A0 ; put handle in A0
rts
;-------------------------------------------------------------------------------
; a_RecoverHandle. Interface for RecoverHandle
;
; Inputs A0 = handle (long)
; Outputs A0 = the handle (long)
; *Warning*, D0 is unchanged
;
IF PATCHEDIN THEN
a_RecoverHandle
ELSE
FIG_RECOVERHANDLETRAP
ENDIF
move.l D0,-(SP) ; Save D0 for some stupid reason
move.l A0,-(SP) ; put client ptr on the stack
move.l D1,-(SP) ; put trap word on the stack (C requires long)
jsr c_RecoverHandle ; call C implementation
addq #8,SP ; cleanup 8 bytes from the stack
move.l D0,A0 ; move the handle to A0
move.l (SP)+,D0 ; restore D0
rts
;-------------------------------------------------------------------------------
; a_ReallocHandle. Interface for ReallocHandle
;
; Inputs D0 = size to allocate (long)
; A0 = original handle
; Output D0 = result code (word)
;
;
;
IF PATCHEDIN THEN
a_ReallocHandle
ELSE
FIG_REALLOCHANDLETRAP
ENDIF
move.l D0,-(SP) ; put size on stack
move.l A0,-(SP) ; put handle on stack
jsr c_ReallocHandle ; call C implementation
addq #8,SP ; cleanup 8 bytes from the stack
rts
;-------------------------------------------------------------------------------
; a_NewPtr. Interface for NewPtr
;
; Inputs D0 = size (long)
; D1 = trap word (word)
; Outputs D0 = result code (word)
; A0 = thePtr (long)
;
IF PATCHEDIN THEN
a_NewPtr
ELSE
FIG_NEWPTRTRAP
ENDIF
subq #4,SP ; make space for handle
move.l D0,-(SP) ; put size on the stack
move.l D1,-(SP) ; put trap word on the stack (C requires long)
pea 8(SP) ; push pointer to thePtr on stack
jsr c_NewPtr ; call C implementation
lea $C(SP),SP ; cleanup 12 bytes from the stack
move.l (SP)+,A0 ; put thePtr in A0
rts
;-------------------------------------------------------------------------------
; a_DisposePtr. Interface for DisposePtr
;
; Input A0 = ptr to dispose
; Output D0 = result code (word)
;
IF PATCHEDIN THEN
a_DisposePtr
ELSE
FIG_DISPOSEPTR
ENDIF
move.l A0,-(SP) ; put ptr on stack
jsr c_DisposePtr ; call C implementation
addq #4,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_GetPtrSize. Interface for GetPtrSize
;
; Input A0 = handle to get
; Output D0 = if >= 0, size of handle (long), this is handled by c_GetHandleSize
; if < 0, result code (word)
;
; Note: The extra note in IM about GetPtrSize returning 0 is handled in the
; the MPW glue to this routine. We can't do it here.
;
IF PATCHEDIN THEN
a_GetPtrSize
ELSE
FIG_GETPTRSIZETRAP
ENDIF
move.l A0,-(SP) ; put handle on stack
jsr c_GetPtrSize ; call C implementation
addq #4,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_SetPtrSize. Interface for SetPtrSize
;
; Inputs D0 = requested size
; A0 = handle to set
; Output D0 = result code (word)
;
IF PATCHEDIN THEN
a_SetPtrSize
ELSE
FIG_SETPTRSIZETRAP
ENDIF
move.l D0,-(SP) ; put size on stack
move.l A0,-(SP) ; put handle on stack
jsr c_SetPtrSize ; call C implementation
addq #8,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_PtrZone. Interface for PtrZone
;
; Inputs A0 = handle (long)
; Outputs D0 = result code (word)
; A0 = the handle (long)
;
IF PATCHEDIN THEN
a_PtrZone
ELSE
FIG_PTRZONETRAP
ENDIF
subq #4,SP ; make space for the zone
move.l A0,-(SP) ; put ptr on the stack
pea 4(SP) ; push pointer to the zone on stack
jsr c_PtrZone ; call C implementation
addq #8,SP ; cleanup 8 bytes from the stack
move.l (SP)+,A0 ; put zone in A0, cleanup stack
rts
;-------------------------------------------------------------------------------
; a_FreeMem. Interface for FreeMem
;
; Input D1 = trap word (word)
; Output D0 = function result (long word)
;
IF PATCHEDIN THEN
a_FreeMem
ELSE
FIG_FREEMEM
ENDIF
move.l D1,-(SP) ; put trap word on the stack (C requires long)
jsr c_FreeMem ; call C implementation
addq #4,sp ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_MaxMem. Interface for MaxMem
;
; Inputs D1 = trap word (word)
; Outputs D0 = function result (long)
; A0 = grow size (long)
;
IF PATCHEDIN THEN
a_MaxMem
ELSE
FIG_MAXMEMTRAP
ENDIF
subq #4,SP ; make space for grow size
pea (SP) ; push pointer to grow size on stack
move.l D1,-(SP) ; put trap word on the stack (C requires long)
jsr c_MaxMem ; call C implementation
addq #8,SP ; cleanup 6 bytes from the stack
move.l (SP)+,A0 ; put grow size in A0, adjust stack
rts
;-------------------------------------------------------------------------------
; a_CompactMem. Interface for CompactMem
;
; Inputs D0 = size needed (long)
; D1 = trap word (word)
; Outputs D0 = function result (long)
;
IF PATCHEDIN THEN
a_CompactMem
ELSE
FIG_COMPACTMEMTRAP
ENDIF
move.l D0,-(SP) ; put sizeNeeded of stack
move.l D1,-(SP) ; put trap word on the stack (C requires long)
jsr c_CompactMem ; call C implementation
addq #8,SP ; cleanup 6 bytes from the stack
rts
;-------------------------------------------------------------------------------
; a_ReserveMem. Interface for ReserveMem
;
; Inputs D0 = size needed (long)
; D1 = trap word (word)
; Outputs D0 = function result (long)
;
IF PATCHEDIN THEN
a_ReserveMem
ELSE
FIG_RESRVMEM
ENDIF
move.l D0,-(SP) ; put sizeNeeded of stack
move.l D1,-(SP) ; put trap word on the stack (C requires long)
jsr c_ReserveMem ; call C implementation
addq #8,SP ; cleanup 6 bytes from the stack
rts
;-------------------------------------------------------------------------------
; a_PurgeMem. Interface for PurgeMem
;
; Inputs D0 = size needed (long)
; D1 = trap word (word)
; Outputs D0 = function result (long)
;
IF PATCHEDIN THEN
a_PurgeMem
ELSE
FIG_PURGEMEM
ENDIF
move.l D0,-(SP) ; put sizeNeeded of stack
move.l D1,-(SP) ; put trap word on the stack (C requires long)
jsr c_PurgeMem ; call C implementation
addq #8,SP ; cleanup 6 bytes from the stack
rts
;-------------------------------------------------------------------------------
; a_EmptyHandle. Interface for EmptyHandle
;
; Input A0 = handle to empty
; Output D0 = result code (word)
; A0 = handle to empty
;
; note: The Handle does not change, however the MP does.
;
IF PATCHEDIN THEN
a_EmptyHandle
ELSE
FIG_EMPTYHANDLE
ENDIF
move.l A0,-(SP) ; put handle on stack
jsr c_EmptyHandle ; call C implementation
addq #4,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_HLock. Interface for HLock
;
; Input A0 = handle to lock
; Output D0 = result code (word)
;
IF PATCHEDIN THEN
a_HLock
ELSE
FIG_HLOCK
ENDIF
move.l A0,-(SP) ; put handle on stack
jsr c_HLock ; call C implementation
addq #4,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_HUnlock. Interface for HUnlock
;
; Input A0 = handle to unlock
; Output D0 = result code (word)
;
IF PATCHEDIN THEN
a_HUnlock
ELSE
FIG_HUNLOCK
ENDIF
move.l A0,-(SP) ; put handle on stack
jsr c_HUnlock ; call C implementation
addq #4,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_HPurge. Interface for HPurge
;
; Input A0 = handle to purge
; Output D0 = result code (word)
;
IF PATCHEDIN THEN
a_HPurge
ELSE
FIG_HPURGE
ENDIF
move.l A0,-(SP) ; put handle on stack
jsr c_HPurge ; call C implementation
addq #4,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_HNoPurge. Interface for HNoPurge
;
; Input A0 = handle to not purge
; Output D0 = result code (word)
;
IF PATCHEDIN THEN
a_HNoPurge
ELSE
FIG_HNOPURGE
ENDIF
move.l A0,-(SP) ; put handle on stack
jsr c_HNoPurge ; call C implementation
addq #4,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_SetGrowZone. Interface for SetGrowZone
;
; Input A0 = pointer to grow zone proc
; Output D0 = result code (word)
;
IF PATCHEDIN THEN
a_SetGrowZone
ELSE
FIG_SETGROWZONE
ENDIF
move.l A0,-(SP) ; put handle on stack
jsr c_SetGrowZone ; call C implementation
addq #4,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_MoveHHi. Interface for MoveHHi
;
; Input A0 = handle to move
; Output D0 = result code (word)
;
IF PATCHEDIN THEN
a_MoveHHi
ELSE
FIG_MOVEHHI
ENDIF
move.l A0,-(SP) ; put handle on stack
jsr c_MoveHHi ; call C implementation
addq #4,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_MoveHLow. Interface for MoveHLow
;
; Input A0 = handle to move
; Output D0 = result code (word)
;
IF PATCHEDIN THEN
a_MoveHLow
ELSE
FIG_MOVEHLOW
ENDIF
move.l A0,-(SP) ; put handle on stack
jsr c_MoveHLow ; call C implementation
addq #4,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_MaxBlock. Interface for MaxBlock
;
; Inputs D1 = trap word (word)
; Outputs D0 = function result (long)
;
IF PATCHEDIN THEN
a_MaxBlock
ELSE
FIG_MAXBLOCKTRAP
ENDIF
move.l D1,-(SP) ; put trap word on the stack (C requires long)
jsr c_MaxBlock ; call C implementation
addq #4,SP ; cleanup 8 bytes from the stack
rts
;-------------------------------------------------------------------------------
; c_PurgeSpace. Interface for PurgeSpace
;
; Input D1 = trap word (word)
; Outputs D0 = total (long)
; A0 = contig (long)
;
IF PATCHEDIN THEN
a_PurgeSpace
ELSE
FIG_PURGESPACETRAP
ENDIF
subq #4,SP ; make space for contig parameter
pea (SP) ; push pointer to contig on the stack
move.l D1,-(SP) ; put trap word on the stack (C requires long)
jsr c_PurgeSpace ; call C implementation
addq #8,SP ; pop parameters off stack
move.l (SP)+,A0 ; put contig in A0
rts
;-------------------------------------------------------------------------------
; a_StackSpace. Interface for StackSpace
;
; Input none;
; Output D0 = function result (long)
;
IF PATCHEDIN THEN
a_StackSpace
ELSE
FIG_STACKSPACETRAP
ENDIF
; Note: as a otimization, we a now implementing this short trap right here
; since its called very often and is very small.
moveq #30,D0 ;fudge factor (changed from 20 to support figment)
add.l SP,D0 ;
andi.w #$FFFC,D0 ;round down to multiple of 4
sub.l HiHeapMark,D0 ;
clr.w MemErr ;no problem here
rts
; This is the way to call high level glue
; jsr c_StackSpace ; call C implementation
; rts
;-------------------------------------------------------------------------------
; a_HSetRBit. Interface for HSetRBit
;
; Input A0 = handle to modify
; Output D0 = result code (word)
;
IF PATCHEDIN THEN
a_HSetRBit
ELSE
FIG_HRSRC
ENDIF
move.l A0,-(SP) ; put handle on stack
jsr c_HSetRBit ; call C implementation
addq #4,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_HClrRBit. Interface for HClrRBit
;
; Input A0 = handle to modify
; Output D0 = result code (word)
;
IF PATCHEDIN THEN
a_HClrRBit
ELSE
FIG_HNORSRC
ENDIF
move.l A0,-(SP) ; put handle on stack
jsr c_HClrRBit ; call C implementation
addq #4,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_HGetState. Interface for HGetState
;
; Input A0 = handle to get
; Output D0 = handle state (byte)
;
;
IF PATCHEDIN THEN
a_HGetState
ELSE
FIG_HGETFLAGS
ENDIF
move.l A0,-(SP) ; put handle on stack
jsr c_HGetState ; call C implementation
addq #4,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_HSetState. Interface for HSetState
;
; Inputs D0 = new flags (byte)
; A0 = handle to set
; Output D0 = result code (word)
;
;
IF PATCHEDIN THEN
a_HSetState
ELSE
FIG_HSETFLAGS
ENDIF
move.l D0,-(SP) ; put flags on stack, its a longword not a byte
move.l A0,-(SP) ; put handle on stack
jsr c_HSetState ; call C implementation
addq #8,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; HeapDispatch. Interface for HeapDispatch (Trap $A0A4)
;
; Inputs D0 = selector
; Outputs It depends
;
;
IF PATCHEDIN THEN
a_MemoryDispatch
ELSE
HEAPDISPATCH
ENDIF
tst.w D0 ; normalize selector to 0..n
bmi.s @selectorOutOfRange ; selector is out of range...
cmp.w #TableSize/2,d0 ; is there a table entry for this one?
bhi.s @selectorOutOfRange ; no, selector is out of range...
lea Table,a2 ; get the address of the selected routine
add.w (a2,d0.w*2),a2
jsr (a2) ; call the selected routine
rts
@selectorOutOfRange
_debugger
move.l #paramErr,d0 ; abort: return error code
rts
;-------------------------------------------------------------------------------
; a_InitProcessMgrHeap. Interface for InitProcessMgrHeap
;
; Inputs A0 = old ProcessMgr zone
; Output D0 = new ProcessMgr zone
;
;
a_InitProcessMgrHeap
move.l A0,-(SP) ; put old ProcessMgr zone on the stack
jsr c_InitProcessMgrHeap ; call C implementation
addq #4,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_ShrinkSysHeap. Interface for ShrinkSysHeap
;
; Inputs A0 = Amount to shrink
; Output D0 = Actual size it shrank
;
;
a_ShrinkSysHeap
move.l A0,-(SP) ; put size needed on the stack
jsr c_ShrinkSysHeap ; call C implementation
addq #4,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_LowerProcessMgrZoneBottom. Interface for LowerProcessMgrZoneBottom
;
; Inputs A0 = Amount to lower
; A1 = ptr to ProcessMgr zone
; Outputs none.
;
;
a_LowerProcessMgrZoneBottom
move.l A1,-(SP) ; put PM zone pointer on the stack
move.l A0,-(SP) ; put size needed on the stack
jsr c_LowerProcessMgrZoneBottom ; call C implementation
addq #8,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_ShrinkProcessMgrZone. Interface for ShrinkProcessMgrZone
;
; Inputs A0 = Amount to lower
; A1 = ptr to ProcessMgr zone
; Output D0 = Actual size it shrank
;
;
a_ShrinkProcessMgrZone
move.l A1,-(SP) ; put PM zone pointer on the stack
move.l A0,-(SP) ; put size needed on the stack
jsr c_ShrinkProcessMgrZone ; call C implementation
addq #8,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_ExtendSystemZone. Interface for ExtendSystemZone
;
; Inputs A0 = size to extend
; Outputs none
;
;
a_ExtendSystemZone
move.l A0,-(SP) ; put size needed on the stack
jsr c_ExtendSystemZone ; call C implementation
addq #4,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_ReclaimSpaceIfSysHeapLow. Interface for ReclaimSpaceIfSysHeapLow
;
; Inputs A0 = ptr to handle
; A1 = ptr to ProcessMgr zone
; Outputs none
;
;
a_ReclaimSpaceIfSysHeapLow
move.l A1,-(SP) ; put PM zone pointer on the stack
move.l A0,-(SP) ; put pointer to the new handle on the stack
jsr c_ReclaimSpaceIfSysHeapLow ; call C implementation
addq #8,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_StraddleBlockSize. Interface for StraddleBlockSize
;
; Input A0 = pointer to parameter block,
; Output D0 = result code (word)
;
; Comment: This glue is very similar to InitZone
;
a_StraddleBlockSize
move.l (A0),-(SP) ; put zone start on the stack
move.l 4(A0),-(SP) ; put sawInterestingBlock on stack
move.l 8(A0),-(SP) ; put blockOfInterest on stack
move.l $C(A0),-(SP) ; put highSysStorage
move.l $10(A0),-(SP) ; put lowPMStorage
jsr c_StraddleBlockSize ; call C implementation
lea $14(SP),SP ; clean up 20 bytes off the stack
rts
;-------------------------------------------------------------------------------
; a_ProcessMgrMaxBlock. Interface for ProcessMgrMaxBlock
;
; Inputs A0 = ptr to ProcessMgr zone
; Output D0 = Max size
;
;
a_ProcessMgrMaxBlock
move.l A0,-(SP) ; put size needed on the stack
jsr c_ProcessMgrMaxBlock ; call C implementation
addq #4,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_GetProcessMgrLoFreeBytes. Interface for GetProcessMgrLoFreeBytes
;
; Inputs A0 = Handle of interest
; A1 = Saw interesting block pointer
; Output D0 = Low free bytes
;
;
a_GetProcessMgrLoFreeBytes
move.l A1,-(SP) ; put sawInterestingBlock ptr on the stack
move.l A0,-(SP) ; put handle of interest on the stack
jsr c_GetProcessMgrLoFreeBytes ; call C implementation
addq #8,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_GetSystemHiFreeBytes. Interface for GetSystemHiFreeBytes
;
; Inputs none.
; Output D0 = Size we got
;
;
a_GetSystemHiFreeBytes
jsr c_GetSystemHiFreeBytes ; call C implementation
rts
;-------------------------------------------------------------------------------
; a_RegisterDisposeProc. Interface for RegisterDisposeProc
;
; Inputs A0 = Proc to register
; A1 = Zone Ptr
; Output D0 = Result code (could be memFullErr)
;
;
a_RegisterDisposeProc
move.l A1,-(SP) ; put zone pointer on the stack
move.l A0,-(SP) ; put proc ptr on the stack
jsr c_RegisterDisposeProc ; call C implementation
addq #8,SP ; clean up 8 bytes off the stack
rts
;-------------------------------------------------------------------------------
; a_NewHandleHi. Interface for NewHandleHi
;
; Inputs A0 = size (long) since selector is in D0
; D1 = trap word (word)
; Outputs D0 = result code (word)
; A0 = the handle (long)
;
; note: Trap dispatcher will not preserve A0 recause the routine passes it back.
;
a_NewHandleHi
subq #4,SP ; make space for handle
move.l A0,-(SP) ; put requested size on the stack
move.l D1,-(SP) ; put trap word on the stack
pea 8(SP) ; push pointer to handle on stack
jsr c_NewHandleHi ; call C implementation
lea 12(SP),SP ; cleanup 12 bytes from the stack
move.l (SP)+,A0 ; put handle in A0
rts
;-------------------------------------------------------------------------------
; a_GetNextBlock. Interface for GetNextBlock
;
; Inputs A0 = Ptr to currrent block
; A1 = Zone Ptr
; Output D0 = Ptr to next block
;
;
a_GetNextBlock
move.l A1,-(SP) ; put zone pointer on the stack
move.l A0,-(SP) ; put currentBlock ptr on the stack
jsr c_GetNextBlockInHeap ; call C implementation
addq #8,SP ; clean up 8 bytes off the stack
rts
;-------------------------------------------------------------------------------
; a_DisposeZone. Interface for DisposeZone
;
; Inputs A0 = Zone to dispose (long)
; Output D0 = result code (word)
;
;
a_DisposeZone
move.l A0,-(SP) ; put zone pointer on the stack
jsr c_DisposeZone ; call C implementation
addq #4,SP ; clean up 4 bytes off the stack
rts
;-------------------------------------------------------------------------------
; c_SetZoneCompatibilityFlags. Interface for SetZoneCompatibilityFlags
;
; Inputs A1 = new flags (word)
; A0 = zone to set
; Output D0 = result code (word)
;
;
a_SetZoneCompatibilityFlags
move.l A1,-(SP) ; put flags on stack, its a longword not a short
move.l A0,-(SP) ; put the zone on stack
jsr c_SetZoneCompatibilityFlags ; call C implementation
addq #8,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; a_GetZoneCompatibilityFlags. Interface for GetZoneCompatibilityFlags
;
; Input A0 = zone to get
; Output D0 = flags state
;
;
a_GetZoneCompatibilityFlags
move.l A0,-(SP) ; put zone on stack
jsr c_GetZoneCompatibilityFlags ; call C implementation
addq #4,SP ; clean up stack
rts
;-------------------------------------------------------------------------------
; QuickTime compatibility calls.. Hopefully these will go away
;
;
; Stage I, Quick Handle calls....
;
;
a_HLockQ
_HLock
rts
a_HUnlockQ
_HUnlock
rts
a_HPurgeQ
_HPurge
rts
a_HNoPurgeQ
_HNoPurge
rts
a_HGetStateQ
_HGetState
rts
a_HSetStateQ
move.l A1,D0 ;move state into D0
_HSetState
rts
;-------------------------------------------------------------------------------
; QuickTime compatibility calls.. Hopefully these will go away
;
;
; Stage II, "Butt ugly" memory area notification scheme.....
;
;
a_RegisterHandleTrashNotification
;move.l A1,-(SP) ; put handle on the stack
move.l A0,-(SP) ; put Trash Proc Ptr on the stack
jsr c_RegisterHandleTrashNotification
addq #4,SP ; clean up 4 bytes off the stack
rts
a_RegisterPtrTrashNotification
; not implemented, dont need to support
;move.l A1,-(SP) ; put ptr on the stack
;move.l A0,-(SP) ; put Trash Proc Ptr on the stack
;jsr c_RegisterPtrTrashNotification
;addq #8,SP ; clean up 8 bytes off the stack
rts
a_UnregisterHandleTrashNotification
;move.l A1,-(SP) ; put handle on the stack
move.l A0,-(SP) ; put Trash Proc Ptr on the stack
jsr c_UnregisterHandleTrashNotification
addq #4,SP ; clean up 4 bytes off the stack
rts
a_UnregisterPtrTrashNotification
; not implemented, dont need to support
;move.l A1,-(SP) ; put ptr on the stack
;move.l A0,-(SP) ; put Trash Proc Ptr on the stack
;jsr c_UnregisterPtrTrashNotification
;addq #8,SP ; clean up 8 bytes off the stack
rts
a_TrashZone
move.l A0,-(SP) ; put psn ptr on stack
jsr c_TrashZone
addq #4,SP ; clean up 4 bytes off the stack
rts
a_TrashMemoryArea
move.l A1,-(SP) ; put end address on stack
move.l A0,-(SP) ; put start address on stack
jsr c_TrashMemoryArea
addq #8,SP ; clean up 8 bytes off the stack
rts
a_TrashProcess
move.l A0,-(SP) ; put psn ptr on stack
jsr c_TrashProcess
addq #4,SP ; clean up 4 bytes off the stack
rts
;-------------------------------------------------------------------------------
; QuickTime compatibility calls.. Hopefully these will go away
;
;
; Stage III, Safe System Heap memory allocations.....
;
;
a_NewHandleSystemSafe
move.l A0,-(SP) ; put size on the stack
jsr c_NewHandleSystemSafe
addq #4,SP ; clean up 4 bytes off the stack
move.l D0,A0 ; move return result into A0
rts
a_EnoughSystemHeapSlop
jsr c_EnoughSystemHeapSlop
; return result returned in D0
rts
a_NewPtrSystemSafe
move.l A0,-(SP) ; put size on the stack
jsr c_NewPtrSystemSafe
addq #4,SP ; clean up 4 bytes off the stack
move.l D0,A0 ; move return result into A0
rts
END