A header file named instruct.h declares a number of memory management and stack operations on a data structure of the following form.
     struct instruction_node
     {
       port client;
       score sheet;
       struct avm_packet actor;
       struct avm_packet datum;
       instruction dependents;
     };
   In this structure, an instruction is a pointer to an
instruction_node, a score is a pointer to a profile
database entry as discussed in Profiling, and the port and
avm_packet types are as described in Ports and Packets.
   
This data structure is appropriate for a simple virtual machine code
evaluation strategy involving no concurrency. The strategy to evaluate an
expression f x would be based on a stack of these
nodes threaded through the dependents field, and would proceed
something like this.
     
actor.contents field, and x in
its datum.contents field. 
client in this node would refer to a static packet to whose
contents field the final result will be delivered. 
actor.contents field on the top of the
stack, detects by its form the operation it represents, and decides
whether it corresponds to one that can be evaluated immediately by way
of a canned function available in the library. List reversal,
transposition, and comparison would be examples of such operations. 
client field. 
compose(g,h) (silly notation), the node with
f and x would be popped, but a node with
g as its actor.contents would be pushed, and then a
node with h as its actor.contents and x
as its datum.contents would be pushed. Furthermore, the
client field of the latter node would point to the
datum.contents of the one with g, and the
client field of the one with g would point
wherever the client of the popped node used to point. 
actor.contents is neither
implemented by a canned operation in the library nor easily decomposable
into some that are, the evaluator can either give up or use virtual code
to execute other virtual code. The latter trick is accomplished by
pushing a node with f as its datum.contents, and a
copy of a hard coded virtual code interpreter V as its
actor.contents. The client of this node will point to the
f in the original node so as to overwrite it when a
simplified version is subsequently computed. The implementation of
V is a straightforward exercise in silly
programming. 
client
in the original instruction node.
        What makes this strategy feasible to implement is the assumption of a
sequential language, wherein synchronization incurs no cost and is
automatic. The availability of any operand is implied by its position at
the top of the stack. If you are reading this section with a view to
implementing a concurrent or multi-threaded evaluation strategy, it will
be apparent that further provisions would need to be made, such as that
of a data_ready flag added to the avm_packet structure.
   
The following functions support the use of stacks of instruction nodes that would be needed in an evaluation strategy such as the one above.
This function performs the memory allocation for instruction nodes. It attempts to create one and to initialize the fields with the given parameters, returning a pointer to it if successful. It returns a
NULLpointer if the storage could not be allocated.Copies of the
listparametersactor_contentsanddata_contentsare made by this function usingavm_copied, so the originals still exist as far as the caller is concerned and will have to be deallocated separately from this structure. The copies are made only if the allocation succeeds.Any fields other than those indicated by the parameters to this function are filled with zeros in the result.
This function performs the storage reclamation of instructions, taking as its argument the instruction to be reclaimed. The
listfields in the structure corresponding to thelistparameters used when it was created are specifically reclaimed as well, usingavm_dispose.The argument to this function is the address of an
instructionrather than just aninstructionso that theinstructionwhose address is given may be reassigned as thedependentsfield of the deallocated node. In this way, the instructions can form a stack that is popped by this function.This function cooperates with
avm_scheduledin the use of a local cache of instruction nodes in the interest of better performance. Client modules should not attempt to allocate or reclaim instructions directly withmallocorfree, but use only these functions.It causes a fatal internal error to pass a
NULLpointer to this function.
Given the address of an instruction pointer that may be regarded as the top of a stack of instructions threaded through the
dependentsfield, this function exchanges the positions of the top instruction and the one below it. A fatal internal error is caused if there are fewer than two instructions in the stack.A use for this function arises in the course of evaluating virtual code applications of the form
conditional(p,(f,g))(insillynotation). The evaluation strategy would require pushing nodes for all three constituents, but with p pushed last (therefore evaluated first). The result of the evaluation of p would require either the top one or the one below it to be popped without being evaluated, depending on whether the result is empty.
This function should be called before any of the instruction memory management functions is called in order to initialize some local data structures. Results are unpredictable without it.
This function should be called after the last call to any of the other functions in this section in order to detect and report unreclaimed storage associated with them. A warning message will be written to standard error if any unreclaimed instructions remain. This function relies on the assumption that the memory management has been done only by way of the above functions.