1
0
mirror of https://github.com/KarolS/millfork.git synced 2025-01-11 12:29:46 +00:00
millfork/docs/stdlib/stdlib.md

52 lines
1.4 KiB
Markdown
Raw Normal View History

2019-07-15 14:21:50 +02:00
[< back to index](../doc_index.md)
2018-12-17 17:18:29 +01:00
## stdlib
The `stdlib` module is automatically imported on most targets.
#### `macro asm void poke(word const addr, byte register(a) value)`
Stores a byte at given constant address. Will not be optimized away by the optimizer.
#### `macro asm byte peek(word const addr)`
Reads a byte from given constant address. Will not be optimized away by the optimizer.
#### `macro asm void disable_irq()`
Disables interrupts.
#### `macro asm void enable_irq()`
Enables interrupts.
#### `byte hi_nibble_to_hex(byte register(a) value)`
Returns an ASCII representation of the upper nibble of the given byte.
#### `byte lo_nibble_to_hex(byte register(a) value)`
Returns an ASCII representation of the lower nibble of the given byte.
#### `macro asm void panic()`
2018-12-17 17:18:29 +01:00
Crashes the program.
2020-03-31 19:07:35 +02:00
## Standard macros available without any import
#### `macro void memory_barrier()`
Informs the optimizer that at this point arbitrary memory has been accessed and either read or written by an external device.
The optimizer should not optimize any memory accesses across that macro.
Available for: all targets.
#### `macro void breakpoint()`
If the `-fbreakpoints` option is selected (default), then it emits a memory barrier,
and also outputs a breakpoint to the label file (if the format of the label file allows it).
If the `-fno-breakpoints` option is selected, then it does nothing.
Available for: all targets.