Z80 Assembly meter in Visual Studio Code
The Z80 Assembly meter extension for Visual Studio Code meters clock cycles and bytecode size from Z80 assembly source code.
This extension meters timing in Z80 clock periods, referred to as T (time) cycles.
As the MSX standard requires so-called M1 wait cycles, this extension also meters M1 wait cycles for Z80 timing calculations on MSX. For a good explanation on how to do Z80 timing calculations on MSX, please read Wait States from Grauw MSX Assembly Page.
In Amstrad CPC architecture, all instruction timings are stretched so that they are all multiples of a microsecond (1�B5;s), which is approximatively equivalent to the duration of a NOP instruction. This extension can meter duration in "number of NOPs" for timing calculations on Amstrad CPC.
Select Z80 assembly source code to view clock cycles and bytecode size in the status bar.
If there is no selection, the current line will be used.
This extension can be installed standalone, but does not contribute any problem matcher, symbol provider, definition provider, or completion proproser for Z80 assembly.
Therefore, this extension can be installed alongside other Z80-related extensions such as:
This extension contributes the following settings:
z80-asm-meter.languageIds: Additional language IDs for which the extension is enabled (such as "c", to meter in-lined assembly). Defaults to:
"z80-macroasm", "z80-asm", "z80", "pasmo".
z80-asm-meter.maxLines: When working with huge files, metering can be disabled when the line count of the selection exceeds a certain threshold. Unlimited by default.
z80-asm-meter.maxLoC: Stops metering when the parsed lines of code (LoC) count exceeds a certain threshold. Unlimited by default.
z80-asm-meter.timing: Controls the visibility of the timing information in the status bar:
disabled: Timing information is not shown.
z80 (default): Z80 timing information is shown.
msx: Z80 + M1 timing information is shown. Useful for Z80 timing calculations on MSX, as the MSX standard requires so-called M1 wait cycles.
cpc: Amstrad CPC timing information (in number of NOPs) is shown.
z80+msx: Both Z80 and MSX (Z80+M1) timing information are shown.
z80+cpc: Both Z80 and Amstrad CPC timing information are shown.
z80-asm-meter.size: Controls the visibility of the size information in the status bar:
disabled: Size information is not shown.
bytecode (default): Bytecode size information is shown.
loc: Processed lines of code (LOC) count is shown.
bytecode+loc: Both bytecode size and LOC count are shown.
z80-asm-meter.opcode: Controls the visibility of the instruction and its opcode in the status bar:
disabled (default): Neither instruction nor its opcode are shown.
instruction: The instruction is shown. Can be used to check if the extension is mistaking instructions.
opcode: The opcode of the instruction is shown.
both: Both instruction and its opcode are shown.
z80-asm-meter.maxOpcodes: Stops instruction and opcode block visualization (in the tooltip) when the instruction count exceeds this value. Defaults to 16.
Coded by theNestruo (Néstor Sancho).
- Correction timing opcode
LD BC, (nn), by contributor: IIIvan37
- Fixes instruction status bar item not being hidden
- New option to display opcodes, by contributor: hlide
- Visibility configuration for instruction and its opcode
- Fixed issues:
- Some invalid instructions are falsely counted as valid. #6
"z80" (MSX Z80 by Yeoungman Seo) to the default additional language IDs
- Metering of the current line if there is no selection, by contributor: hlide
- Added configurable additional language IDs for which the extension is enabled
- Amstrad CPC timing explained in the readme file
- Added missing undocumented instructions:
- Added alternative syntax:
- Amstrad CPC timing in NOPs added by contributor: IIIvan37
- Code refactor (for future improvements)
- Code clean-up
- CodeFactor integration
- Travis-CI integration