core.ops - Core Opcodes
Parrot's core library of ops.
Core operations are primarily flow control and interpreter introspection.
When making changes to any ops file,
make bootstrap-ops to regenerate all generated ops files.
These are the fundamental operations. Please note: These opcodes must not be moved; they must have exactly these opcode numbers. Opcodes ending with underscores are for internal use only; don't emit these opcodes.
Halts the interpreter. See also exit.
Does nothing other than waste an iota of time and 32 bits of bytecode space.
Check the event queue and run event handlers if there are unhandled events. Note: This opcode is mainly for testing. It should not be necessary to ever use it explicitly.
Check the event queue and run event handlers if there are unhandled events. Note: Do not use this opcode. It is for internal use only.
Load Parrot bytecode from file $1, and search the library path to locate the file. Automatically triggers :load functions if the file found is a .pbc. If it is a .pir or a .pasm, the file is compiled first and the :init subs are triggered instead. Nothing is returned.
Load Parrot bytecode from file $2, searching the library path to locate the file. Returns a new PackfileView in $1. Does not perform any automatic initialization. Use the PackfileView PMC interface to introspect and perform actions on it.
Load the compiler libraries for a language $1. Search the library path to locate the main compiler file in the standard locations.
The control flow opcodes check conditions and manage program flow.
Branch forward or backward by the amount in $1.
Go to the location specified by the label in $2. Push the current location onto the stack passed in $1 for later returning.
Pop the location off the top of the call stack and go there.
Jump to the address held in register $1.
These operations perform a conditional relative branch. If the condition is met, the branch happens. Otherwise control falls to the next operation.
Check register $1. If true, branch by $2.
Check register $1. If false, branch by $2.
These operations are used to generate and call subroutines and continuations.
Call the subroutine in $1 and generate a new return continuation, if needed. For example, a NCI subroutine which executes code in some C library will not create a continuation, nor will anything but the first call to a coroutine.
Call the subroutine in $1 and use continuation $2.
Yield results from a coroutine.
Call the subroutine in $1 and use the current continuation as the subs continuation.
Return from the sub or method via the current continuation.
Capture the current lexical state of the inner subroutine PMC.
Create a closure of the given subroutine PMC by cloning the sub's state.
Implementations of function argument and params handling
Define arguments for the next function call.
Define return values for the next function call.
Define function parameters for this subroutine.
Define return results for the subroutine return statement.
For all of these opcodes the passed invar PMC constant is the string representation of a FixedIntegerArray with one flag word per argument. The flags are documented currently in include/parrot/enums.h only.
After this argument a variable amount of arguments must follow according to the elements of the signature array.
Returns the get_results signature PMC of the caller. This PMC is a FixedIntegerPMCArray. The number of elements of this PMC is equal to the number of return values that are expected. The individual bits per entry are specified in docs/pdds/pdd03_calling_conventions.pod.
Sets register $1 to the current address plus the offset $2.
Sets PMC in register $1 to the current address plus the offset $2.
Sets PMC in register $1 to the absolute address $2 obtained from get_addr.
Sets $1 to the absolute address of the Sub PMC $2.
Register a task with the concurrency scheduler. Details about the task are stored within the task PMC.
Add an event or exception handler to the concurrency scheduler. Details about the handler are stored within the handler PMC.
Create an exception handler for the given catch label and push it onto the exception handler stack.
Push an invokable PMC onto the exception handler stack.
Pop the most recently placed exception off the handler stack.
Throw the exception in $1 with current continuation.
Throw the exception in $1 with continuation from $2.
Only valid inside an exception handler. Rethrow the exception $1.
Get a count of currently active exception handlers on the stack.
Die with message $1
Die with severity $1 and error $2. If severity is .EXCEPT_DOOMED, call _exit($2). The latter isn't catchable.
Exit the interpreter with exit_status $1. If you want to communicate an extended exit status, create an exception with severity EXCEPT_exit and throw it.
Finalize exception handling, freeing any information needed to resume the handled exception, like inner runloops. $1 is the Exception handled or the ExceptionHandler that is handling it.
Pops all exception handlers upto the one indicated by $1. Like with the finalize op, $1 can either be the handled Exception or the ExceptionHandler handling it. Also, you should not resume Exceptions after pop_upto_eh or finalize has been called. This limitation may be fixed in a future version of parrot. Also note that the specified exception handler is not popped.
Returns the caught exception without clearing the call object. This is currently needed because HLL authors use get_params to fetch the exception, but get_params clears the call object. So we can't use get_params in PCT to get the exception object without disturbing the HLL code. This op will be removed again when PCT offers another mechansim to get the exception and the HLLs switched to it.
These operations inspect or modify the interpreter itself, possibly affecting its subsequent operation.
If $1 is zero, turn off debugging. Otherwise turn debug flag $1 on.
If $1 is zero, turn off byte code bounds checking. Otherwise turn it on.
If $1 is zero, turn off profiling. Otherwise turn it on.
If $1 is zero, turn off tracing. Otherwise turn trace flag $1 on.
If $1 is zero, turn off GC_DEBUG. Otherwise turn it on.
Fetch some piece of information about the interpreter and put it in $1. Possible values for $2 are defined in runtime/parrot/include/interpinfo.pasm. The valid constants for each return value are (excluding the .INTERPINFO_ prefix):
TOTAL_MEM_ALLOC, TOTAL_MEM_USED, GC_MARK_RUNS, GC_COLLECT_RUNS, ACTIVE_PMCS, ACTIVE_BUFFERS, TOTAL_PMCS, TOTAL_BUFFERS, HEADER_ALLOCS_SINCE_COLLECT, MEM_ALLOCS_SINCE_COLLECT, TOTAL_COPIED, IMPATIENT_PMCS, GC_LAZY_MARK_RUNS, EXTENDED_PMCS, CURRENT_RUNCORE, PARROT_INTSIZE, PARROT_FLOATSIZE, PARROT_POINTERSIZE, PARROT_INTMAX, PARROT_INTMIN
CURRENT_SUB, CURRENT_CONT, CURRENT_OBJECT, CURRENT_LEXPAD
EXECUTABLE_FULLNAME, EXECUTABLE_BASENAME, RUNTIME_PREFIX, CURRENT_RUNCORE, PARROT_OS, PARROT_OS_VERSION, PARROT_OS_VERSION_NUMBER, CPU_ARCH, CPU_TYPE
Turns on warnings categories. Categories already turned on will stay on. Initial setting is currently all warnings off. Include warnings.pasm to access the categories. Refer to that file for the current list of warnings available.
To turn on multiple categories, OR the category numbers together.
Turns off warnings categories. Categories already turned off will stay off. See the documentation for warningson for category numbers.
Turns on error categories. Categories already turned on will stay on. To access these from PASM, include errors.pasm. The current categories are:
When performing arithmetic on Integer PMCs, throw a math overflow exception instead of promoting to BigInt. This flag does not pertain to native integers, which are never promoted. Default: off.
Throw an exception on an argument versus parameter count mismatch. Default: on.
Throw an exception on a return versus result count mismatch. Default: off.
To turn on multiple categories, OR the category numbers together.
Turns off errors categories. Categories already turned off will stay off. See the documentation for errorson for category numbers.
Switch the current runcore to the one with the specified name. Needs to be an op, as we need to restart the runops() call. You can get the name of the current runcore with the interpinfo op.
Run the code starting at offset $2 within interpreter $1.
Get the current ParrotInterpreter.
Opcodes that interact with the GC subsystem.
Triggers a GC run, based on the value of $1, where:
Trigger a GC run unconditionally.
Trigger a garbage collection.
Disable GC runs. (Nestable)
Re-enable GC runs.
Disable GC runs (nestable).
Mark the PMC wanting destruction as soon as possible,
for example when unused during the lazy sweep,
Opcodes for interfacing with C functions in shared libraries.
Load a dynamic link library named $2 and store it in $1. $3, if provided, controls library loading and initialization; currently, we expect a bitmask accessible as an integer. Bit definitions are accessible from PASM if dlopenflags.pasm is included. The current bits are:
Make any symbols in the library accessible to other libraries loaded.
Look up symbol $3 in library $2 with signature $4, and put the corresponding sub object in $1. Note that you need the signature so we can build or find an appropriate thunking function.
Look up symbol $3 in library $2. We assume that this is actually a variable address rather than a function address, and build an UnManagedStruct PMC and stick the address into its data pointer.
Get the compiler object for source type $2.
The returned compiler object should provide a
compile method for translating code in the source type.
some Parrot compilers such as
PASM currently return a sub that is to be invoked directly on the source.
Register $2 as the compiler object for source type $1.
Create a callback stub $1 for PASM subroutine $2 with userdata $3 and callback function signature $4. Only 2 argument signatures with signature chars U[1iscpt] or [1iscpt]U are handled currently. But these cover a lot of callback signatures. Please note that the userdata PMC U has to be handled transparently by the caller of the callback function.
These operations relate to bytecode annotations.
Gets all bytecode annotations in effect at the current point, in a Hash. If there are none, returns an empty Hash.
Gets the bytecode annotation with the given name that is in effect at the current point. Returns PMCNULL if there is none.
Copyright (C) 2001-2012, Parrot Foundation.
This program is free software. It is subject to the same license as the Parrot interpreter itself.