QDOS Internals

Anything you never knew you wanted to know about the Sinclair QL.

User Tools

Site Tools



This shows you the differences between two versions of the page.

Link to this comparison view

Next revision
Previous revision
qdosmsq:traps:trap_1:rehp [2009/01/30 11:44]
norman created
qdosmsq:traps:trap_1:rehp [2021/12/20 17:11]
norman [Notes] Updated notes on standard process.
Line 1: Line 1:
 +====== MT_LNKFR/SMS_REHP ======
 +This trap frees previously allocated space in a user heap. 
 +^Call Parameters^^Return Parameters^^
 +|D1.L|Size of area to be linked (back) in to the user heap. |D1.L|Corrupted.|
 +|D2.L|Unused. |D2.L| Corrupted.|
 +|D3.L|Unused. |D3.L| Corrupted.|
 +|A0.L|Address of the area of heap/memory to link (back) in to the user heap (Relative A6). |A0.L|Corrupted.|
 +|A1.L|Pointer to pointer to free space (Relative A6) or zero. |A1.L| Corrupted.|
 +|A2.L|Unused. |A2.L| Corrupted.|
 +===== Errors =====
 +No errors are returned by this trap.
 +===== Notes =====
 +  * All registers not shown above are not used on entry and are preserved on exit.
 +  * A user heap is an area of memory, maybe in the common heap, set aside for use by a single job. The job can allocate areas of this user heap for its own needs, and deallocate them as required. This stops, or reduces fragmentation of the common heap which is used by every task in the system. [[qdosmsq:memory:heaps|See here]] for more information on heaps.
 +  * If the long word at (A1,A6) is zero, then this trap will create a new user heap at the address in A0.
 +  * If (A1,A6) is not zero, then you are assumed to be releasing a previously allocated chunk of user heap back into the user heap's free space.
 +  * Normally, the sequence of events would be:
 +    * Allocate some space in the common heap, address in A0;
 +    * Call MT_LNKFR/SMS_REHP to link the space into a heap with the word at (a6,a1.l) set to zero and the heap space in A0;
 +    * Repeat as necessary:
 +      * Allocate space from the heap;
 +      * Use the space allocated;
 +      * Return allocations to the heap;
 +    * End Repeat
 +    * Return the allocated space back to the common heap.
 +===== Example =====
 +[[qdosmsq:traps:trap_1:heaps|This example]] show the use of this, and other, heap
 +manipulation traps.
qdosmsq/traps/trap_1/rehp.txt ยท Last modified: 2021/12/20 17:11 by norman