From b4cba810a0d4d88819e17c020254e1ec059f182e Mon Sep 17 00:00:00 2001 From: Sven Van de Velde Date: Mon, 16 Oct 2023 12:43:37 +0200 Subject: [PATCH] Tables --- README.md | 126 +- images/INTRO1.jpg | Bin 136030 -> 87022 bytes images/UPDATE-VERA-CONFIRMATION.jpg | Bin 0 -> 88636 bytes images/VERA-UPDATE-BRIEFING.jpg | Bin 0 -> 127973 bytes src/cx16-defines.h | 10 +- target/src/CX16-UPDATE.PRG | Bin 32720 -> 21499 bytes target/src/cx16-update.asm | 27772 +++++++++----------------- target/src/cx16-update.klog | 12 +- 8 files changed, 9976 insertions(+), 17944 deletions(-) create mode 100644 images/UPDATE-VERA-CONFIRMATION.jpg create mode 100644 images/VERA-UPDATE-BRIEFING.jpg diff --git a/README.md b/README.md index 956449e..948fb41 100644 --- a/README.md +++ b/README.md @@ -91,16 +91,11 @@ So in summary, remember the following: - JP1 jumper pins OPEN => VERA addresses the SD card. - JP1 jumper pins CLOSED => VERA addresses the SPI IC. - -![VERA-JP1-OPEN](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/VERA-JP1-OPEN.jpg) - -At the start position, before running the CX16 update program, ensure that the JP1 jumper pins on the VERA board are **OPEN** (Picture above)! This is necessary to instruct VERA to address any memory instruction to the SD card. - -![VERA-JP1-CLOSED](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/VERA-JP1-CLOSED.jpg) - -During the update process, the program will ask you to place a jumper cap, **CLOSING** the JP1 jumper pins (picture above). This is necessary to instruct VERA to address any memory instruction to the SPI IC, in order to allow for the memory flashing of the VERA.BIN file now stored in RAM, onto the SPI IC memory (only the first 128KB will be updated). - -Once the VERA memory has been updated, the program will ask you to remove the JP1 jumper cap, **opening** the pins again. This is necessary to direct VERA to address the SD card again for further file reads. +| | | +| --- | --- | +| 1. For preparation, before running the CX16 update program, **ensure** that the JP1 jumper pins on the VERA board are **OPEN** (Picture above)! This is necessary to instruct VERA to address any memory instruction to the SD card. | ![VERA-JP1-OPEN](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/VERA-JP1-OPEN.jpg) | +| 2. During the update process, the program will ask you to place a jumper cap, **CLOSING** the JP1 jumper pins (picture above). This is necessary to instruct VERA to address any memory instruction to the SPI IC, in order to allow for the memory flashing of the VERA.BIN file now stored in RAM, onto the SPI IC memory (only the first 128KB will be updated). | ![VERA-JP1-CLOSED](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/VERA-JP1-CLOSED.jpg) | +| 3. Once the VERA memory has been updated, the program will ask you to remove the JP1 jumper cap, **opening** the pins again. This is necessary to direct VERA to address the SD card again for further file reads. | ![VERA-JP1-OPEN](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/VERA-JP1-OPEN.jpg) | **Note that this will happen during the update process and it is crucial that you follow carefully the instructions given by the program! It might be advisory to practice this process before you execute the CX16 update program, with your CX16 board powered OFF! Put a jumper cap on the JP1 jumper pins closing it and re-opening it by removing. Simple, but if you've never done this, this may require a bit of practice!** @@ -108,23 +103,25 @@ Updating the **external** VERA card won't require you to follow this process. ### 1.3.2 Prepare: CLOSE SMC J5 jumper pins! -![CX16-J5](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/CX16-J5.jpg) - -Ensure that the J5 jumper pins on the Commander X16 main board are **closed**. If the J5 jumper pins are not closed, the keyboard won't be functional (Picture above)! +| | | +| --- | --- | +| Ensure that the J5 jumper pins on the Commander X16 main board are **closed**. If the J5 jumper pins are not closed, the keyboard won't be functional! | ![CX16-J5](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/CX16-J5.jpg) | ### 1.3.3 Prepare: CLOSE Main CX16 ROM J1 jumper pins! -![CX16-J1](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/CX16-J1.jpg) -Ensure that the J1 jumper pins on the Commander X16 main board are **closed**, to **remove the write protection** of the main CX16 ROM. If the J1 jumper pins are **not closed**, the **main CX16 ROM will not be detected** by the update program. (Picture above)! +| | | +| --- | --- | +| Ensure that the J1 jumper pins on the Commander X16 main board are **closed**, to **remove the write protection** of the main CX16 ROM. If the J1 jumper pins are **not closed**, the **main CX16 ROM will not be detected** by the update program! | ![CX16-J1](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/CX16-J1.jpg) | -### 1.3.4 Prepare: Flash multiple ROMs on the external RAM/ROM board or cartridge. -First for all clarity, find below a picture of such a ROM expansion cartridge: +### 1.3.4 Prepare: Flash multiple ROMs on the external RAM/ROM board or cartridge. -![ROM-CARD](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/ROM-CARD.jpg) +| | | +| --- | --- | +| First for all clarity, find below a picture of such a ROM expansion cartridge. | ![ROM-CARD](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/ROM-CARD.jpg) | On the ROM cartridge, 7 extra RAM/ROM chips can be placed for usage, and can be updated using this program. The cartridge is placed in one of the 4 PCI extension slots on the CX16 main board, and provides an extra 3.5 MB of banked RAM/ROM to your CX16 between addresses $C000 and $FFFF, with zeropage $01 as the bank register. Each bank has $4000 bytes! @@ -134,14 +131,15 @@ For example, `ROM1.BIN` will flash ROM#1 on the cartridge. `ROM5.BIN` will flash In order to flash the ROMs, **close** the relevant jumper pins: -![ROM-CARD-J1-CLOSED](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/ROM-CARD-J1-CLOSED.jpg) - -![ROM-CARD-J2-CLOSED](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/ROM-CARD-J2-CLOSED.jpg) +| Preparation | | +| --- | --- | +| 1. **Close** the J1 jumper pins (at the left side of the cartridge board) to remove the write-protection for ROM#1 till ROM#6. | ![ROM-CARD-J1-CLOSED](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/ROM-CARD-J1-CLOSED.jpg) | +| 2. **Close** the J2 jumper pins (at the right side of the cartridge board) to remove the write-protection for ROM#7. | ![ROM-CARD-J2-CLOSED](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/ROM-CARD-J2-CLOSED.jpg) | - 1. **Close** the J1 jumper pins (at the left side of the cartridge board) to remove the write-protection for ROM#1 till ROM#6. + - 2. **Close** the J2 jumper pins (at the right side of the cartridge board) to remove the write-protection for ROM#7. + Once you have the J1 and/or J2 jumper pins properly closed on the cartridge board, the ROMs will be detected by the flashing program. If the jumper pins are open, the ROMs won't be recognized by the flashing program and your ROM*n*.BIN file(s) will not be flashed! @@ -200,21 +198,17 @@ Please find below a detailed description of the complete process. ## 2.1.1 Introduction and briefing screens -![Into-1](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/INTRO1.jpg) - -At program start, you will see an introduction screen, introducing the update process. +| Step | Picture | +| --- | --- | +| At program start, you will see an introduction screen, introducing the update process. Please carefully read the text at the bottom panel of the screen, and press SPACE to continue ... | ![Into-1](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/INTRO1.jpg) | +| A second screen appears, which indicates the color schema used to indicate the update status of each component on your Commander X16 main board and/or your expansion cartridge board. Press SPACE to continue. | ![Into-2](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/INTRO2.jpg) | -Please carefully read the text at the bottom panel of the screen, and press SPACE to continue ... - -![Into-1](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/INTRO2.jpg) - -A second screen appears, which indicates the color schema used to indicate the update status of each component on your Commander X16 main board and/or your expansion cartridge board. Press SPACE to continue. ### 2.1.2 Component detection -Next, the update program detects which components are upgradable and will validate which files are found on the SD card. - -![FLASH-DETECT](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/FLASH-DETECT.jpg) +| Step | Picture | +| --- | --- | +| Next, the update program detects which components are upgradable and will validate which files are found on the SD card. The Commander X16 main board SMC, VERA and main ROM chip are detected, together with the external cardridge 7 ROM chips. | ![FLASH-DETECT](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/FLASH-DETECT.jpg) | The Commander X16 main board SMC, VERA and main ROM chip are detected, together with the external cardridge 7 ROM chips. @@ -224,21 +218,20 @@ The Commander X16 main board SMC, VERA and main ROM chip are detected, together ### 2.1.3 File presence and validation -After component detection, the program will immediately search for file presence for **each detected component** and will validate it. +| Step | Picture | +| --- | --- | +| After component detection, the program will immediately search for file presence for **each detected component** and will validate it. The program will read each file and check on data size and any validation content to be used before flashing. | ![FLASH-CHECK](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/FLASH-CHECK.jpg) | -![FLASH-CHECK](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/FLASH-CHECK.jpg) - -The program will read each file and check on data size and any validation content to be used before flashing. - Detected and valid files will result in the status of the component in a **PURPLE** led and status `Update`. -- Files that are not present, will result in the component not to be updated. The component will get a GREY led and status `skipped`. +- Files that are not present, will result in the component not to be updated. The component will get a GREY led and status `Skipped`. ### 2.1.4 Pre-Update conditions. -Before the update commences, there are important conditions vaidated to ensure that any upgrade file or component compatibility risk or issues, potentially corrupting your CX16, are properly mitigated. - -![SMC-ROM-COMPATIBILITY](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/SMC-ROM-COMPATIBILITY.jpg) +| Step | Picture | +| --- | --- | +| Before the update commences, there are important conditions vaidated to ensure that any upgrade file or component compatibility risk or issues, potentially corrupting your CX16, are properly mitigated. | ![SMC-ROM-COMPATIBILITY](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/SMC-ROM-COMPATIBILITY.jpg) | 1. SMC and ROM must be flashed together: To avoid an SMC update corrupting your CX16 because it is not supportive or compatible with your ROM. The SMC file contains flags to ensure the compatibility between the SMC and the ROM. @@ -247,48 +240,40 @@ Before the update commences, there are important conditions vaidated to ensure t 3. The main CX16 ROM not detected will stop the update process. -![UPDATE-CONFIRM](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/UPDATE-CONFIRM.jpg) - -When there are no issues, the user is asked for a confirmation to proceed with the update: - - - Replying `N` will cancel the update. - - Replying `Y` will proceed with the update! +| Step | Picture | +| --- | --- | +| When there are no issues, the user is asked for a confirmation to proceed with the update. Replying `N` will cancel the update. Replying `Y` will proceed with the update! | ![UPDATE-CONFIRM](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/UPDATE-CONFIRM.jpg) | -## 2.2 The update process, updating your components -The program will update each component that has status `Update`. +## 2.2 The CX16 update program updating your CX16 internal and external components -The program will read the firmware data into memory first, and will then commence with the update process, updating your component. +The CX16 update program will update each component that has status `Update`. -However, the update process differs for each component type, so please read carefully the below explanation: +For each component, program will read the firmware data into RAM memory first, and will then use the data stored in RAM to update your CX16 component. +The program guides you through the update process for each component in a very user friendly way, but mistakes are always possible, to please read carefully the below explanation. However, the **component update process differs for each component type**, so be aware! ### 2.2.1 The VERA update process -The update process of the VERA requires a manual interaction, where the user places the JP1 jumper cap, closing the JP1 jumper pins when requested on the VERA board. +| Step | Picture | +| --- | --- | +| Once the CX16 update has verified all the the files, and the VERA.BIN file is accepted, you need to confirm here with typing `Y` on the CX16 keyboard. | ![UPDATE-VERA-CONFIRMATION](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/UPDATE-VERA-CONFIRMATION.jpg) | +| You will be presented with this briefing, that explains the importance of the JP1 jumper pins manual handing during the update process (Picture above). Press SPACE on the CX16 keyboard to continue. | ![VERA-UPDATE-BRIEFING](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/VERA-UPDATE-BRIEFING.jpg) | ### 2.2.2 The SMC update process The SMC update is straightforward. -It will first read the `SMC.BIN` into internal memory. - -![POWER-RESET-SCREEN](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/POWER-RESET-SCREEN.jpg) - -Then, the program asks you to press the `POWER` and the `RESET` button at the same time on the CX16 board. - -![POWER-RESET](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/POWER-RESET.jpg) - -Do so on the CX16 board. - -When the POWER-RESET button is not pressed in time (there is a countdown), the program will cancel the update of the SMC but will continue updating any other component. The update of the ROM will be skipped, though! - -![SMC-ROM-ISSUE](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/SMC-ROM-ISSUE.jpg) - -The cancellation of the SMC update results in a reported issue, as the SMC and the ROM must be flashed together. - -When POWER-RESET is pressed, the program will flash your SMC. Don't interrupt the process. +| | | +| --- | --- | +| It will first read the `SMC.BIN` into internal memory. | | +| Then, the program asks you to press the `POWER` and the `RESET` button at the same time on the CX16 board. | ![POWER-RESET-SCREEN](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/POWER-RESET-SCREEN.jpg) | +| Do so on the CX16 board. | ![POWER-RESET](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/POWER-RESET.jpg) | +| When the POWER-RESET button is not pressed in time (there is a countdown), the program will cancel the update of the SMC but will continue updating any other component. The update of the ROM will be skipped, though! The cancellation of the SMC update results in a reported issue, as the SMC and the ROM must be flashed together. | ![SMC-ROM-ISSUE](https://raw.githubusercontent.com/FlightControl-User/x16-flash/main/images/SMC-ROM-ISSUE.jpg) | +| When POWER-RESET is pressed, the program will flash your SMC. Don't interrupt the process. | | +| To ensure that your SMC has been properly updated, the SMC will show as a **GREEN** led and status `Updated`. | | + **VERY IMPORTANT:** **Once your SMC is updated, you MUST wait till the end of the program to continue to update process, or your CX16 will be BRICKED!!!** @@ -297,6 +282,7 @@ When POWER-RESET is pressed, the program will flash your SMC. Don't interrupt th ### 2.2.3 The main CX16 ROM update process + ### 2.2.4 The external cardridge ROMs update process The loading process is seamless, if there is a file, each byte in the file is loaded into low and high RAM. The first $4000 bytes are loaded in low RAM, while the remainder of the ROM[N].BIN file is loaded in high RAM. This is nothing for you to be concerned about, just explaining how the program works. But note that a ROM[N].BIN file that is 512KB large, will be fully loaded into RAM on the Commander X16! diff --git a/images/INTRO1.jpg b/images/INTRO1.jpg index cbebf7db11acd2e56e13c8ff15ee692a828f3ec7..71a7a4fd654ff8da93a409ccc241231ac5c5e980 100644 GIT binary patch literal 87022 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�KQzSK>yDE* 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 f(~LBY{d_?cL96f0^rgiiQ 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%0ADq{q;ZA5h^ZnUtwz@%f;MU)`ntZtF^@pD`@ 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 literal 0 HcmV?d00001 diff --git a/src/cx16-defines.h b/src/cx16-defines.h index 477437b..5de6cfc 100644 --- a/src/cx16-defines.h +++ b/src/cx16-defines.h @@ -33,16 +33,16 @@ #define __INTRO +#define __VERA_CHIP_PROCESS +// #define __SMC_CHIP_PROCESS +// #define __ROM_CHIP_PROCESS + + #define __VERA_JP1_DETECT // #define __VERA_FLASH #define __SMC_FLASH #define __ROM_FLASH - -#define __VERA_CHIP_PROCESS -#define __SMC_CHIP_PROCESS -#define __ROM_CHIP_PROCESS - #define __VERA_CHIP_DETECT #define __SMC_CHIP_DETECT #define __ROM_CHIP_DETECT diff --git a/target/src/CX16-UPDATE.PRG b/target/src/CX16-UPDATE.PRG index 2d870ed5b4d096fec22710dd51c22b7da882166a..a1c7e9449d3fdc2289375cbd5fc50174773e10c8 100644 GIT binary patch literal 21499 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 E8-Wb%>;M1& literal 32720 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] - // [784] phi textcolor::color#23 = WHITE [phi:conio_x16_init::@1->textcolor#0] -- vbum1=vbuc1 + // [439] phi from conio_x16_init::@1 to textcolor [phi:conio_x16_init::@1->textcolor] + // [439] phi textcolor::color#21 = WHITE [phi:conio_x16_init::@1->textcolor#0] -- vbum1=vbuc1 lda #WHITE sta textcolor.color jsr textcolor @@ -342,8 +317,8 @@ conio_x16_init: { // conio_x16_init::@2 // bgcolor(CONIO_BACKCOLOR_DEFAULT) // [23] call bgcolor - // [789] phi from conio_x16_init::@2 to bgcolor [phi:conio_x16_init::@2->bgcolor] - // [789] phi bgcolor::color#15 = BLUE [phi:conio_x16_init::@2->bgcolor#0] -- vbum1=vbuc1 + // [444] phi from conio_x16_init::@2 to bgcolor [phi:conio_x16_init::@2->bgcolor] + // [444] phi bgcolor::color#15 = BLUE [phi:conio_x16_init::@2->bgcolor#0] -- vbum1=vbuc1 lda #BLUE sta bgcolor.color jsr bgcolor @@ -359,13 +334,13 @@ conio_x16_init: { jsr cbm_k_plot_get // [28] cbm_k_plot_get::return#2 = cbm_k_plot_get::return#0 // conio_x16_init::@5 - // [29] conio_x16_init::$4 = cbm_k_plot_get::return#2 -- vwum1=vwum2 + // [29] conio_x16_init::$4 = cbm_k_plot_get::return#2 -- vwuz1=vwum2 lda cbm_k_plot_get.return - sta conio_x16_init__4 + sta.z conio_x16_init__4 lda cbm_k_plot_get.return+1 - sta conio_x16_init__4+1 + sta.z conio_x16_init__4+1 // BYTE1(cbm_k_plot_get()) - // [30] conio_x16_init::$5 = byte1 conio_x16_init::$4 -- vbuz1=_byte1_vwum2 + // [30] conio_x16_init::$5 = byte1 conio_x16_init::$4 -- vbuz1=_byte1_vwuz2 sta.z conio_x16_init__5 // __conio.cursor_x = BYTE1(cbm_k_plot_get()) // [31] *((char *)&__conio) = conio_x16_init::$5 -- _deref_pbuc1=vbuz1 @@ -375,17 +350,17 @@ conio_x16_init: { jsr cbm_k_plot_get // [33] cbm_k_plot_get::return#3 = cbm_k_plot_get::return#0 // conio_x16_init::@6 - // [34] conio_x16_init::$6 = cbm_k_plot_get::return#3 -- vwum1=vwum2 + // [34] conio_x16_init::$6 = cbm_k_plot_get::return#3 -- vwuz1=vwum2 lda cbm_k_plot_get.return - sta conio_x16_init__6 + sta.z conio_x16_init__6 lda cbm_k_plot_get.return+1 - sta conio_x16_init__6+1 + sta.z conio_x16_init__6+1 // BYTE0(cbm_k_plot_get()) - // [35] conio_x16_init::$7 = byte0 conio_x16_init::$6 -- vbum1=_byte0_vwum2 - lda conio_x16_init__6 - sta conio_x16_init__7 + // [35] conio_x16_init::$7 = byte0 conio_x16_init::$6 -- vbuz1=_byte0_vwuz2 + lda.z conio_x16_init__6 + sta.z conio_x16_init__7 // __conio.cursor_y = BYTE0(cbm_k_plot_get()) - // [36] *((char *)&__conio+1) = conio_x16_init::$7 -- _deref_pbuc1=vbum1 + // [36] *((char *)&__conio+1) = conio_x16_init::$7 -- _deref_pbuc1=vbuz1 sta __conio+1 // gotoxy(__conio.cursor_x, __conio.cursor_y) // [37] gotoxy::x#2 = *((char *)&__conio) -- vbum1=_deref_pbuc1 @@ -395,9 +370,9 @@ conio_x16_init: { lda __conio+1 sta gotoxy.y // [39] call gotoxy - // [802] phi from conio_x16_init::@6 to gotoxy [phi:conio_x16_init::@6->gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#2 [phi:conio_x16_init::@6->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = gotoxy::x#2 [phi:conio_x16_init::@6->gotoxy#1] -- register_copy + // [457] phi from conio_x16_init::@6 to gotoxy [phi:conio_x16_init::@6->gotoxy] + // [457] phi gotoxy::y#26 = gotoxy::y#2 [phi:conio_x16_init::@6->gotoxy#0] -- register_copy + // [457] phi gotoxy::x#26 = gotoxy::x#2 [phi:conio_x16_init::@6->gotoxy#1] -- register_copy jsr gotoxy // conio_x16_init::@7 // __conio.scroll[0] = 1 @@ -411,12 +386,7 @@ conio_x16_init: { // } // [42] return rts - .segment Data - conio_x16_init__4: .word 0 - conio_x16_init__6: .word 0 - conio_x16_init__7: .byte 0 } -.segment Code // cputc // Output one character at the current cursor position // Moves the cursor forward. Scrolls the entire screen if needed @@ -424,8 +394,8 @@ conio_x16_init: { cputc: { .const OFFSET_STACK_C = 0 .label cputc__1 = $22 - .label cputc__2 = $52 - .label cputc__3 = $53 + .label cputc__2 = $47 + .label cputc__3 = $48 // [43] cputc::c#0 = stackidx(char,cputc::OFFSET_STACK_C) -- vbum1=_stackidxbyte_vbuc1 tsx lda STACK_BASE+OFFSET_STACK_C,x @@ -553,46 +523,56 @@ cputc: { // main main: { .const bank_set_brom1_bank = 4 + .const bank_set_brom2_bank = 0 + .const bank_set_bram1_bank = 0 .const bank_set_brom3_bank = 4 .const bank_set_brom4_bank = 0 - .const bank_set_brom5_bank = 0 - .const bank_set_brom6_bank = 4 - .const bank_set_bram1_bank = 0 - .const bank_set_brom7_bank = 4 - .const bank_set_brom8_bank = 0 - .const bank_set_brom9_bank = 0 - .const bank_set_brom10_bank = 4 - .label main__87 = $ce - .label main__111 = $e6 - .label main__112 = $e7 - .label main__113 = $cd - .label main__140 = $e4 - .label main__191 = $5e - .label check_status_smc1_main__0 = $6b - .label check_status_rom1_main__0 = $e8 - .label check_status_smc11_main__0 = $e9 - .label check_status_smc12_main__0 = $ea - .label rom_chip = $d6 - .label rom_chip1 = $d7 - .label rom_chip2 = $db - .label rom_bytes_read = $eb - .label rom_file_modulo = $e0 - .label rom_file_github_id = $6c - .label rom_file_prefix_id = $e5 - .label rom_chip3 = $d1 - .label flashed_bytes = $c3 - .label rom_chip4 = $da - .label file1 = $cf - .label rom_bytes_read1 = $dc - .label rom_differences = $f5 - .label w = $d9 - .label w1 = $d8 - .label main__371 = $ce - .label main__372 = $ce - .label main__373 = $ce - .label main__375 = $cd - .label main__376 = $cd - .label main__377 = $cd + .const bank_set_brom5_bank = 4 + .label main__30 = $e1 + .label main__47 = $e7 + .label main__56 = $e6 + .label main__69 = $e5 + .label main__72 = $a9 + .label main__111 = $e4 + .label main__116 = $42 + .label main__153 = $e2 + .label main__158 = $e3 + .label check_status_smc1_main__0 = $63 + .label check_status_cx16_rom1_check_status_rom1_main__0 = $c7 + .label check_status_smc2_main__0 = $c8 + .label check_status_cx16_rom2_check_status_rom1_main__0 = $c9 + .label check_status_smc3_main__0 = $ca + .label check_status_cx16_rom3_check_status_rom1_main__0 = $cb + .label check_status_smc4_main__0 = $cc + .label check_status_cx16_rom4_check_status_rom1_main__0 = $cd + .label check_status_smc5_main__0 = $ce + .label check_status_smc6_main__0 = $cf + .label check_status_vera1_main__0 = $d0 + .label check_status_smc7_main__0 = $d1 + .label check_status_vera2_main__0 = $d2 + .label check_status_vera3_main__0 = $d3 + .label check_status_vera4_main__0 = $dd + .label check_status_smc8_main__0 = $de + .label check_status_cx16_rom5_check_status_rom1_main__0 = $df + .label check_status_vera5_main__0 = $e0 + .label check_status_smc9_main__0 = $d4 + .label check_status_smc10_main__0 = $d5 + .label check_status_vera6_main__0 = $d6 + .label check_status_vera7_main__0 = $d7 + .label check_status_smc11_main__0 = $d8 + .label check_status_vera8_main__0 = $d9 + .label check_status_smc12_main__0 = $da + .label check_status_vera9_main__0 = $db + .label check_status_smc13_main__0 = $dc + .label rom_chip = $af + .label ch = $c6 + .label ch1 = $c5 + .label rom_chip1 = $aa + .label w = $b1 + .label w1 = $b0 + .label main__231 = $a9 + .label main__232 = $a9 + .label main__233 = $a9 // display_frame_init_64() // [71] call display_frame_init_64 // Get the current screen mode ... @@ -613,4367 +593,2036 @@ main: { } */ jsr display_frame_init_64 - // [72] phi from main to main::@97 [phi:main->main::@97] - // main::@97 + // [72] phi from main to main::@49 [phi:main->main::@49] + // main::@49 // display_frame_draw() // [73] call display_frame_draw // ST1 | Reset canvas to 64 columns - // [851] phi from main::@97 to display_frame_draw [phi:main::@97->display_frame_draw] + // [506] phi from main::@49 to display_frame_draw [phi:main::@49->display_frame_draw] jsr display_frame_draw - // [74] phi from main::@97 to main::@98 [phi:main::@97->main::@98] - // main::@98 + // [74] phi from main::@49 to main::@50 [phi:main::@49->main::@50] + // main::@50 // display_frame_title("Commander X16 Update Utility (v3.0.0) ") // [75] call display_frame_title - // [892] phi from main::@98 to display_frame_title [phi:main::@98->display_frame_title] + // [547] phi from main::@50 to display_frame_title [phi:main::@50->display_frame_title] jsr display_frame_title - // [76] phi from main::@98 to main::display_info_title1 [phi:main::@98->main::display_info_title1] + // [76] phi from main::@50 to main::display_info_title1 [phi:main::@50->main::display_info_title1] // main::display_info_title1 // cputsxy(INFO_X-2, INFO_Y-2, "# Chip Status Type Curr. Release Update Info") // [77] call cputsxy - // [897] phi from main::display_info_title1 to cputsxy [phi:main::display_info_title1->cputsxy] - // [897] phi cputsxy::s#4 = main::s [phi:main::display_info_title1->cputsxy#0] -- pbuz1=pbuc1 + // [552] phi from main::display_info_title1 to cputsxy [phi:main::display_info_title1->cputsxy] + // [552] phi cputsxy::s#3 = main::s [phi:main::display_info_title1->cputsxy#0] -- pbuz1=pbuc1 lda #s sta.z cputsxy.s+1 - // [897] phi cputsxy::y#4 = $11-2 [phi:main::display_info_title1->cputsxy#1] -- vbum1=vbuc1 + // [552] phi cputsxy::y#3 = $11-2 [phi:main::display_info_title1->cputsxy#1] -- vbum1=vbuc1 lda #$11-2 sta cputsxy.y - // [897] phi cputsxy::x#4 = 4-2 [phi:main::display_info_title1->cputsxy#2] -- vbum1=vbuc1 + // [552] phi cputsxy::x#3 = 4-2 [phi:main::display_info_title1->cputsxy#2] -- vbum1=vbuc1 lda #4-2 sta cputsxy.x jsr cputsxy - // [78] phi from main::display_info_title1 to main::@99 [phi:main::display_info_title1->main::@99] - // main::@99 + // [78] phi from main::display_info_title1 to main::@51 [phi:main::display_info_title1->main::@51] + // main::@51 // cputsxy(INFO_X-2, INFO_Y-1, "- ---- --------- ------ ------------- --------------------------") // [79] call cputsxy - // [897] phi from main::@99 to cputsxy [phi:main::@99->cputsxy] - // [897] phi cputsxy::s#4 = main::s1 [phi:main::@99->cputsxy#0] -- pbuz1=pbuc1 + // [552] phi from main::@51 to cputsxy [phi:main::@51->cputsxy] + // [552] phi cputsxy::s#3 = main::s1 [phi:main::@51->cputsxy#0] -- pbuz1=pbuc1 lda #s1 sta.z cputsxy.s+1 - // [897] phi cputsxy::y#4 = $11-1 [phi:main::@99->cputsxy#1] -- vbum1=vbuc1 + // [552] phi cputsxy::y#3 = $11-1 [phi:main::@51->cputsxy#1] -- vbum1=vbuc1 lda #$11-1 sta cputsxy.y - // [897] phi cputsxy::x#4 = 4-2 [phi:main::@99->cputsxy#2] -- vbum1=vbuc1 + // [552] phi cputsxy::x#3 = 4-2 [phi:main::@51->cputsxy#2] -- vbum1=vbuc1 lda #4-2 sta cputsxy.x jsr cputsxy - // [80] phi from main::@99 to main::@67 [phi:main::@99->main::@67] - // main::@67 + // [80] phi from main::@51 to main::@27 [phi:main::@51->main::@27] + // main::@27 // display_action_progress("Introduction, please read carefully the below!") // [81] call display_action_progress - // [904] phi from main::@67 to display_action_progress [phi:main::@67->display_action_progress] - // [904] phi display_action_progress::info_text#27 = main::info_text [phi:main::@67->display_action_progress#0] -- pbuz1=pbuc1 + // [559] phi from main::@27 to display_action_progress [phi:main::@27->display_action_progress] + // [559] phi display_action_progress::info_text#19 = main::info_text [phi:main::@27->display_action_progress#0] -- pbuz1=pbuc1 lda #info_text sta.z display_action_progress.info_text+1 jsr display_action_progress - // [82] phi from main::@67 to main::@100 [phi:main::@67->main::@100] - // main::@100 + // [82] phi from main::@27 to main::@52 [phi:main::@27->main::@52] + // main::@52 // display_progress_clear() // [83] call display_progress_clear - // [918] phi from main::@100 to display_progress_clear [phi:main::@100->display_progress_clear] + // [573] phi from main::@52 to display_progress_clear [phi:main::@52->display_progress_clear] jsr display_progress_clear - // [84] phi from main::@100 to main::@101 [phi:main::@100->main::@101] - // main::@101 + // [84] phi from main::@52 to main::@53 [phi:main::@52->main::@53] + // main::@53 // display_chip_smc() // [85] call display_chip_smc - // [933] phi from main::@101 to display_chip_smc [phi:main::@101->display_chip_smc] + // [588] phi from main::@53 to display_chip_smc [phi:main::@53->display_chip_smc] jsr display_chip_smc - // [86] phi from main::@101 to main::@102 [phi:main::@101->main::@102] - // main::@102 + // [86] phi from main::@53 to main::@54 [phi:main::@53->main::@54] + // main::@54 // display_chip_vera() // [87] call display_chip_vera - // [938] phi from main::@102 to display_chip_vera [phi:main::@102->display_chip_vera] + // [593] phi from main::@54 to display_chip_vera [phi:main::@54->display_chip_vera] jsr display_chip_vera - // [88] phi from main::@102 to main::@103 [phi:main::@102->main::@103] - // main::@103 + // [88] phi from main::@54 to main::@55 [phi:main::@54->main::@55] + // main::@55 // display_chip_rom() // [89] call display_chip_rom - // [943] phi from main::@103 to display_chip_rom [phi:main::@103->display_chip_rom] + // [598] phi from main::@55 to display_chip_rom [phi:main::@55->display_chip_rom] jsr display_chip_rom - // [90] phi from main::@103 to main::@104 [phi:main::@103->main::@104] - // main::@104 + // [90] phi from main::@55 to main::@56 [phi:main::@55->main::@56] + // main::@56 // display_info_smc(STATUS_COLOR_NONE, NULL) // [91] call display_info_smc - // [962] phi from main::@104 to display_info_smc [phi:main::@104->display_info_smc] - // [962] phi display_info_smc::info_text#20 = 0 [phi:main::@104->display_info_smc#0] -- pbuz1=vbuc1 + // [617] phi from main::@56 to display_info_smc [phi:main::@56->display_info_smc] + // [617] phi display_info_smc::info_text#10 = 0 [phi:main::@56->display_info_smc#0] -- pbuz1=vbuc1 lda #<0 sta.z display_info_smc.info_text sta.z display_info_smc.info_text+1 - // [962] phi smc_bootloader#14 = 0 [phi:main::@104->display_info_smc#1] -- vwum1=vwuc1 - sta smc_bootloader_1 - sta smc_bootloader_1+1 - // [962] phi display_info_smc::info_status#20 = BLACK [phi:main::@104->display_info_smc#2] -- vbum1=vbuc1 + // [617] phi display_info_smc::info_status#10 = BLACK [phi:main::@56->display_info_smc#1] -- vbum1=vbuc1 lda #BLACK sta display_info_smc.info_status jsr display_info_smc - // [92] phi from main::@104 to main::@105 [phi:main::@104->main::@105] - // main::@105 + // [92] phi from main::@56 to main::@57 [phi:main::@56->main::@57] + // main::@57 // display_info_vera(STATUS_NONE, NULL) // [93] call display_info_vera - // [998] phi from main::@105 to display_info_vera [phi:main::@105->display_info_vera] - // [998] phi display_info_vera::info_text#19 = 0 [phi:main::@105->display_info_vera#0] -- pbuz1=vbuc1 + // [653] phi from main::@57 to display_info_vera [phi:main::@57->display_info_vera] + // [653] phi display_info_vera::info_text#19 = 0 [phi:main::@57->display_info_vera#0] -- pbuz1=vbuc1 lda #<0 sta.z display_info_vera.info_text sta.z display_info_vera.info_text+1 - // [998] phi spi_memory_capacity#106 = 0 [phi:main::@105->display_info_vera#1] -- vbum1=vbuc1 + // [653] phi spi_memory_capacity#110 = 0 [phi:main::@57->display_info_vera#1] -- vbum1=vbuc1 sta spi_memory_capacity - // [998] phi spi_memory_type#107 = 0 [phi:main::@105->display_info_vera#2] -- vbum1=vbuc1 + // [653] phi spi_memory_type#111 = 0 [phi:main::@57->display_info_vera#2] -- vbum1=vbuc1 sta spi_memory_type - // [998] phi spi_manufacturer#108 = 0 [phi:main::@105->display_info_vera#3] -- vbum1=vbuc1 + // [653] phi spi_manufacturer#100 = 0 [phi:main::@57->display_info_vera#3] -- vbum1=vbuc1 sta spi_manufacturer - // [998] phi display_info_vera::info_status#19 = STATUS_NONE [phi:main::@105->display_info_vera#4] -- vbum1=vbuc1 + // [653] phi display_info_vera::info_status#19 = STATUS_NONE [phi:main::@57->display_info_vera#4] -- vbum1=vbuc1 lda #STATUS_NONE sta display_info_vera.info_status jsr display_info_vera - // [94] phi from main::@105 to main::@12 [phi:main::@105->main::@12] - // [94] phi main::rom_chip#2 = 0 [phi:main::@105->main::@12#0] -- vbuz1=vbuc1 + // [94] phi from main::@57 to main::@10 [phi:main::@57->main::@10] + // [94] phi main::rom_chip#2 = 0 [phi:main::@57->main::@10#0] -- vbuz1=vbuc1 lda #0 sta.z rom_chip - // main::@12 - __b12: + // main::@10 + __b10: // for(unsigned char rom_chip=0; rom_chip<8; rom_chip++) - // [95] if(main::rom_chip#2<8) goto main::@13 -- vbuz1_lt_vbuc1_then_la1 + // [95] if(main::rom_chip#2<8) goto main::@11 -- vbuz1_lt_vbuc1_then_la1 lda.z rom_chip cmp #8 - bcs !__b13+ - jmp __b13 - !__b13: - // [96] phi from main::@12 to main::@14 [phi:main::@12->main::@14] - // main::@14 + bcs !__b11+ + jmp __b11 + !__b11: + // [96] phi from main::@10 to main::@12 [phi:main::@10->main::@12] + // main::@12 // main_intro() // [97] call main_intro - // [1038] phi from main::@14 to main_intro [phi:main::@14->main_intro] + // [693] phi from main::@12 to main_intro [phi:main::@12->main_intro] jsr main_intro - // [98] phi from main::@14 to main::@108 [phi:main::@14->main::@108] - // main::@108 - // smc_detect() - // [99] call smc_detect - jsr smc_detect - // [100] smc_detect::return#2 = smc_detect::return#0 - // main::@109 - // smc_bootloader = smc_detect() - // [101] smc_bootloader#0 = smc_detect::return#2 -- vwum1=vwum2 - lda smc_detect.return - sta smc_bootloader - lda smc_detect.return+1 - sta smc_bootloader+1 - // strcpy(smc_version_text, "0.0.0") - // [102] call strcpy - // [1066] phi from main::@109 to strcpy [phi:main::@109->strcpy] - // [1066] phi strcpy::dst#0 = smc_version_text [phi:main::@109->strcpy#0] -- pbuz1=pbuc1 - lda #smc_version_text - sta.z strcpy.dst+1 - // [1066] phi strcpy::src#0 = main::source1 [phi:main::@109->strcpy#1] -- pbuz1=pbuc1 - lda #source1 - sta.z strcpy.src+1 - jsr strcpy - // [103] phi from main::@109 to main::@110 [phi:main::@109->main::@110] - // main::@110 - // display_chip_smc() - // [104] call display_chip_smc - // [933] phi from main::@110 to display_chip_smc [phi:main::@110->display_chip_smc] - jsr display_chip_smc - // main::@111 - // if(smc_bootloader == 0x0100) - // [105] if(smc_bootloader#0==$100) goto main::@1 -- vwum1_eq_vwuc1_then_la1 - lda smc_bootloader - cmp #<$100 - bne !+ - lda smc_bootloader+1 - cmp #>$100 - bne !__b1+ - jmp __b1 - !__b1: - !: - // main::@15 - // if(smc_bootloader == 0x0200) - // [106] if(smc_bootloader#0==$200) goto main::@18 -- vwum1_eq_vwuc1_then_la1 - lda smc_bootloader - cmp #<$200 - bne !+ - lda smc_bootloader+1 - cmp #>$200 - bne !__b18+ - jmp __b18 - !__b18: - !: - // main::@16 - // if(smc_bootloader > 0x2) - // [107] if(smc_bootloader#0>=2+1) goto main::@19 -- vwum1_ge_vbuc1_then_la1 - lda smc_bootloader+1 - beq !__b19+ - jmp __b19 - !__b19: - lda smc_bootloader - cmp #2+1 - bcc !__b19+ - jmp __b19 - !__b19: - !: - // main::@17 - // cx16_k_i2c_read_byte(FLASH_I2C_SMC_DEVICE, FLASH_I2C_SMC_VERSION) - // [108] cx16_k_i2c_read_byte::device = $42 -- vbum1=vbuc1 - lda #$42 - sta cx16_k_i2c_read_byte.device - // [109] cx16_k_i2c_read_byte::offset = $30 -- vbum1=vbuc1 - lda #$30 - sta cx16_k_i2c_read_byte.offset - // [110] call cx16_k_i2c_read_byte - jsr cx16_k_i2c_read_byte - // [111] cx16_k_i2c_read_byte::return#14 = cx16_k_i2c_read_byte::return#1 - // main::@118 - // smc_release = cx16_k_i2c_read_byte(FLASH_I2C_SMC_DEVICE, FLASH_I2C_SMC_VERSION) - // [112] smc_release#0 = cx16_k_i2c_read_byte::return#14 -- vbum1=vwum2 - lda cx16_k_i2c_read_byte.return - sta smc_release - // cx16_k_i2c_read_byte(FLASH_I2C_SMC_DEVICE, FLASH_I2C_SMC_MAJOR) - // [113] cx16_k_i2c_read_byte::device = $42 -- vbum1=vbuc1 - lda #$42 - sta cx16_k_i2c_read_byte.device - // [114] cx16_k_i2c_read_byte::offset = $31 -- vbum1=vbuc1 - lda #$31 - sta cx16_k_i2c_read_byte.offset - // [115] call cx16_k_i2c_read_byte - jsr cx16_k_i2c_read_byte - // [116] cx16_k_i2c_read_byte::return#15 = cx16_k_i2c_read_byte::return#1 - // main::@119 - // smc_major = cx16_k_i2c_read_byte(FLASH_I2C_SMC_DEVICE, FLASH_I2C_SMC_MAJOR) - // [117] smc_major#0 = cx16_k_i2c_read_byte::return#15 -- vbum1=vwum2 - lda cx16_k_i2c_read_byte.return - sta smc_major - // cx16_k_i2c_read_byte(FLASH_I2C_SMC_DEVICE, FLASH_I2C_SMC_MINOR) - // [118] cx16_k_i2c_read_byte::device = $42 -- vbum1=vbuc1 - lda #$42 - sta cx16_k_i2c_read_byte.device - // [119] cx16_k_i2c_read_byte::offset = $32 -- vbum1=vbuc1 - lda #$32 - sta cx16_k_i2c_read_byte.offset - // [120] call cx16_k_i2c_read_byte - jsr cx16_k_i2c_read_byte - // [121] cx16_k_i2c_read_byte::return#16 = cx16_k_i2c_read_byte::return#1 - // main::@120 - // smc_minor = cx16_k_i2c_read_byte(FLASH_I2C_SMC_DEVICE, FLASH_I2C_SMC_MINOR) - // [122] smc_minor#0 = cx16_k_i2c_read_byte::return#16 -- vbum1=vwum2 - lda cx16_k_i2c_read_byte.return - sta smc_minor - // smc_get_version_text(smc_version_text, smc_release, smc_major, smc_minor) - // [123] smc_get_version_text::release#0 = smc_release#0 -- vbum1=vbum2 - lda smc_release - sta smc_get_version_text.release - // [124] smc_get_version_text::major#0 = smc_major#0 -- vbum1=vbum2 - lda smc_major - sta smc_get_version_text.major - // [125] smc_get_version_text::minor#0 = smc_minor#0 -- vbum1=vbum2 - lda smc_minor - sta smc_get_version_text.minor - // [126] call smc_get_version_text - // [1079] phi from main::@120 to smc_get_version_text [phi:main::@120->smc_get_version_text] - // [1079] phi smc_get_version_text::minor#2 = smc_get_version_text::minor#0 [phi:main::@120->smc_get_version_text#0] -- register_copy - // [1079] phi smc_get_version_text::major#2 = smc_get_version_text::major#0 [phi:main::@120->smc_get_version_text#1] -- register_copy - // [1079] phi smc_get_version_text::release#2 = smc_get_version_text::release#0 [phi:main::@120->smc_get_version_text#2] -- register_copy - // [1079] phi smc_get_version_text::version_string#2 = smc_version_text [phi:main::@120->smc_get_version_text#3] -- pbuz1=pbuc1 - lda #smc_version_text - sta.z smc_get_version_text.version_string+1 - jsr smc_get_version_text - // main::@121 - // [127] smc_bootloader#503 = smc_bootloader#0 -- vwum1=vwum2 - lda smc_bootloader - sta smc_bootloader_1 - lda smc_bootloader+1 - sta smc_bootloader_1+1 - // display_info_smc(STATUS_DETECTED, NULL) - // [128] call display_info_smc - // [962] phi from main::@121 to display_info_smc [phi:main::@121->display_info_smc] - // [962] phi display_info_smc::info_text#20 = 0 [phi:main::@121->display_info_smc#0] -- pbuz1=vbuc1 - lda #<0 - sta.z display_info_smc.info_text - sta.z display_info_smc.info_text+1 - // [962] phi smc_bootloader#14 = smc_bootloader#503 [phi:main::@121->display_info_smc#1] -- register_copy - // [962] phi display_info_smc::info_status#20 = STATUS_DETECTED [phi:main::@121->display_info_smc#2] -- vbum1=vbuc1 - lda #STATUS_DETECTED - sta display_info_smc.info_status - jsr display_info_smc - // [129] phi from main::@121 to main::@2 [phi:main::@121->main::@2] - // [129] phi smc_minor#398 = smc_minor#0 [phi:main::@121->main::@2#0] -- register_copy - // [129] phi smc_major#399 = smc_major#0 [phi:main::@121->main::@2#1] -- register_copy - // [129] phi smc_release#400 = smc_release#0 [phi:main::@121->main::@2#2] -- register_copy - // main::@2 - __b2: + // [98] phi from main::@12 to main::@60 [phi:main::@12->main::@60] + // main::@60 // main_vera_detect() - // [130] call main_vera_detect - // [1096] phi from main::@2 to main_vera_detect [phi:main::@2->main_vera_detect] + // [99] call main_vera_detect + // [710] phi from main::@60 to main_vera_detect [phi:main::@60->main_vera_detect] jsr main_vera_detect - // main::SEI1 - // asm - // asm { sei } - sei - // [132] phi from main::SEI1 to main::@68 [phi:main::SEI1->main::@68] - // main::@68 - // rom_detect() - // [133] call rom_detect - // Detecting ROM chips - // [1105] phi from main::@68 to rom_detect [phi:main::@68->rom_detect] - jsr rom_detect - // [134] phi from main::@68 to main::@122 [phi:main::@68->main::@122] - // main::@122 - // display_chip_rom() - // [135] call display_chip_rom - // [943] phi from main::@122 to display_chip_rom [phi:main::@122->display_chip_rom] - jsr display_chip_rom - // [136] phi from main::@122 to main::@20 [phi:main::@122->main::@20] - // [136] phi main::rom_chip1#10 = 0 [phi:main::@122->main::@20#0] -- vbuz1=vbuc1 - lda #0 - sta.z rom_chip1 - // main::@20 - __b20: - // for(unsigned char rom_chip = 0; rom_chip < 8; rom_chip++) - // [137] if(main::rom_chip1#10<8) goto main::@21 -- vbuz1_lt_vbuc1_then_la1 - lda.z rom_chip1 - cmp #8 - bcs !__b21+ - jmp __b21 - !__b21: // main::bank_set_brom1 // BROM = bank - // [138] BROM = main::bank_set_brom1_bank#0 -- vbuz1=vbuc1 + // [100] BROM = main::bank_set_brom1_bank#0 -- vbuz1=vbuc1 lda #bank_set_brom1_bank sta.z BROM // main::CLI1 // asm // asm { cli } cli - // main::check_status_smc1 - // status_smc == status - // [140] main::check_status_smc1_$0 = status_smc#0 == STATUS_DETECTED -- vboz1=vbum2_eq_vbuc1 - lda status_smc - eor #STATUS_DETECTED - beq !+ - lda #1 - !: - eor #1 - sta.z check_status_smc1_main__0 - // return (unsigned char)(status_smc == status); - // [141] main::check_status_smc1_return#0 = (char)main::check_status_smc1_$0 -- vbum1=vbuz2 - sta check_status_smc1_return - // main::@69 - // if(check_status_smc(STATUS_DETECTED)) - // [142] if(0==main::check_status_smc1_return#0) goto main::CLI2 -- 0_eq_vbum1_then_la1 - bne !__b7+ - jmp __b7 - !__b7: - // [143] phi from main::@69 to main::@24 [phi:main::@69->main::@24] - // main::@24 - // display_action_progress("Checking SMC.BIN ...") - // [144] call display_action_progress - // [904] phi from main::@24 to display_action_progress [phi:main::@24->display_action_progress] - // [904] phi display_action_progress::info_text#27 = main::info_text3 [phi:main::@24->display_action_progress#0] -- pbuz1=pbuc1 - lda #info_text3 - sta.z display_action_progress.info_text+1 - jsr display_action_progress - // [145] phi from main::@24 to main::@128 [phi:main::@24->main::@128] - // main::@128 - // smc_read(STATUS_CHECKING) - // [146] call smc_read - // [1155] phi from main::@128 to smc_read [phi:main::@128->smc_read] - // [1155] phi __errno#102 = 0 [phi:main::@128->smc_read#0] -- vwsm1=vwsc1 - lda #<0 - sta __errno - sta __errno+1 - // [1155] phi __stdio_filecount#128 = 0 [phi:main::@128->smc_read#1] -- vbum1=vbuc1 - sta __stdio_filecount - // [1155] phi smc_read::info_status#10 = STATUS_CHECKING [phi:main::@128->smc_read#2] -- vbum1=vbuc1 - lda #STATUS_CHECKING - sta smc_read.info_status - jsr smc_read - // smc_read(STATUS_CHECKING) - // [147] smc_read::return#2 = smc_read::return#0 - // main::@129 - // smc_file_size = smc_read(STATUS_CHECKING) - // [148] smc_file_size#0 = smc_read::return#2 -- vwum1=vwum2 - lda smc_read.return - sta smc_file_size - lda smc_read.return+1 - sta smc_file_size+1 - // if (!smc_file_size) - // [149] if(0==smc_file_size#0) goto main::@27 -- 0_eq_vwum1_then_la1 - lda smc_file_size - ora smc_file_size+1 - bne !__b27+ - jmp __b27 - !__b27: - // main::@25 - // if(smc_file_size > 0x1E00) - // [150] if(smc_file_size#0>$1e00) goto main::@28 -- vwum1_gt_vwuc1_then_la1 - lda #>$1e00 - cmp smc_file_size+1 - bcs !__b28+ - jmp __b28 - !__b28: - bne !+ - lda #<$1e00 - cmp smc_file_size - bcs !__b28+ - jmp __b28 - !__b28: - !: - // main::@26 - // smc_file_release = smc_file_header[0] - // [151] smc_file_release#0 = *smc_file_header -- vbum1=_deref_pbuc1 - // SF4 | SMC.BIN and all ok | Display the SMC.BIN file version and set SMC to Flash. | Flash - // The first 3 bytes of the smc file header is the version of the SMC file. - lda smc_file_header - sta smc_file_release - // smc_file_major = smc_file_header[1] - // [152] smc_file_major#0 = *(smc_file_header+1) -- vbum1=_deref_pbuc1 - lda smc_file_header+1 - sta smc_file_major - // smc_file_minor = smc_file_header[2] - // [153] smc_file_minor#0 = *(smc_file_header+2) -- vbum1=_deref_pbuc1 - lda smc_file_header+2 - sta smc_file_minor - // smc_get_version_text(smc_file_version_text, smc_file_release, smc_file_major, smc_file_minor) - // [154] smc_get_version_text::release#1 = smc_file_release#0 -- vbum1=vbum2 - lda smc_file_release - sta smc_get_version_text.release - // [155] smc_get_version_text::major#1 = smc_file_major#0 -- vbum1=vbum2 - lda smc_file_major - sta smc_get_version_text.major - // [156] smc_get_version_text::minor#1 = smc_file_minor#0 -- vbum1=vbum2 - lda smc_file_minor - sta smc_get_version_text.minor - // [157] call smc_get_version_text - // [1079] phi from main::@26 to smc_get_version_text [phi:main::@26->smc_get_version_text] - // [1079] phi smc_get_version_text::minor#2 = smc_get_version_text::minor#1 [phi:main::@26->smc_get_version_text#0] -- register_copy - // [1079] phi smc_get_version_text::major#2 = smc_get_version_text::major#1 [phi:main::@26->smc_get_version_text#1] -- register_copy - // [1079] phi smc_get_version_text::release#2 = smc_get_version_text::release#1 [phi:main::@26->smc_get_version_text#2] -- register_copy - // [1079] phi smc_get_version_text::version_string#2 = main::smc_file_version_text [phi:main::@26->smc_get_version_text#3] -- pbuz1=pbuc1 - lda #smc_file_version_text - sta.z smc_get_version_text.version_string+1 - jsr smc_get_version_text - // [158] phi from main::@26 to main::@130 [phi:main::@26->main::@130] - // main::@130 - // sprintf(info_text, "SMC.BIN:%s", smc_file_version_text) - // [159] call snprintf_init - // [1205] phi from main::@130 to snprintf_init [phi:main::@130->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:main::@130->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 - jsr snprintf_init - // [160] phi from main::@130 to main::@131 [phi:main::@130->main::@131] - // main::@131 - // sprintf(info_text, "SMC.BIN:%s", smc_file_version_text) - // [161] call printf_str - // [1210] phi from main::@131 to printf_str [phi:main::@131->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main::@131->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main::s4 [phi:main::@131->printf_str#1] -- pbuz1=pbuc1 - lda #s4 - sta.z printf_str.s+1 - jsr printf_str - // [162] phi from main::@131 to main::@132 [phi:main::@131->main::@132] - // main::@132 - // sprintf(info_text, "SMC.BIN:%s", smc_file_version_text) - // [163] call printf_string - // [1219] phi from main::@132 to printf_string [phi:main::@132->printf_string] - // [1219] phi printf_string::putc#26 = &snputc [phi:main::@132->printf_string#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = main::smc_file_version_text [phi:main::@132->printf_string#1] -- pbuz1=pbuc1 - lda #smc_file_version_text - sta.z printf_string.str+1 - // [1219] phi printf_string::format_justify_left#26 = 0 [phi:main::@132->printf_string#2] -- vbum1=vbuc1 - lda #0 - sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = 0 [phi:main::@132->printf_string#3] -- vbum1=vbuc1 - sta printf_string.format_min_length - jsr printf_string - // main::@133 - // sprintf(info_text, "SMC.BIN:%s", smc_file_version_text) - // [164] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 - lda #0 - pha - // [165] callexecute snputc -- call_vprc1 - jsr snputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // [167] smc_bootloader#505 = smc_bootloader#0 -- vwum1=vwum2 - lda smc_bootloader - sta smc_bootloader_1 - lda smc_bootloader+1 - sta smc_bootloader_1+1 - // display_info_smc(STATUS_FLASH, info_text) - // [168] call display_info_smc - // All ok, display file version. - // [962] phi from main::@133 to display_info_smc [phi:main::@133->display_info_smc] - // [962] phi display_info_smc::info_text#20 = info_text [phi:main::@133->display_info_smc#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z display_info_smc.info_text - lda #>@info_text - sta.z display_info_smc.info_text+1 - // [962] phi smc_bootloader#14 = smc_bootloader#505 [phi:main::@133->display_info_smc#1] -- register_copy - // [962] phi display_info_smc::info_status#20 = STATUS_FLASH [phi:main::@133->display_info_smc#2] -- vbum1=vbuc1 - lda #STATUS_FLASH - sta display_info_smc.info_status - jsr display_info_smc - // [169] phi from main::@133 to main::CLI2 [phi:main::@133->main::CLI2] - // [169] phi smc_file_minor#301 = smc_file_minor#0 [phi:main::@133->main::CLI2#0] -- register_copy - // [169] phi smc_file_major#301 = smc_file_major#0 [phi:main::@133->main::CLI2#1] -- register_copy - // [169] phi smc_file_release#301 = smc_file_release#0 [phi:main::@133->main::CLI2#2] -- register_copy - // [169] phi __stdio_filecount#109 = __stdio_filecount#39 [phi:main::@133->main::CLI2#3] -- register_copy - // [169] phi __errno#113 = __errno#123 [phi:main::@133->main::CLI2#4] -- register_copy - jmp CLI2 - // [169] phi from main::@69 to main::CLI2 [phi:main::@69->main::CLI2] - __b7: - // [169] phi smc_file_minor#301 = 0 [phi:main::@69->main::CLI2#0] -- vbum1=vbuc1 - lda #0 - sta smc_file_minor - // [169] phi smc_file_major#301 = 0 [phi:main::@69->main::CLI2#1] -- vbum1=vbuc1 - sta smc_file_major - // [169] phi smc_file_release#301 = 0 [phi:main::@69->main::CLI2#2] -- vbum1=vbuc1 - sta smc_file_release - // [169] phi __stdio_filecount#109 = 0 [phi:main::@69->main::CLI2#3] -- vbum1=vbuc1 - sta __stdio_filecount - // [169] phi __errno#113 = 0 [phi:main::@69->main::CLI2#4] -- vwsm1=vwsc1 - sta __errno - sta __errno+1 - // main::CLI2 - CLI2: - // asm - // asm { cli } - cli - // main::bank_set_brom3 - // BROM = bank - // [171] BROM = main::bank_set_brom3_bank#0 -- vbuz1=vbuc1 - lda #bank_set_brom3_bank - sta.z BROM - // main::CLI3 - // asm - // asm { cli } - cli - // [173] phi from main::CLI3 to main::@71 [phi:main::CLI3->main::@71] - // main::@71 + // [102] phi from main::CLI1 to main::@28 [phi:main::CLI1->main::@28] + // main::@28 // display_progress_clear() - // [174] call display_progress_clear - // [918] phi from main::@71 to display_progress_clear [phi:main::@71->display_progress_clear] + // [103] call display_progress_clear + // [573] phi from main::@28 to display_progress_clear [phi:main::@28->display_progress_clear] jsr display_progress_clear - // [175] phi from main::@71 to main::@127 [phi:main::@71->main::@127] - // main::@127 + // [104] phi from main::@28 to main::@61 [phi:main::@28->main::@61] + // main::@61 // main_vera_check() - // [176] call main_vera_check - // [1244] phi from main::@127 to main_vera_check [phi:main::@127->main_vera_check] + // [105] call main_vera_check + // [719] phi from main::@61 to main_vera_check [phi:main::@61->main_vera_check] jsr main_vera_check - // main::bank_set_brom4 + // main::bank_set_brom2 // BROM = bank - // [177] BROM = main::bank_set_brom4_bank#0 -- vbuz1=vbuc1 - lda #bank_set_brom4_bank + // [106] BROM = main::bank_set_brom2_bank#0 -- vbuz1=vbuc1 + lda #bank_set_brom2_bank sta.z BROM - // main::SEI2 + // main::SEI1 // asm // asm { sei } sei - // main::SEI3 - // asm { sei } - sei - // [180] phi from main::SEI3 to main::@29 [phi:main::SEI3->main::@29] - // [180] phi __stdio_filecount#111 = __stdio_filecount#36 [phi:main::SEI3->main::@29#0] -- register_copy - // [180] phi __errno#115 = __errno#123 [phi:main::SEI3->main::@29#1] -- register_copy - // [180] phi main::rom_chip2#10 = 0 [phi:main::SEI3->main::@29#2] -- vbuz1=vbuc1 - lda #0 - sta.z rom_chip2 - // We loop all the possible ROM chip slots on the board and on the extension card, - // and we check the file contents. - // Any error identified gets reported and this chip will not be flashed. - // In case of ROM0.BIN in error, no flashing will be done! - // main::@29 - __b29: - // for(unsigned char rom_chip = 0; rom_chip < 8; rom_chip++) - // [181] if(main::rom_chip2#10<8) goto main::bank_set_brom5 -- vbuz1_lt_vbuc1_then_la1 - lda.z rom_chip2 - cmp #8 - bcs !bank_set_brom5+ - jmp bank_set_brom5 - !bank_set_brom5: - // main::bank_set_brom6 - // BROM = bank - // [182] BROM = main::bank_set_brom6_bank#0 -- vbuz1=vbuc1 - lda #bank_set_brom6_bank - sta.z BROM - // main::CLI4 - // asm - // asm { cli } - cli - // main::check_status_smc2 + // main::check_status_smc1 // status_smc == status - // [184] main::check_status_smc2_$0 = status_smc#0 == STATUS_FLASH -- vbom1=vbum2_eq_vbuc1 + // [108] main::check_status_smc1_$0 = status_smc#0 == STATUS_FLASH -- vboz1=vbum2_eq_vbuc1 lda status_smc eor #STATUS_FLASH beq !+ lda #1 !: eor #1 - sta check_status_smc2_main__0 + sta.z check_status_smc1_main__0 // return (unsigned char)(status_smc == status); - // [185] main::check_status_smc2_return#0 = (char)main::check_status_smc2_$0 -- vbum1=vbum2 - sta check_status_smc2_return - // [186] phi from main::check_status_smc2 to main::check_status_cx16_rom1 [phi:main::check_status_smc2->main::check_status_cx16_rom1] + // [109] main::check_status_smc1_return#0 = (char)main::check_status_smc1_$0 -- vbum1=vbuz2 + sta check_status_smc1_return + // [110] phi from main::check_status_smc1 to main::check_status_cx16_rom1 [phi:main::check_status_smc1->main::check_status_cx16_rom1] // main::check_status_cx16_rom1 // main::check_status_cx16_rom1_check_status_rom1 // status_rom[rom_chip] == status - // [187] main::check_status_cx16_rom1_check_status_rom1_$0 = *status_rom == STATUS_FLASH -- vbom1=_deref_pbuc1_eq_vbuc2 + // [111] main::check_status_cx16_rom1_check_status_rom1_$0 = *status_rom == STATUS_FLASH -- vboz1=_deref_pbuc1_eq_vbuc2 lda status_rom eor #STATUS_FLASH beq !+ lda #1 !: eor #1 - sta check_status_cx16_rom1_check_status_rom1_main__0 + sta.z check_status_cx16_rom1_check_status_rom1_main__0 // return (unsigned char)(status_rom[rom_chip] == status); - // [188] main::check_status_cx16_rom1_check_status_rom1_return#0 = (char)main::check_status_cx16_rom1_check_status_rom1_$0 -- vbum1=vbum2 + // [112] main::check_status_cx16_rom1_check_status_rom1_return#0 = (char)main::check_status_cx16_rom1_check_status_rom1_$0 -- vbum1=vbuz2 sta check_status_cx16_rom1_check_status_rom1_return - // main::@73 + // main::@29 // if(!check_status_smc(STATUS_FLASH) && check_status_cx16_rom(STATUS_FLASH)) - // [189] if(0!=main::check_status_smc2_return#0) goto main::check_status_smc3 -- 0_neq_vbum1_then_la1 - lda check_status_smc2_return - bne check_status_smc3 - // main::@244 - // [190] if(0!=main::check_status_cx16_rom1_check_status_rom1_return#0) goto main::@36 -- 0_neq_vbum1_then_la1 + // [113] if(0!=main::check_status_smc1_return#0) goto main::check_status_smc2 -- 0_neq_vbum1_then_la1 + lda check_status_smc1_return + bne check_status_smc2 + // main::@125 + // [114] if(0!=main::check_status_cx16_rom1_check_status_rom1_return#0) goto main::@13 -- 0_neq_vbum1_then_la1 lda check_status_cx16_rom1_check_status_rom1_return - beq !__b36+ - jmp __b36 - !__b36: - // main::check_status_smc3 - check_status_smc3: + beq !__b13+ + jmp __b13 + !__b13: + // main::check_status_smc2 + check_status_smc2: // status_smc == status - // [191] main::check_status_smc3_$0 = status_smc#0 == STATUS_FLASH -- vbom1=vbum2_eq_vbuc1 + // [115] main::check_status_smc2_$0 = status_smc#0 == STATUS_FLASH -- vboz1=vbum2_eq_vbuc1 lda status_smc eor #STATUS_FLASH beq !+ lda #1 !: eor #1 - sta check_status_smc3_main__0 + sta.z check_status_smc2_main__0 // return (unsigned char)(status_smc == status); - // [192] main::check_status_smc3_return#0 = (char)main::check_status_smc3_$0 -- vbum1=vbum2 - sta check_status_smc3_return - // [193] phi from main::check_status_smc3 to main::check_status_cx16_rom2 [phi:main::check_status_smc3->main::check_status_cx16_rom2] + // [116] main::check_status_smc2_return#0 = (char)main::check_status_smc2_$0 -- vbum1=vbuz2 + sta check_status_smc2_return + // [117] phi from main::check_status_smc2 to main::check_status_cx16_rom2 [phi:main::check_status_smc2->main::check_status_cx16_rom2] // main::check_status_cx16_rom2 // main::check_status_cx16_rom2_check_status_rom1 // status_rom[rom_chip] == status - // [194] main::check_status_cx16_rom2_check_status_rom1_$0 = *status_rom == STATUS_NONE -- vbom1=_deref_pbuc1_eq_vbuc2 + // [118] main::check_status_cx16_rom2_check_status_rom1_$0 = *status_rom == STATUS_NONE -- vboz1=_deref_pbuc1_eq_vbuc2 lda status_rom eor #STATUS_NONE beq !+ lda #1 !: eor #1 - sta check_status_cx16_rom2_check_status_rom1_main__0 + sta.z check_status_cx16_rom2_check_status_rom1_main__0 // return (unsigned char)(status_rom[rom_chip] == status); - // [195] main::check_status_cx16_rom2_check_status_rom1_return#0 = (char)main::check_status_cx16_rom2_check_status_rom1_$0 -- vbum1=vbum2 + // [119] main::check_status_cx16_rom2_check_status_rom1_return#0 = (char)main::check_status_cx16_rom2_check_status_rom1_$0 -- vbum1=vbuz2 sta check_status_cx16_rom2_check_status_rom1_return - // main::@74 + // main::@30 // if(check_status_smc(STATUS_FLASH) && check_status_cx16_rom(STATUS_NONE)) - // [196] if(0==main::check_status_smc3_return#0) goto main::check_status_smc4 -- 0_eq_vbum1_then_la1 + // [120] if(0==main::check_status_smc2_return#0) goto main::check_status_smc3 -- 0_eq_vbum1_then_la1 // VA3 | SMC.BIN and CX16 ROM not Detected | Display issue and don't flash. Ask to close the J1 jumper pins on the CX16 main board. | Issue - lda check_status_smc3_return - beq check_status_smc4 - // main::@245 - // [197] if(0!=main::check_status_cx16_rom2_check_status_rom1_return#0) goto main::@3 -- 0_neq_vbum1_then_la1 + lda check_status_smc2_return + beq check_status_smc3 + // main::@126 + // [121] if(0!=main::check_status_cx16_rom2_check_status_rom1_return#0) goto main::@1 -- 0_neq_vbum1_then_la1 lda check_status_cx16_rom2_check_status_rom1_return - beq !__b3+ - jmp __b3 - !__b3: - // main::check_status_smc4 - check_status_smc4: + beq !__b1+ + jmp __b1 + !__b1: + // main::check_status_smc3 + check_status_smc3: // status_smc == status - // [198] main::check_status_smc4_$0 = status_smc#0 == STATUS_FLASH -- vbom1=vbum2_eq_vbuc1 + // [122] main::check_status_smc3_$0 = status_smc#0 == STATUS_FLASH -- vboz1=vbum2_eq_vbuc1 lda status_smc eor #STATUS_FLASH beq !+ lda #1 !: eor #1 - sta check_status_smc4_main__0 + sta.z check_status_smc3_main__0 // return (unsigned char)(status_smc == status); - // [199] main::check_status_smc4_return#0 = (char)main::check_status_smc4_$0 -- vbum1=vbum2 - sta check_status_smc4_return - // [200] phi from main::check_status_smc4 to main::check_status_cx16_rom3 [phi:main::check_status_smc4->main::check_status_cx16_rom3] + // [123] main::check_status_smc3_return#0 = (char)main::check_status_smc3_$0 -- vbum1=vbuz2 + sta check_status_smc3_return + // [124] phi from main::check_status_smc3 to main::check_status_cx16_rom3 [phi:main::check_status_smc3->main::check_status_cx16_rom3] // main::check_status_cx16_rom3 // main::check_status_cx16_rom3_check_status_rom1 // status_rom[rom_chip] == status - // [201] main::check_status_cx16_rom3_check_status_rom1_$0 = *status_rom == STATUS_FLASH -- vbom1=_deref_pbuc1_eq_vbuc2 + // [125] main::check_status_cx16_rom3_check_status_rom1_$0 = *status_rom == STATUS_FLASH -- vboz1=_deref_pbuc1_eq_vbuc2 lda status_rom eor #STATUS_FLASH beq !+ lda #1 !: eor #1 - sta check_status_cx16_rom3_check_status_rom1_main__0 + sta.z check_status_cx16_rom3_check_status_rom1_main__0 // return (unsigned char)(status_rom[rom_chip] == status); - // [202] main::check_status_cx16_rom3_check_status_rom1_return#0 = (char)main::check_status_cx16_rom3_check_status_rom1_$0 -- vbum1=vbum2 + // [126] main::check_status_cx16_rom3_check_status_rom1_return#0 = (char)main::check_status_cx16_rom3_check_status_rom1_$0 -- vbum1=vbuz2 sta check_status_cx16_rom3_check_status_rom1_return - // main::@75 + // main::@31 // if(check_status_smc(STATUS_FLASH) && !check_status_cx16_rom(STATUS_FLASH)) - // [203] if(0==main::check_status_smc4_return#0) goto main::check_status_smc5 -- 0_eq_vbum1_then_la1 - lda check_status_smc4_return - beq check_status_smc5 - // main::@246 - // [204] if(0==main::check_status_cx16_rom3_check_status_rom1_return#0) goto main::@5 -- 0_eq_vbum1_then_la1 + // [127] if(0==main::check_status_smc3_return#0) goto main::check_status_smc4 -- 0_eq_vbum1_then_la1 + lda check_status_smc3_return + beq check_status_smc4 + // main::@127 + // [128] if(0==main::check_status_cx16_rom3_check_status_rom1_return#0) goto main::@3 -- 0_eq_vbum1_then_la1 lda check_status_cx16_rom3_check_status_rom1_return - bne !__b5+ - jmp __b5 - !__b5: - // main::check_status_smc5 - check_status_smc5: + bne !__b3+ + jmp __b3 + !__b3: + // main::check_status_smc4 + check_status_smc4: // status_smc == status - // [205] main::check_status_smc5_$0 = status_smc#0 == STATUS_FLASH -- vbom1=vbum2_eq_vbuc1 + // [129] main::check_status_smc4_$0 = status_smc#0 == STATUS_FLASH -- vboz1=vbum2_eq_vbuc1 lda status_smc eor #STATUS_FLASH beq !+ lda #1 !: eor #1 - sta check_status_smc5_main__0 + sta.z check_status_smc4_main__0 // return (unsigned char)(status_smc == status); - // [206] main::check_status_smc5_return#0 = (char)main::check_status_smc5_$0 -- vbum1=vbum2 - sta check_status_smc5_return - // [207] phi from main::check_status_smc5 to main::check_status_cx16_rom4 [phi:main::check_status_smc5->main::check_status_cx16_rom4] + // [130] main::check_status_smc4_return#0 = (char)main::check_status_smc4_$0 -- vbum1=vbuz2 + sta check_status_smc4_return + // [131] phi from main::check_status_smc4 to main::check_status_cx16_rom4 [phi:main::check_status_smc4->main::check_status_cx16_rom4] // main::check_status_cx16_rom4 // main::check_status_cx16_rom4_check_status_rom1 // status_rom[rom_chip] == status - // [208] main::check_status_cx16_rom4_check_status_rom1_$0 = *status_rom == STATUS_FLASH -- vbom1=_deref_pbuc1_eq_vbuc2 + // [132] main::check_status_cx16_rom4_check_status_rom1_$0 = *status_rom == STATUS_FLASH -- vboz1=_deref_pbuc1_eq_vbuc2 lda status_rom eor #STATUS_FLASH beq !+ lda #1 !: eor #1 - sta check_status_cx16_rom4_check_status_rom1_main__0 + sta.z check_status_cx16_rom4_check_status_rom1_main__0 // return (unsigned char)(status_rom[rom_chip] == status); - // [209] main::check_status_cx16_rom4_check_status_rom1_return#0 = (char)main::check_status_cx16_rom4_check_status_rom1_$0 -- vbum1=vbum2 + // [133] main::check_status_cx16_rom4_check_status_rom1_return#0 = (char)main::check_status_cx16_rom4_check_status_rom1_$0 -- vbum1=vbuz2 sta check_status_cx16_rom4_check_status_rom1_return - // main::@76 + // main::@32 // smc_supported_rom(rom_release[0]) - // [210] smc_supported_rom::rom_release#0 = *rom_release -- vbum1=_deref_pbuc1 + // [134] smc_supported_rom::rom_release#0 = *rom_release -- vbum1=_deref_pbuc1 lda rom_release sta smc_supported_rom.rom_release - // [211] call smc_supported_rom - // [1271] phi from main::@76 to smc_supported_rom [phi:main::@76->smc_supported_rom] + // [135] call smc_supported_rom + // [746] phi from main::@32 to smc_supported_rom [phi:main::@32->smc_supported_rom] jsr smc_supported_rom // smc_supported_rom(rom_release[0]) - // [212] smc_supported_rom::return#3 = smc_supported_rom::return#2 - // main::@168 - // [213] main::$45 = smc_supported_rom::return#3 -- vbum1=vbum2 + // [136] smc_supported_rom::return#3 = smc_supported_rom::return#2 + // main::@74 + // [137] main::$30 = smc_supported_rom::return#3 -- vbuz1=vbum2 lda smc_supported_rom.return - sta main__45 + sta.z main__30 // if(check_status_smc(STATUS_FLASH) && check_status_cx16_rom(STATUS_FLASH) && !smc_supported_rom(rom_release[0])) - // [214] if(0==main::check_status_smc5_return#0) goto main::check_status_smc6 -- 0_eq_vbum1_then_la1 - lda check_status_smc5_return - beq check_status_smc6 - // main::@248 - // [215] if(0==main::check_status_cx16_rom4_check_status_rom1_return#0) goto main::check_status_smc6 -- 0_eq_vbum1_then_la1 + // [138] if(0==main::check_status_smc4_return#0) goto main::check_status_smc5 -- 0_eq_vbum1_then_la1 + lda check_status_smc4_return + beq check_status_smc5 + // main::@129 + // [139] if(0==main::check_status_cx16_rom4_check_status_rom1_return#0) goto main::check_status_smc5 -- 0_eq_vbum1_then_la1 lda check_status_cx16_rom4_check_status_rom1_return - beq check_status_smc6 - // main::@247 - // [216] if(0==main::$45) goto main::@6 -- 0_eq_vbum1_then_la1 - lda main__45 - bne !__b6+ - jmp __b6 - !__b6: - // main::check_status_smc6 - check_status_smc6: + beq check_status_smc5 + // main::@128 + // [140] if(0==main::$30) goto main::@4 -- 0_eq_vbuz1_then_la1 + lda.z main__30 + bne !__b4+ + jmp __b4 + !__b4: + // main::check_status_smc5 + check_status_smc5: // status_smc == status - // [217] main::check_status_smc6_$0 = status_smc#0 == STATUS_FLASH -- vbom1=vbum2_eq_vbuc1 + // [141] main::check_status_smc5_$0 = status_smc#0 == STATUS_FLASH -- vboz1=vbum2_eq_vbuc1 lda status_smc eor #STATUS_FLASH beq !+ lda #1 !: eor #1 - sta check_status_smc6_main__0 + sta.z check_status_smc5_main__0 // return (unsigned char)(status_smc == status); - // [218] main::check_status_smc6_return#0 = (char)main::check_status_smc6_$0 -- vbum1=vbum2 - sta check_status_smc6_return - // main::@77 + // [142] main::check_status_smc5_return#0 = (char)main::check_status_smc5_$0 -- vbum1=vbuz2 + sta check_status_smc5_return + // main::@33 // if(check_status_smc(STATUS_FLASH) && smc_release == smc_file_release && smc_major == smc_file_major && smc_minor == smc_file_minor) - // [219] if(0==main::check_status_smc6_return#0) goto main::check_status_smc7 -- 0_eq_vbum1_then_la1 - beq check_status_smc7 - // main::@251 - // [220] if(smc_release#400==smc_file_release#301) goto main::@250 -- vbum1_eq_vbum2_then_la1 - lda smc_release - cmp smc_file_release - bne !__b250+ - jmp __b250 - !__b250: - // main::check_status_smc7 - check_status_smc7: + // [143] if(0!=main::check_status_smc5_return#0) goto main::@6 -- 0_neq_vbum1_then_la1 + beq !__b6+ + jmp __b6 + !__b6: + // main::check_status_smc6 + check_status_smc6: // status_smc == status - // [221] main::check_status_smc7_$0 = status_smc#0 == STATUS_ISSUE -- vbom1=vbum2_eq_vbuc1 + // [144] main::check_status_smc6_$0 = status_smc#0 == STATUS_ISSUE -- vboz1=vbum2_eq_vbuc1 lda status_smc eor #STATUS_ISSUE beq !+ lda #1 !: eor #1 - sta check_status_smc7_main__0 + sta.z check_status_smc6_main__0 // return (unsigned char)(status_smc == status); - // [222] main::check_status_smc7_return#0 = (char)main::check_status_smc7_$0 -- vbum1=vbum2 - sta check_status_smc7_return + // [145] main::check_status_smc6_return#0 = (char)main::check_status_smc6_$0 -- vbum1=vbuz2 + sta check_status_smc6_return // main::check_status_vera1 // status_vera == status - // [223] main::check_status_vera1_$0 = status_vera#127 == STATUS_ISSUE -- vbom1=vbum2_eq_vbuc1 + // [146] main::check_status_vera1_$0 = status_vera#127 == STATUS_ISSUE -- vboz1=vbum2_eq_vbuc1 lda status_vera eor #STATUS_ISSUE beq !+ lda #1 !: eor #1 - sta check_status_vera1_main__0 + sta.z check_status_vera1_main__0 // return (unsigned char)(status_vera == status); - // [224] main::check_status_vera1_return#0 = (char)main::check_status_vera1_$0 -- vbum1=vbum2 + // [147] main::check_status_vera1_return#0 = (char)main::check_status_vera1_$0 -- vbum1=vbuz2 sta check_status_vera1_return - // [225] phi from main::check_status_vera1 to main::@78 [phi:main::check_status_vera1->main::@78] - // main::@78 + // [148] phi from main::check_status_vera1 to main::@34 [phi:main::check_status_vera1->main::@34] + // main::@34 // check_status_roms(STATUS_ISSUE) - // [226] call check_status_roms - // [1278] phi from main::@78 to check_status_roms [phi:main::@78->check_status_roms] - // [1278] phi check_status_roms::status#6 = STATUS_ISSUE [phi:main::@78->check_status_roms#0] -- vbum1=vbuc1 + // [149] call check_status_roms + // [753] phi from main::@34 to check_status_roms [phi:main::@34->check_status_roms] + // [753] phi check_status_roms::status#6 = STATUS_ISSUE [phi:main::@34->check_status_roms#0] -- vbum1=vbuc1 lda #STATUS_ISSUE sta check_status_roms.status jsr check_status_roms // check_status_roms(STATUS_ISSUE) - // [227] check_status_roms::return#3 = check_status_roms::return#2 - // main::@173 - // [228] main::$62 = check_status_roms::return#3 -- vbum1=vbum2 + // [150] check_status_roms::return#3 = check_status_roms::return#2 + // main::@79 + // [151] main::$47 = check_status_roms::return#3 -- vbuz1=vbum2 lda check_status_roms.return - sta main__62 - // main::check_status_smc8 + sta.z main__47 + // main::check_status_smc7 // status_smc == status - // [229] main::check_status_smc8_$0 = status_smc#0 == STATUS_ERROR -- vbom1=vbum2_eq_vbuc1 + // [152] main::check_status_smc7_$0 = status_smc#0 == STATUS_ERROR -- vboz1=vbum2_eq_vbuc1 lda status_smc eor #STATUS_ERROR beq !+ lda #1 !: eor #1 - sta check_status_smc8_main__0 + sta.z check_status_smc7_main__0 // return (unsigned char)(status_smc == status); - // [230] main::check_status_smc8_return#0 = (char)main::check_status_smc8_$0 -- vbum1=vbum2 - sta check_status_smc8_return + // [153] main::check_status_smc7_return#0 = (char)main::check_status_smc7_$0 -- vbum1=vbuz2 + sta check_status_smc7_return // main::check_status_vera2 // status_vera == status - // [231] main::check_status_vera2_$0 = status_vera#127 == STATUS_ERROR -- vbom1=vbum2_eq_vbuc1 + // [154] main::check_status_vera2_$0 = status_vera#127 == STATUS_ERROR -- vboz1=vbum2_eq_vbuc1 lda status_vera eor #STATUS_ERROR beq !+ lda #1 !: eor #1 - sta check_status_vera2_main__0 + sta.z check_status_vera2_main__0 // return (unsigned char)(status_vera == status); - // [232] main::check_status_vera2_return#0 = (char)main::check_status_vera2_$0 -- vbum1=vbum2 + // [155] main::check_status_vera2_return#0 = (char)main::check_status_vera2_$0 -- vbum1=vbuz2 sta check_status_vera2_return - // [233] phi from main::check_status_vera2 to main::@79 [phi:main::check_status_vera2->main::@79] - // main::@79 + // [156] phi from main::check_status_vera2 to main::@35 [phi:main::check_status_vera2->main::@35] + // main::@35 // check_status_roms(STATUS_ERROR) - // [234] call check_status_roms - // [1278] phi from main::@79 to check_status_roms [phi:main::@79->check_status_roms] - // [1278] phi check_status_roms::status#6 = STATUS_ERROR [phi:main::@79->check_status_roms#0] -- vbum1=vbuc1 + // [157] call check_status_roms + // [753] phi from main::@35 to check_status_roms [phi:main::@35->check_status_roms] + // [753] phi check_status_roms::status#6 = STATUS_ERROR [phi:main::@35->check_status_roms#0] -- vbum1=vbuc1 lda #STATUS_ERROR sta check_status_roms.status jsr check_status_roms // check_status_roms(STATUS_ERROR) - // [235] check_status_roms::return#4 = check_status_roms::return#2 - // main::@174 - // [236] main::$71 = check_status_roms::return#4 -- vbum1=vbum2 + // [158] check_status_roms::return#4 = check_status_roms::return#2 + // main::@80 + // [159] main::$56 = check_status_roms::return#4 -- vbuz1=vbum2 lda check_status_roms.return - sta main__71 + sta.z main__56 // if(!check_status_smc(STATUS_ISSUE) && !check_status_vera(STATUS_ISSUE) && !check_status_roms(STATUS_ISSUE) && // !check_status_smc(STATUS_ERROR) && !check_status_vera(STATUS_ERROR) && !check_status_roms(STATUS_ERROR)) - // [237] if(0!=main::check_status_smc7_return#0) goto main::check_status_vera3 -- 0_neq_vbum1_then_la1 - lda check_status_smc7_return + // [160] if(0!=main::check_status_smc6_return#0) goto main::check_status_vera3 -- 0_neq_vbum1_then_la1 + lda check_status_smc6_return bne check_status_vera3 - // main::@256 - // [238] if(0==main::check_status_vera1_return#0) goto main::@255 -- 0_eq_vbum1_then_la1 + // main::@134 + // [161] if(0==main::check_status_vera1_return#0) goto main::@133 -- 0_eq_vbum1_then_la1 lda check_status_vera1_return - bne !__b255+ - jmp __b255 - !__b255: + bne !__b133+ + jmp __b133 + !__b133: // main::check_status_vera3 check_status_vera3: // status_vera == status - // [239] main::check_status_vera3_$0 = status_vera#127 == STATUS_ERROR -- vbom1=vbum2_eq_vbuc1 + // [162] main::check_status_vera3_$0 = status_vera#127 == STATUS_ERROR -- vboz1=vbum2_eq_vbuc1 lda status_vera eor #STATUS_ERROR beq !+ lda #1 !: eor #1 - sta check_status_vera3_main__0 + sta.z check_status_vera3_main__0 // return (unsigned char)(status_vera == status); - // [240] main::check_status_vera3_return#0 = (char)main::check_status_vera3_$0 -- vbum1=vbum2 + // [163] main::check_status_vera3_return#0 = (char)main::check_status_vera3_$0 -- vbum1=vbuz2 sta check_status_vera3_return - // main::@80 + // main::@36 // if(check_status_vera(STATUS_ERROR)) - // [241] if(0==main::check_status_vera3_return#0) goto main::check_status_smc13 -- 0_eq_vbum1_then_la1 - bne !check_status_smc13+ - jmp check_status_smc13 - !check_status_smc13: - // main::bank_set_brom10 + // [164] if(0==main::check_status_vera3_return#0) goto main::check_status_smc9 -- 0_eq_vbum1_then_la1 + bne !check_status_smc9+ + jmp check_status_smc9 + !check_status_smc9: + // main::bank_set_brom5 // BROM = bank - // [242] BROM = main::bank_set_brom10_bank#0 -- vbuz1=vbuc1 - lda #bank_set_brom10_bank + // [165] BROM = main::bank_set_brom5_bank#0 -- vbuz1=vbuc1 + lda #bank_set_brom5_bank sta.z BROM - // main::CLI6 + // main::CLI3 // asm // asm { cli } cli // main::vera_display_set_border_color1 // *VERA_CTRL &= ~VERA_DCSEL - // [244] *VERA_CTRL = *VERA_CTRL & ~VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 + // [167] *VERA_CTRL = *VERA_CTRL & ~VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 lda #VERA_DCSEL^$ff and VERA_CTRL sta VERA_CTRL // *VERA_DC_BORDER = color - // [245] *VERA_DC_BORDER = RED -- _deref_pbuc1=vbuc2 + // [168] *VERA_DC_BORDER = RED -- _deref_pbuc1=vbuc2 lda #RED sta VERA_DC_BORDER - // [246] phi from main::vera_display_set_border_color1 to main::@89 [phi:main::vera_display_set_border_color1->main::@89] - // main::@89 + // [169] phi from main::vera_display_set_border_color1 to main::@41 [phi:main::vera_display_set_border_color1->main::@41] + // main::@41 // textcolor(WHITE) - // [247] call textcolor - // [784] phi from main::@89 to textcolor [phi:main::@89->textcolor] - // [784] phi textcolor::color#23 = WHITE [phi:main::@89->textcolor#0] -- vbum1=vbuc1 + // [170] call textcolor + // [439] phi from main::@41 to textcolor [phi:main::@41->textcolor] + // [439] phi textcolor::color#21 = WHITE [phi:main::@41->textcolor#0] -- vbum1=vbuc1 lda #WHITE sta textcolor.color jsr textcolor - // [248] phi from main::@89 to main::@211 [phi:main::@89->main::@211] - // main::@211 + // [171] phi from main::@41 to main::@92 [phi:main::@41->main::@92] + // main::@92 // bgcolor(BLUE) - // [249] call bgcolor - // [789] phi from main::@211 to bgcolor [phi:main::@211->bgcolor] - // [789] phi bgcolor::color#15 = BLUE [phi:main::@211->bgcolor#0] -- vbum1=vbuc1 + // [172] call bgcolor + // [444] phi from main::@92 to bgcolor [phi:main::@92->bgcolor] + // [444] phi bgcolor::color#15 = BLUE [phi:main::@92->bgcolor#0] -- vbum1=vbuc1 lda #BLUE sta bgcolor.color jsr bgcolor - // [250] phi from main::@211 to main::@212 [phi:main::@211->main::@212] - // main::@212 + // [173] phi from main::@92 to main::@93 [phi:main::@92->main::@93] + // main::@93 // clrscr() - // [251] call clrscr + // [174] call clrscr jsr clrscr - // [252] phi from main::@212 to main::@213 [phi:main::@212->main::@213] - // main::@213 + // [175] phi from main::@93 to main::@94 [phi:main::@93->main::@94] + // main::@94 // printf("There was a severe error updating your VERA!") - // [253] call printf_str - // [1210] phi from main::@213 to printf_str [phi:main::@213->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:main::@213->printf_str#0] -- pprz1=pprc1 + // [176] call printf_str + // [785] phi from main::@94 to printf_str [phi:main::@94->printf_str] + // [785] phi printf_str::putc#53 = &cputc [phi:main::@94->printf_str#0] -- pprz1=pprc1 lda #cputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main::s15 [phi:main::@213->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #s15 + lda #>s2 sta.z printf_str.s+1 jsr printf_str - // [254] phi from main::@213 to main::@214 [phi:main::@213->main::@214] - // main::@214 + // [177] phi from main::@94 to main::@95 [phi:main::@94->main::@95] + // main::@95 // printf("You are back at the READY prompt without resetting your CX16.\n\n") - // [255] call printf_str - // [1210] phi from main::@214 to printf_str [phi:main::@214->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:main::@214->printf_str#0] -- pprz1=pprc1 + // [178] call printf_str + // [785] phi from main::@95 to printf_str [phi:main::@95->printf_str] + // [785] phi printf_str::putc#53 = &cputc [phi:main::@95->printf_str#0] -- pprz1=pprc1 lda #cputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main::s16 [phi:main::@214->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #s16 + lda #>s3 sta.z printf_str.s+1 jsr printf_str - // [256] phi from main::@214 to main::@215 [phi:main::@214->main::@215] - // main::@215 + // [179] phi from main::@95 to main::@96 [phi:main::@95->main::@96] + // main::@96 // printf("Please don't reset or shut down your VERA until you've\n") - // [257] call printf_str - // [1210] phi from main::@215 to printf_str [phi:main::@215->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:main::@215->printf_str#0] -- pprz1=pprc1 + // [180] call printf_str + // [785] phi from main::@96 to printf_str [phi:main::@96->printf_str] + // [785] phi printf_str::putc#53 = &cputc [phi:main::@96->printf_str#0] -- pprz1=pprc1 lda #cputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main::s17 [phi:main::@215->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #s17 + lda #>s4 sta.z printf_str.s+1 jsr printf_str - // [258] phi from main::@215 to main::@216 [phi:main::@215->main::@216] - // main::@216 + // [181] phi from main::@96 to main::@97 [phi:main::@96->main::@97] + // main::@97 // printf("managed to either reflash your VERA with the previous firmware ") - // [259] call printf_str - // [1210] phi from main::@216 to printf_str [phi:main::@216->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:main::@216->printf_str#0] -- pprz1=pprc1 + // [182] call printf_str + // [785] phi from main::@97 to printf_str [phi:main::@97->printf_str] + // [785] phi printf_str::putc#53 = &cputc [phi:main::@97->printf_str#0] -- pprz1=pprc1 lda #cputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main::s18 [phi:main::@216->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #s18 + lda #>s5 sta.z printf_str.s+1 jsr printf_str - // [260] phi from main::@216 to main::@217 [phi:main::@216->main::@217] - // main::@217 + // [183] phi from main::@97 to main::@98 [phi:main::@97->main::@98] + // main::@98 // printf("or have update successs retrying!\n\n") - // [261] call printf_str - // [1210] phi from main::@217 to printf_str [phi:main::@217->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:main::@217->printf_str#0] -- pprz1=pprc1 + // [184] call printf_str + // [785] phi from main::@98 to printf_str [phi:main::@98->printf_str] + // [785] phi printf_str::putc#53 = &cputc [phi:main::@98->printf_str#0] -- pprz1=pprc1 lda #cputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main::s19 [phi:main::@217->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #s19 + lda #>s6 sta.z printf_str.s+1 jsr printf_str - // [262] phi from main::@217 to main::@218 [phi:main::@217->main::@218] - // main::@218 + // [185] phi from main::@98 to main::@99 [phi:main::@98->main::@99] + // main::@99 // printf("PLEASE REMOVE THE JP1 JUMPER OR YOUR SDCARD WON'T WORK!\n") - // [263] call printf_str - // [1210] phi from main::@218 to printf_str [phi:main::@218->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:main::@218->printf_str#0] -- pprz1=pprc1 + // [186] call printf_str + // [785] phi from main::@99 to printf_str [phi:main::@99->printf_str] + // [785] phi printf_str::putc#53 = &cputc [phi:main::@99->printf_str#0] -- pprz1=pprc1 lda #cputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main::s20 [phi:main::@218->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #s20 + lda #>s7 sta.z printf_str.s+1 jsr printf_str - // [264] phi from main::@218 to main::@219 [phi:main::@218->main::@219] - // main::@219 + // [187] phi from main::@99 to main::@100 [phi:main::@99->main::@100] + // main::@100 // wait_moment(32) - // [265] call wait_moment - // [1310] phi from main::@219 to wait_moment [phi:main::@219->wait_moment] - // [1310] phi wait_moment::w#13 = $20 [phi:main::@219->wait_moment#0] -- vbum1=vbuc1 + // [188] call wait_moment + // [794] phi from main::@100 to wait_moment [phi:main::@100->wait_moment] + // [794] phi wait_moment::w#10 = $20 [phi:main::@100->wait_moment#0] -- vbum1=vbuc1 lda #$20 sta wait_moment.w jsr wait_moment - // [266] phi from main::@219 to main::@220 [phi:main::@219->main::@220] - // main::@220 + // [189] phi from main::@100 to main::@101 [phi:main::@100->main::@101] + // main::@101 // system_reset() - // [267] call system_reset - // [1318] phi from main::@220 to system_reset [phi:main::@220->system_reset] + // [190] call system_reset + // [802] phi from main::@101 to system_reset [phi:main::@101->system_reset] jsr system_reset // main::@return // } - // [268] return + // [191] return rts - // main::check_status_smc13 - check_status_smc13: + // main::check_status_smc9 + check_status_smc9: // status_smc == status - // [269] main::check_status_smc13_$0 = status_smc#0 == STATUS_SKIP -- vbom1=vbum2_eq_vbuc1 + // [192] main::check_status_smc9_$0 = status_smc#0 == STATUS_SKIP -- vboz1=vbum2_eq_vbuc1 lda status_smc eor #STATUS_SKIP beq !+ lda #1 !: eor #1 - sta check_status_smc13_main__0 + sta.z check_status_smc9_main__0 // return (unsigned char)(status_smc == status); - // [270] main::check_status_smc13_return#0 = (char)main::check_status_smc13_$0 -- vbum1=vbum2 - sta check_status_smc13_return - // main::check_status_smc14 + // [193] main::check_status_smc9_return#0 = (char)main::check_status_smc9_$0 -- vbum1=vbuz2 + sta check_status_smc9_return + // main::check_status_smc10 // status_smc == status - // [271] main::check_status_smc14_$0 = status_smc#0 == STATUS_NONE -- vbom1=vbum2_eq_vbuc1 + // [194] main::check_status_smc10_$0 = status_smc#0 == STATUS_NONE -- vboz1=vbum2_eq_vbuc1 lda status_smc eor #STATUS_NONE beq !+ lda #1 !: eor #1 - sta check_status_smc14_main__0 + sta.z check_status_smc10_main__0 // return (unsigned char)(status_smc == status); - // [272] main::check_status_smc14_return#0 = (char)main::check_status_smc14_$0 -- vbum1=vbum2 - sta check_status_smc14_return + // [195] main::check_status_smc10_return#0 = (char)main::check_status_smc10_$0 -- vbum1=vbuz2 + sta check_status_smc10_return // main::check_status_vera6 // status_vera == status - // [273] main::check_status_vera6_$0 = status_vera#127 == STATUS_SKIP -- vbom1=vbum2_eq_vbuc1 + // [196] main::check_status_vera6_$0 = status_vera#127 == STATUS_SKIP -- vboz1=vbum2_eq_vbuc1 lda status_vera eor #STATUS_SKIP beq !+ lda #1 !: eor #1 - sta check_status_vera6_main__0 + sta.z check_status_vera6_main__0 // return (unsigned char)(status_vera == status); - // [274] main::check_status_vera6_return#0 = (char)main::check_status_vera6_$0 -- vbum1=vbum2 + // [197] main::check_status_vera6_return#0 = (char)main::check_status_vera6_$0 -- vbum1=vbuz2 sta check_status_vera6_return // main::check_status_vera7 // status_vera == status - // [275] main::check_status_vera7_$0 = status_vera#127 == STATUS_NONE -- vbom1=vbum2_eq_vbuc1 + // [198] main::check_status_vera7_$0 = status_vera#127 == STATUS_NONE -- vboz1=vbum2_eq_vbuc1 lda status_vera eor #STATUS_NONE beq !+ lda #1 !: eor #1 - sta check_status_vera7_main__0 + sta.z check_status_vera7_main__0 // return (unsigned char)(status_vera == status); - // [276] main::check_status_vera7_return#0 = (char)main::check_status_vera7_$0 -- vbum1=vbum2 + // [199] main::check_status_vera7_return#0 = (char)main::check_status_vera7_$0 -- vbum1=vbuz2 sta check_status_vera7_return - // [277] phi from main::check_status_vera7 to main::@88 [phi:main::check_status_vera7->main::@88] - // main::@88 + // [200] phi from main::check_status_vera7 to main::@40 [phi:main::check_status_vera7->main::@40] + // main::@40 // check_status_roms_less(STATUS_SKIP) - // [278] call check_status_roms_less - // [1323] phi from main::@88 to check_status_roms_less [phi:main::@88->check_status_roms_less] + // [201] call check_status_roms_less + // [807] phi from main::@40 to check_status_roms_less [phi:main::@40->check_status_roms_less] jsr check_status_roms_less // check_status_roms_less(STATUS_SKIP) - // [279] check_status_roms_less::return#3 = check_status_roms_less::return#2 - // main::@210 - // [280] main::$84 = check_status_roms_less::return#3 -- vbum1=vbum2 + // [202] check_status_roms_less::return#3 = check_status_roms_less::return#2 + // main::@91 + // [203] main::$69 = check_status_roms_less::return#3 -- vbuz1=vbum2 lda check_status_roms_less.return - sta main__84 + sta.z main__69 // if((check_status_smc(STATUS_SKIP) || check_status_smc(STATUS_NONE)) && // (check_status_vera(STATUS_SKIP) || check_status_vera(STATUS_NONE)) && // (check_status_roms_less(STATUS_SKIP)) ) - // [281] if(0!=main::check_status_smc13_return#0) goto main::@264 -- 0_neq_vbum1_then_la1 - lda check_status_smc13_return - beq !__b264+ - jmp __b264 - !__b264: - // main::@265 - // [282] if(0!=main::check_status_smc14_return#0) goto main::@264 -- 0_neq_vbum1_then_la1 - lda check_status_smc14_return - beq !__b264+ - jmp __b264 - !__b264: - // main::check_status_smc15 - check_status_smc15: + // [204] if(0!=main::check_status_smc9_return#0) goto main::@139 -- 0_neq_vbum1_then_la1 + lda check_status_smc9_return + beq !__b139+ + jmp __b139 + !__b139: + // main::@140 + // [205] if(0!=main::check_status_smc10_return#0) goto main::@139 -- 0_neq_vbum1_then_la1 + lda check_status_smc10_return + beq !__b139+ + jmp __b139 + !__b139: + // main::check_status_smc11 + check_status_smc11: // status_smc == status - // [283] main::check_status_smc15_$0 = status_smc#0 == STATUS_ERROR -- vbom1=vbum2_eq_vbuc1 + // [206] main::check_status_smc11_$0 = status_smc#0 == STATUS_ERROR -- vboz1=vbum2_eq_vbuc1 lda status_smc eor #STATUS_ERROR beq !+ lda #1 !: eor #1 - sta check_status_smc15_main__0 + sta.z check_status_smc11_main__0 // return (unsigned char)(status_smc == status); - // [284] main::check_status_smc15_return#0 = (char)main::check_status_smc15_$0 -- vbum1=vbum2 - sta check_status_smc15_return + // [207] main::check_status_smc11_return#0 = (char)main::check_status_smc11_$0 -- vbum1=vbuz2 + sta check_status_smc11_return // main::check_status_vera8 // status_vera == status - // [285] main::check_status_vera8_$0 = status_vera#127 == STATUS_ERROR -- vbom1=vbum2_eq_vbuc1 + // [208] main::check_status_vera8_$0 = status_vera#127 == STATUS_ERROR -- vboz1=vbum2_eq_vbuc1 lda status_vera eor #STATUS_ERROR beq !+ lda #1 !: eor #1 - sta check_status_vera8_main__0 + sta.z check_status_vera8_main__0 // return (unsigned char)(status_vera == status); - // [286] main::check_status_vera8_return#0 = (char)main::check_status_vera8_$0 -- vbum1=vbum2 + // [209] main::check_status_vera8_return#0 = (char)main::check_status_vera8_$0 -- vbum1=vbuz2 sta check_status_vera8_return - // [287] phi from main::check_status_vera8 to main::@91 [phi:main::check_status_vera8->main::@91] - // main::@91 + // [210] phi from main::check_status_vera8 to main::@43 [phi:main::check_status_vera8->main::@43] + // main::@43 // check_status_roms(STATUS_ERROR) - // [288] call check_status_roms - // [1278] phi from main::@91 to check_status_roms [phi:main::@91->check_status_roms] - // [1278] phi check_status_roms::status#6 = STATUS_ERROR [phi:main::@91->check_status_roms#0] -- vbum1=vbuc1 + // [211] call check_status_roms + // [753] phi from main::@43 to check_status_roms [phi:main::@43->check_status_roms] + // [753] phi check_status_roms::status#6 = STATUS_ERROR [phi:main::@43->check_status_roms#0] -- vbum1=vbuc1 lda #STATUS_ERROR sta check_status_roms.status jsr check_status_roms // check_status_roms(STATUS_ERROR) - // [289] check_status_roms::return#10 = check_status_roms::return#2 - // main::@221 - // [290] main::$274 = check_status_roms::return#10 -- vbum1=vbum2 + // [212] check_status_roms::return#10 = check_status_roms::return#2 + // main::@102 + // [213] main::$153 = check_status_roms::return#10 -- vbuz1=vbum2 lda check_status_roms.return - sta main__274 + sta.z main__153 // if(check_status_smc(STATUS_ERROR) || check_status_vera(STATUS_ERROR) || check_status_roms(STATUS_ERROR)) - // [291] if(0!=main::check_status_smc15_return#0) goto main::vera_display_set_border_color3 -- 0_neq_vbum1_then_la1 - lda check_status_smc15_return + // [214] if(0!=main::check_status_smc11_return#0) goto main::vera_display_set_border_color3 -- 0_neq_vbum1_then_la1 + lda check_status_smc11_return beq !vera_display_set_border_color3+ jmp vera_display_set_border_color3 !vera_display_set_border_color3: - // main::@267 - // [292] if(0!=main::check_status_vera8_return#0) goto main::vera_display_set_border_color3 -- 0_neq_vbum1_then_la1 + // main::@142 + // [215] if(0!=main::check_status_vera8_return#0) goto main::vera_display_set_border_color3 -- 0_neq_vbum1_then_la1 lda check_status_vera8_return beq !vera_display_set_border_color3+ jmp vera_display_set_border_color3 !vera_display_set_border_color3: - // main::@266 - // [293] if(0!=main::$274) goto main::vera_display_set_border_color3 -- 0_neq_vbum1_then_la1 - lda main__274 + // main::@141 + // [216] if(0!=main::$153) goto main::vera_display_set_border_color3 -- 0_neq_vbuz1_then_la1 + lda.z main__153 beq !vera_display_set_border_color3+ jmp vera_display_set_border_color3 !vera_display_set_border_color3: - // main::check_status_smc16 + // main::check_status_smc12 // status_smc == status - // [294] main::check_status_smc16_$0 = status_smc#0 == STATUS_ISSUE -- vbom1=vbum2_eq_vbuc1 + // [217] main::check_status_smc12_$0 = status_smc#0 == STATUS_ISSUE -- vboz1=vbum2_eq_vbuc1 lda status_smc eor #STATUS_ISSUE beq !+ lda #1 !: eor #1 - sta check_status_smc16_main__0 + sta.z check_status_smc12_main__0 // return (unsigned char)(status_smc == status); - // [295] main::check_status_smc16_return#0 = (char)main::check_status_smc16_$0 -- vbum1=vbum2 - sta check_status_smc16_return + // [218] main::check_status_smc12_return#0 = (char)main::check_status_smc12_$0 -- vbum1=vbuz2 + sta check_status_smc12_return // main::check_status_vera9 // status_vera == status - // [296] main::check_status_vera9_$0 = status_vera#127 == STATUS_ISSUE -- vbom1=vbum2_eq_vbuc1 + // [219] main::check_status_vera9_$0 = status_vera#127 == STATUS_ISSUE -- vboz1=vbum2_eq_vbuc1 lda status_vera eor #STATUS_ISSUE beq !+ lda #1 !: eor #1 - sta check_status_vera9_main__0 + sta.z check_status_vera9_main__0 // return (unsigned char)(status_vera == status); - // [297] main::check_status_vera9_return#0 = (char)main::check_status_vera9_$0 -- vbum1=vbum2 + // [220] main::check_status_vera9_return#0 = (char)main::check_status_vera9_$0 -- vbum1=vbuz2 sta check_status_vera9_return - // [298] phi from main::check_status_vera9 to main::@93 [phi:main::check_status_vera9->main::@93] - // main::@93 + // [221] phi from main::check_status_vera9 to main::@45 [phi:main::check_status_vera9->main::@45] + // main::@45 // check_status_roms(STATUS_ISSUE) - // [299] call check_status_roms - // [1278] phi from main::@93 to check_status_roms [phi:main::@93->check_status_roms] - // [1278] phi check_status_roms::status#6 = STATUS_ISSUE [phi:main::@93->check_status_roms#0] -- vbum1=vbuc1 + // [222] call check_status_roms + // [753] phi from main::@45 to check_status_roms [phi:main::@45->check_status_roms] + // [753] phi check_status_roms::status#6 = STATUS_ISSUE [phi:main::@45->check_status_roms#0] -- vbum1=vbuc1 lda #STATUS_ISSUE sta check_status_roms.status jsr check_status_roms // check_status_roms(STATUS_ISSUE) - // [300] check_status_roms::return#11 = check_status_roms::return#2 - // main::@223 - // [301] main::$279 = check_status_roms::return#11 -- vbum1=vbum2 + // [223] check_status_roms::return#11 = check_status_roms::return#2 + // main::@104 + // [224] main::$158 = check_status_roms::return#11 -- vbuz1=vbum2 lda check_status_roms.return - sta main__279 + sta.z main__158 // if(check_status_smc(STATUS_ISSUE) || check_status_vera(STATUS_ISSUE) || check_status_roms(STATUS_ISSUE)) - // [302] if(0!=main::check_status_smc16_return#0) goto main::vera_display_set_border_color4 -- 0_neq_vbum1_then_la1 - lda check_status_smc16_return + // [225] if(0!=main::check_status_smc12_return#0) goto main::vera_display_set_border_color4 -- 0_neq_vbum1_then_la1 + lda check_status_smc12_return beq !vera_display_set_border_color4+ jmp vera_display_set_border_color4 !vera_display_set_border_color4: - // main::@269 - // [303] if(0!=main::check_status_vera9_return#0) goto main::vera_display_set_border_color4 -- 0_neq_vbum1_then_la1 + // main::@144 + // [226] if(0!=main::check_status_vera9_return#0) goto main::vera_display_set_border_color4 -- 0_neq_vbum1_then_la1 lda check_status_vera9_return beq !vera_display_set_border_color4+ jmp vera_display_set_border_color4 !vera_display_set_border_color4: - // main::@268 - // [304] if(0!=main::$279) goto main::vera_display_set_border_color4 -- 0_neq_vbum1_then_la1 - lda main__279 + // main::@143 + // [227] if(0!=main::$158) goto main::vera_display_set_border_color4 -- 0_neq_vbuz1_then_la1 + lda.z main__158 beq !vera_display_set_border_color4+ jmp vera_display_set_border_color4 !vera_display_set_border_color4: // main::vera_display_set_border_color5 // *VERA_CTRL &= ~VERA_DCSEL - // [305] *VERA_CTRL = *VERA_CTRL & ~VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 + // [228] *VERA_CTRL = *VERA_CTRL & ~VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 lda #VERA_DCSEL^$ff and VERA_CTRL sta VERA_CTRL // *VERA_DC_BORDER = color - // [306] *VERA_DC_BORDER = GREEN -- _deref_pbuc1=vbuc2 + // [229] *VERA_DC_BORDER = GREEN -- _deref_pbuc1=vbuc2 lda #GREEN sta VERA_DC_BORDER - // [307] phi from main::vera_display_set_border_color5 to main::@95 [phi:main::vera_display_set_border_color5->main::@95] - // main::@95 + // [230] phi from main::vera_display_set_border_color5 to main::@47 [phi:main::vera_display_set_border_color5->main::@47] + // main::@47 // display_action_progress("Your CX16 update is a success!") - // [308] call display_action_progress - // [904] phi from main::@95 to display_action_progress [phi:main::@95->display_action_progress] - // [904] phi display_action_progress::info_text#27 = main::info_text37 [phi:main::@95->display_action_progress#0] -- pbuz1=pbuc1 - lda #display_action_progress] + // [559] phi display_action_progress::info_text#19 = main::info_text22 [phi:main::@47->display_action_progress#0] -- pbuz1=pbuc1 + lda #info_text37 + lda #>info_text22 sta.z display_action_progress.info_text+1 jsr display_action_progress - // main::check_status_smc17 + // main::check_status_smc13 // status_smc == status - // [309] main::check_status_smc17_$0 = status_smc#0 == STATUS_FLASHED -- vbom1=vbum2_eq_vbuc1 + // [232] main::check_status_smc13_$0 = status_smc#0 == STATUS_FLASHED -- vboz1=vbum2_eq_vbuc1 lda status_smc eor #STATUS_FLASHED beq !+ lda #1 !: eor #1 - sta check_status_smc17_main__0 + sta.z check_status_smc13_main__0 // return (unsigned char)(status_smc == status); - // [310] main::check_status_smc17_return#0 = (char)main::check_status_smc17_$0 -- vbum1=vbum2 - sta check_status_smc17_return - // main::@96 + // [233] main::check_status_smc13_return#0 = (char)main::check_status_smc13_$0 -- vbum1=vbuz2 + sta check_status_smc13_return + // main::@48 // if(check_status_smc(STATUS_FLASHED)) - // [311] if(0!=main::check_status_smc17_return#0) goto main::@56 -- 0_neq_vbum1_then_la1 - beq !__b56+ - jmp __b56 - !__b56: - // [312] phi from main::@96 to main::@11 [phi:main::@96->main::@11] - // main::@11 + // [234] if(0!=main::check_status_smc13_return#0) goto main::@18 -- 0_neq_vbum1_then_la1 + beq !__b18+ + jmp __b18 + !__b18: + // [235] phi from main::@48 to main::@9 [phi:main::@48->main::@9] + // main::@9 // display_progress_text(display_debriefing_text_rom, display_debriefing_count_rom) - // [313] call display_progress_text - // [1331] phi from main::@11 to display_progress_text [phi:main::@11->display_progress_text] - // [1331] phi display_progress_text::text#13 = display_debriefing_text_rom [phi:main::@11->display_progress_text#0] -- qbuz1=qbuc1 + // [236] call display_progress_text + // [815] phi from main::@9 to display_progress_text [phi:main::@9->display_progress_text] + // [815] phi display_progress_text::text#11 = display_debriefing_text_rom [phi:main::@9->display_progress_text#0] -- qbuz1=qbuc1 lda #display_debriefing_text_rom sta.z display_progress_text.text+1 - // [1331] phi display_progress_text::lines#12 = display_debriefing_count_rom [phi:main::@11->display_progress_text#1] -- vbum1=vbuc1 + // [815] phi display_progress_text::lines#10 = display_debriefing_count_rom [phi:main::@9->display_progress_text#1] -- vbum1=vbuc1 lda #display_debriefing_count_rom sta display_progress_text.lines jsr display_progress_text - // [314] phi from main::@11 main::@90 main::@94 to main::@4 [phi:main::@11/main::@90/main::@94->main::@4] - // main::@4 - __b4: + // [237] phi from main::@42 main::@46 main::@9 to main::@2 [phi:main::@42/main::@46/main::@9->main::@2] + // main::@2 + __b2: // textcolor(PINK) - // [315] call textcolor + // [238] call textcolor // DE6 | Wait until reset - // [784] phi from main::@4 to textcolor [phi:main::@4->textcolor] - // [784] phi textcolor::color#23 = PINK [phi:main::@4->textcolor#0] -- vbum1=vbuc1 + // [439] phi from main::@2 to textcolor [phi:main::@2->textcolor] + // [439] phi textcolor::color#21 = PINK [phi:main::@2->textcolor#0] -- vbum1=vbuc1 lda #PINK sta textcolor.color jsr textcolor - // [316] phi from main::@4 to main::@236 [phi:main::@4->main::@236] - // main::@236 + // [239] phi from main::@2 to main::@117 [phi:main::@2->main::@117] + // main::@117 // display_progress_line(2, "DON'T DO ANYTHING UNTIL COUNTDOWN FINISHES!") - // [317] call display_progress_line - // [1341] phi from main::@236 to display_progress_line [phi:main::@236->display_progress_line] - // [1341] phi display_progress_line::text#3 = main::text [phi:main::@236->display_progress_line#0] -- pbuz1=pbuc1 + // [240] call display_progress_line + // [825] phi from main::@117 to display_progress_line [phi:main::@117->display_progress_line] + // [825] phi display_progress_line::text#3 = main::text [phi:main::@117->display_progress_line#0] -- pbuz1=pbuc1 lda #text sta.z display_progress_line.text+1 - // [1341] phi display_progress_line::line#3 = 2 [phi:main::@236->display_progress_line#1] -- vbum1=vbuc1 + // [825] phi display_progress_line::line#3 = 2 [phi:main::@117->display_progress_line#1] -- vbum1=vbuc1 lda #2 sta display_progress_line.line jsr display_progress_line - // [318] phi from main::@236 to main::@237 [phi:main::@236->main::@237] - // main::@237 + // [241] phi from main::@117 to main::@118 [phi:main::@117->main::@118] + // main::@118 // textcolor(WHITE) - // [319] call textcolor - // [784] phi from main::@237 to textcolor [phi:main::@237->textcolor] - // [784] phi textcolor::color#23 = WHITE [phi:main::@237->textcolor#0] -- vbum1=vbuc1 + // [242] call textcolor + // [439] phi from main::@118 to textcolor [phi:main::@118->textcolor] + // [439] phi textcolor::color#21 = WHITE [phi:main::@118->textcolor#0] -- vbum1=vbuc1 lda #WHITE sta textcolor.color jsr textcolor - // [320] phi from main::@237 to main::@64 [phi:main::@237->main::@64] - // [320] phi main::w1#2 = $78 [phi:main::@237->main::@64#0] -- vbuz1=vbuc1 + // [243] phi from main::@118 to main::@24 [phi:main::@118->main::@24] + // [243] phi main::w1#2 = $78 [phi:main::@118->main::@24#0] -- vbuz1=vbuc1 lda #$78 sta.z w1 - // main::@64 - __b64: + // main::@24 + __b24: // for (unsigned char w=120; w>0; w--) - // [321] if(main::w1#2>0) goto main::@65 -- vbuz1_gt_0_then_la1 + // [244] if(main::w1#2>0) goto main::@25 -- vbuz1_gt_0_then_la1 lda.z w1 - bne __b65 - // [322] phi from main::@64 to main::@66 [phi:main::@64->main::@66] - // main::@66 + bne __b25 + // [245] phi from main::@24 to main::@26 [phi:main::@24->main::@26] + // main::@26 // system_reset() - // [323] call system_reset - // [1318] phi from main::@66 to system_reset [phi:main::@66->system_reset] + // [246] call system_reset + // [802] phi from main::@26 to system_reset [phi:main::@26->system_reset] jsr system_reset rts - // [324] phi from main::@64 to main::@65 [phi:main::@64->main::@65] - // main::@65 - __b65: + // [247] phi from main::@24 to main::@25 [phi:main::@24->main::@25] + // main::@25 + __b25: // wait_moment(1) - // [325] call wait_moment - // [1310] phi from main::@65 to wait_moment [phi:main::@65->wait_moment] - // [1310] phi wait_moment::w#13 = 1 [phi:main::@65->wait_moment#0] -- vbum1=vbuc1 + // [248] call wait_moment + // [794] phi from main::@25 to wait_moment [phi:main::@25->wait_moment] + // [794] phi wait_moment::w#10 = 1 [phi:main::@25->wait_moment#0] -- vbum1=vbuc1 lda #1 sta wait_moment.w jsr wait_moment - // [326] phi from main::@65 to main::@238 [phi:main::@65->main::@238] - // main::@238 + // [249] phi from main::@25 to main::@119 [phi:main::@25->main::@119] + // main::@119 // sprintf(info_text, "(%u) Your CX16 will reset after countdown ...", w) - // [327] call snprintf_init - // [1205] phi from main::@238 to snprintf_init [phi:main::@238->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:main::@238->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 + // [250] call snprintf_init jsr snprintf_init - // [328] phi from main::@238 to main::@239 [phi:main::@238->main::@239] - // main::@239 + // [251] phi from main::@119 to main::@120 [phi:main::@119->main::@120] + // main::@120 // sprintf(info_text, "(%u) Your CX16 will reset after countdown ...", w) - // [329] call printf_str - // [1210] phi from main::@239 to printf_str [phi:main::@239->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main::@239->printf_str#0] -- pprz1=pprc1 + // [252] call printf_str + // [785] phi from main::@120 to printf_str [phi:main::@120->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:main::@120->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main::s24 [phi:main::@239->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #s24 + lda #>s11 sta.z printf_str.s+1 jsr printf_str - // main::@240 + // main::@121 // sprintf(info_text, "(%u) Your CX16 will reset after countdown ...", w) - // [330] printf_uchar::uvalue#17 = main::w1#2 -- vbum1=vbuz2 + // [253] printf_uchar::uvalue#8 = main::w1#2 -- vbum1=vbuz2 lda.z w1 sta printf_uchar.uvalue - // [331] call printf_uchar - // [1346] phi from main::@240 to printf_uchar [phi:main::@240->printf_uchar] - // [1346] phi printf_uchar::format_zero_padding#18 = 0 [phi:main::@240->printf_uchar#0] -- vbum1=vbuc1 + // [254] call printf_uchar + // [834] phi from main::@121 to printf_uchar [phi:main::@121->printf_uchar] + // [834] phi printf_uchar::format_zero_padding#10 = 0 [phi:main::@121->printf_uchar#0] -- vbum1=vbuc1 lda #0 sta printf_uchar.format_zero_padding - // [1346] phi printf_uchar::format_min_length#18 = 0 [phi:main::@240->printf_uchar#1] -- vbum1=vbuc1 + // [834] phi printf_uchar::format_min_length#10 = 0 [phi:main::@121->printf_uchar#1] -- vbum1=vbuc1 sta printf_uchar.format_min_length - // [1346] phi printf_uchar::putc#18 = &snputc [phi:main::@240->printf_uchar#2] -- pprz1=pprc1 + // [834] phi printf_uchar::putc#10 = &snputc [phi:main::@121->printf_uchar#2] -- pprz1=pprc1 lda #snputc sta.z printf_uchar.putc+1 - // [1346] phi printf_uchar::format_radix#18 = DECIMAL [phi:main::@240->printf_uchar#3] -- vbum1=vbuc1 + // [834] phi printf_uchar::format_radix#10 = DECIMAL [phi:main::@121->printf_uchar#3] -- vbum1=vbuc1 lda #DECIMAL sta printf_uchar.format_radix - // [1346] phi printf_uchar::uvalue#18 = printf_uchar::uvalue#17 [phi:main::@240->printf_uchar#4] -- register_copy + // [834] phi printf_uchar::uvalue#10 = printf_uchar::uvalue#8 [phi:main::@121->printf_uchar#4] -- register_copy jsr printf_uchar - // [332] phi from main::@240 to main::@241 [phi:main::@240->main::@241] - // main::@241 + // [255] phi from main::@121 to main::@122 [phi:main::@121->main::@122] + // main::@122 // sprintf(info_text, "(%u) Your CX16 will reset after countdown ...", w) - // [333] call printf_str - // [1210] phi from main::@241 to printf_str [phi:main::@241->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main::@241->printf_str#0] -- pprz1=pprc1 + // [256] call printf_str + // [785] phi from main::@122 to printf_str [phi:main::@122->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:main::@122->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main::s25 [phi:main::@241->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #s25 + lda #>s12 sta.z printf_str.s+1 jsr printf_str - // main::@242 + // main::@123 // sprintf(info_text, "(%u) Your CX16 will reset after countdown ...", w) - // [334] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 + // [257] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 lda #0 pha - // [335] callexecute snputc -- call_vprc1 + // [258] callexecute snputc -- call_vprc1 jsr snputc // sideeffect stackpullpadding(1) -- _stackpullpadding_1 pla // display_action_text(info_text) - // [337] call display_action_text - // [1357] phi from main::@242 to display_action_text [phi:main::@242->display_action_text] - // [1357] phi display_action_text::info_text#25 = info_text [phi:main::@242->display_action_text#0] -- pbuz1=pbuc1 + // [260] call display_action_text + // [845] phi from main::@123 to display_action_text [phi:main::@123->display_action_text] + // [845] phi display_action_text::info_text#17 = info_text [phi:main::@123->display_action_text#0] -- pbuz1=pbuc1 lda #<@info_text sta.z display_action_text.info_text lda #>@info_text sta.z display_action_text.info_text+1 jsr display_action_text - // main::@243 + // main::@124 // for (unsigned char w=120; w>0; w--) - // [338] main::w1#1 = -- main::w1#2 -- vbuz1=_dec_vbuz1 + // [261] main::w1#1 = -- main::w1#2 -- vbuz1=_dec_vbuz1 dec.z w1 - // [320] phi from main::@243 to main::@64 [phi:main::@243->main::@64] - // [320] phi main::w1#2 = main::w1#1 [phi:main::@243->main::@64#0] -- register_copy - jmp __b64 - // main::@56 - __b56: - // if(smc_bootloader == 1) - // [339] if(smc_bootloader#0!=1) goto main::@57 -- vwum1_neq_vbuc1_then_la1 - lda smc_bootloader+1 - bne __b57 - lda smc_bootloader - cmp #1 - bne __b57 - // [340] phi from main::@56 to main::@62 [phi:main::@56->main::@62] - // main::@62 - // smc_reset() - // [341] call smc_reset - // [1371] phi from main::@62 to smc_reset [phi:main::@62->smc_reset] - jsr smc_reset - // [342] phi from main::@56 main::@62 to main::@57 [phi:main::@56/main::@62->main::@57] - // main::@57 - __b57: + // [243] phi from main::@124 to main::@24 [phi:main::@124->main::@24] + // [243] phi main::w1#2 = main::w1#1 [phi:main::@124->main::@24#0] -- register_copy + jmp __b24 + // [262] phi from main::@48 to main::@18 [phi:main::@48->main::@18] + // main::@18 + __b18: // display_progress_text(display_debriefing_text_smc, display_debriefing_count_smc) - // [343] call display_progress_text - // [1331] phi from main::@57 to display_progress_text [phi:main::@57->display_progress_text] - // [1331] phi display_progress_text::text#13 = display_debriefing_text_smc [phi:main::@57->display_progress_text#0] -- qbuz1=qbuc1 + // [263] call display_progress_text + // [815] phi from main::@18 to display_progress_text [phi:main::@18->display_progress_text] + // [815] phi display_progress_text::text#11 = display_debriefing_text_smc [phi:main::@18->display_progress_text#0] -- qbuz1=qbuc1 lda #display_debriefing_text_smc sta.z display_progress_text.text+1 - // [1331] phi display_progress_text::lines#12 = display_debriefing_count_smc [phi:main::@57->display_progress_text#1] -- vbum1=vbuc1 + // [815] phi display_progress_text::lines#10 = display_debriefing_count_smc [phi:main::@18->display_progress_text#1] -- vbum1=vbuc1 lda #display_debriefing_count_smc sta display_progress_text.lines jsr display_progress_text - // [344] phi from main::@57 to main::@224 [phi:main::@57->main::@224] - // main::@224 + // [264] phi from main::@18 to main::@105 [phi:main::@18->main::@105] + // main::@105 // textcolor(PINK) - // [345] call textcolor - // [784] phi from main::@224 to textcolor [phi:main::@224->textcolor] - // [784] phi textcolor::color#23 = PINK [phi:main::@224->textcolor#0] -- vbum1=vbuc1 + // [265] call textcolor + // [439] phi from main::@105 to textcolor [phi:main::@105->textcolor] + // [439] phi textcolor::color#21 = PINK [phi:main::@105->textcolor#0] -- vbum1=vbuc1 lda #PINK sta textcolor.color jsr textcolor - // [346] phi from main::@224 to main::@225 [phi:main::@224->main::@225] - // main::@225 + // [266] phi from main::@105 to main::@106 [phi:main::@105->main::@106] + // main::@106 // display_progress_line(2, "DON'T DO ANYTHING UNTIL COUNTDOWN FINISHES!") - // [347] call display_progress_line - // [1341] phi from main::@225 to display_progress_line [phi:main::@225->display_progress_line] - // [1341] phi display_progress_line::text#3 = main::text [phi:main::@225->display_progress_line#0] -- pbuz1=pbuc1 + // [267] call display_progress_line + // [825] phi from main::@106 to display_progress_line [phi:main::@106->display_progress_line] + // [825] phi display_progress_line::text#3 = main::text [phi:main::@106->display_progress_line#0] -- pbuz1=pbuc1 lda #text sta.z display_progress_line.text+1 - // [1341] phi display_progress_line::line#3 = 2 [phi:main::@225->display_progress_line#1] -- vbum1=vbuc1 + // [825] phi display_progress_line::line#3 = 2 [phi:main::@106->display_progress_line#1] -- vbum1=vbuc1 lda #2 sta display_progress_line.line jsr display_progress_line - // [348] phi from main::@225 to main::@226 [phi:main::@225->main::@226] - // main::@226 + // [268] phi from main::@106 to main::@107 [phi:main::@106->main::@107] + // main::@107 // textcolor(WHITE) - // [349] call textcolor - // [784] phi from main::@226 to textcolor [phi:main::@226->textcolor] - // [784] phi textcolor::color#23 = WHITE [phi:main::@226->textcolor#0] -- vbum1=vbuc1 + // [269] call textcolor + // [439] phi from main::@107 to textcolor [phi:main::@107->textcolor] + // [439] phi textcolor::color#21 = WHITE [phi:main::@107->textcolor#0] -- vbum1=vbuc1 lda #WHITE sta textcolor.color jsr textcolor - // [350] phi from main::@226 to main::@58 [phi:main::@226->main::@58] - // [350] phi main::w#2 = $78 [phi:main::@226->main::@58#0] -- vbuz1=vbuc1 + // [270] phi from main::@107 to main::@19 [phi:main::@107->main::@19] + // [270] phi main::w#2 = $78 [phi:main::@107->main::@19#0] -- vbuz1=vbuc1 lda #$78 sta.z w - // main::@58 - __b58: + // main::@19 + __b19: // for (unsigned char w=120; w>0; w--) - // [351] if(main::w#2>0) goto main::@59 -- vbuz1_gt_0_then_la1 + // [271] if(main::w#2>0) goto main::@20 -- vbuz1_gt_0_then_la1 lda.z w - bne __b59 - // [352] phi from main::@58 to main::@60 [phi:main::@58->main::@60] - // main::@60 + bne __b20 + // [272] phi from main::@19 to main::@21 [phi:main::@19->main::@21] + // main::@21 // sprintf(info_text, "Please disconnect your CX16 from power source ...") - // [353] call snprintf_init - // [1205] phi from main::@60 to snprintf_init [phi:main::@60->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:main::@60->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 + // [273] call snprintf_init jsr snprintf_init - // [354] phi from main::@60 to main::@233 [phi:main::@60->main::@233] - // main::@233 + // [274] phi from main::@21 to main::@114 [phi:main::@21->main::@114] + // main::@114 // sprintf(info_text, "Please disconnect your CX16 from power source ...") - // [355] call printf_str - // [1210] phi from main::@233 to printf_str [phi:main::@233->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main::@233->printf_str#0] -- pprz1=pprc1 + // [275] call printf_str + // [785] phi from main::@114 to printf_str [phi:main::@114->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:main::@114->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main::s23 [phi:main::@233->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #s23 + lda #>s10 sta.z printf_str.s+1 jsr printf_str - // main::@234 + // main::@115 // sprintf(info_text, "Please disconnect your CX16 from power source ...") - // [356] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 + // [276] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 lda #0 pha - // [357] callexecute snputc -- call_vprc1 + // [277] callexecute snputc -- call_vprc1 jsr snputc // sideeffect stackpullpadding(1) -- _stackpullpadding_1 pla // display_action_text(info_text) - // [359] call display_action_text - // [1357] phi from main::@234 to display_action_text [phi:main::@234->display_action_text] - // [1357] phi display_action_text::info_text#25 = info_text [phi:main::@234->display_action_text#0] -- pbuz1=pbuc1 + // [279] call display_action_text + // [845] phi from main::@115 to display_action_text [phi:main::@115->display_action_text] + // [845] phi display_action_text::info_text#17 = info_text [phi:main::@115->display_action_text#0] -- pbuz1=pbuc1 lda #<@info_text sta.z display_action_text.info_text lda #>@info_text sta.z display_action_text.info_text+1 jsr display_action_text - // [360] phi from main::@234 to main::@235 [phi:main::@234->main::@235] - // main::@235 + // [280] phi from main::@115 to main::@116 [phi:main::@115->main::@116] + // main::@116 // smc_reset() - // [361] call smc_reset + // [281] call smc_reset // DE5 | The components correctly updated, SMC bootloader 2 // When bootloader 1, the CX16 won't shut down automatically and will hang! The user will see the above bootloader 1 action. // When bootloader 2, the CX16 will shut down automatically. The user will never see the bootloader 1 action. - // [1371] phi from main::@235 to smc_reset [phi:main::@235->smc_reset] + // [859] phi from main::@116 to smc_reset [phi:main::@116->smc_reset] jsr smc_reset - // [362] phi from main::@235 main::@61 to main::@61 [phi:main::@235/main::@61->main::@61] - __b10: + // [282] phi from main::@116 main::@22 to main::@22 [phi:main::@116/main::@22->main::@22] + __b5: // This call will reboot the SMC, which will reset the CX16 if bootloader R2. - // main::@61 - jmp __b10 - // [363] phi from main::@58 to main::@59 [phi:main::@58->main::@59] - // main::@59 - __b59: + // main::@22 + jmp __b5 + // [283] phi from main::@19 to main::@20 [phi:main::@19->main::@20] + // main::@20 + __b20: // wait_moment(1) - // [364] call wait_moment - // [1310] phi from main::@59 to wait_moment [phi:main::@59->wait_moment] - // [1310] phi wait_moment::w#13 = 1 [phi:main::@59->wait_moment#0] -- vbum1=vbuc1 + // [284] call wait_moment + // [794] phi from main::@20 to wait_moment [phi:main::@20->wait_moment] + // [794] phi wait_moment::w#10 = 1 [phi:main::@20->wait_moment#0] -- vbum1=vbuc1 lda #1 sta wait_moment.w jsr wait_moment - // [365] phi from main::@59 to main::@227 [phi:main::@59->main::@227] - // main::@227 + // [285] phi from main::@20 to main::@108 [phi:main::@20->main::@108] + // main::@108 // sprintf(info_text, "[%03u] Please read carefully the below ...", w) - // [366] call snprintf_init - // [1205] phi from main::@227 to snprintf_init [phi:main::@227->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:main::@227->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 + // [286] call snprintf_init jsr snprintf_init - // [367] phi from main::@227 to main::@228 [phi:main::@227->main::@228] - // main::@228 + // [287] phi from main::@108 to main::@109 [phi:main::@108->main::@109] + // main::@109 // sprintf(info_text, "[%03u] Please read carefully the below ...", w) - // [368] call printf_str - // [1210] phi from main::@228 to printf_str [phi:main::@228->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main::@228->printf_str#0] -- pprz1=pprc1 + // [288] call printf_str + // [785] phi from main::@109 to printf_str [phi:main::@109->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:main::@109->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s21 [phi:main::@228->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #s21 + lda #>s8 sta.z printf_str.s+1 jsr printf_str - // main::@229 + // main::@110 // sprintf(info_text, "[%03u] Please read carefully the below ...", w) - // [369] printf_uchar::uvalue#16 = main::w#2 -- vbum1=vbuz2 + // [289] printf_uchar::uvalue#7 = main::w#2 -- vbum1=vbuz2 lda.z w sta printf_uchar.uvalue - // [370] call printf_uchar - // [1346] phi from main::@229 to printf_uchar [phi:main::@229->printf_uchar] - // [1346] phi printf_uchar::format_zero_padding#18 = 1 [phi:main::@229->printf_uchar#0] -- vbum1=vbuc1 + // [290] call printf_uchar + // [834] phi from main::@110 to printf_uchar [phi:main::@110->printf_uchar] + // [834] phi printf_uchar::format_zero_padding#10 = 1 [phi:main::@110->printf_uchar#0] -- vbum1=vbuc1 lda #1 sta printf_uchar.format_zero_padding - // [1346] phi printf_uchar::format_min_length#18 = 3 [phi:main::@229->printf_uchar#1] -- vbum1=vbuc1 + // [834] phi printf_uchar::format_min_length#10 = 3 [phi:main::@110->printf_uchar#1] -- vbum1=vbuc1 lda #3 sta printf_uchar.format_min_length - // [1346] phi printf_uchar::putc#18 = &snputc [phi:main::@229->printf_uchar#2] -- pprz1=pprc1 + // [834] phi printf_uchar::putc#10 = &snputc [phi:main::@110->printf_uchar#2] -- pprz1=pprc1 lda #snputc sta.z printf_uchar.putc+1 - // [1346] phi printf_uchar::format_radix#18 = DECIMAL [phi:main::@229->printf_uchar#3] -- vbum1=vbuc1 + // [834] phi printf_uchar::format_radix#10 = DECIMAL [phi:main::@110->printf_uchar#3] -- vbum1=vbuc1 lda #DECIMAL sta printf_uchar.format_radix - // [1346] phi printf_uchar::uvalue#18 = printf_uchar::uvalue#16 [phi:main::@229->printf_uchar#4] -- register_copy + // [834] phi printf_uchar::uvalue#10 = printf_uchar::uvalue#7 [phi:main::@110->printf_uchar#4] -- register_copy jsr printf_uchar - // [371] phi from main::@229 to main::@230 [phi:main::@229->main::@230] - // main::@230 + // [291] phi from main::@110 to main::@111 [phi:main::@110->main::@111] + // main::@111 // sprintf(info_text, "[%03u] Please read carefully the below ...", w) - // [372] call printf_str - // [1210] phi from main::@230 to printf_str [phi:main::@230->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main::@230->printf_str#0] -- pprz1=pprc1 + // [292] call printf_str + // [785] phi from main::@111 to printf_str [phi:main::@111->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:main::@111->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main::s22 [phi:main::@230->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #s22 + lda #>s9 sta.z printf_str.s+1 jsr printf_str - // main::@231 + // main::@112 // sprintf(info_text, "[%03u] Please read carefully the below ...", w) - // [373] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 + // [293] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 lda #0 pha - // [374] callexecute snputc -- call_vprc1 + // [294] callexecute snputc -- call_vprc1 jsr snputc // sideeffect stackpullpadding(1) -- _stackpullpadding_1 pla // display_action_text(info_text) - // [376] call display_action_text - // [1357] phi from main::@231 to display_action_text [phi:main::@231->display_action_text] - // [1357] phi display_action_text::info_text#25 = info_text [phi:main::@231->display_action_text#0] -- pbuz1=pbuc1 + // [296] call display_action_text + // [845] phi from main::@112 to display_action_text [phi:main::@112->display_action_text] + // [845] phi display_action_text::info_text#17 = info_text [phi:main::@112->display_action_text#0] -- pbuz1=pbuc1 lda #<@info_text sta.z display_action_text.info_text lda #>@info_text sta.z display_action_text.info_text+1 jsr display_action_text - // main::@232 + // main::@113 // for (unsigned char w=120; w>0; w--) - // [377] main::w#1 = -- main::w#2 -- vbuz1=_dec_vbuz1 + // [297] main::w#1 = -- main::w#2 -- vbuz1=_dec_vbuz1 dec.z w - // [350] phi from main::@232 to main::@58 [phi:main::@232->main::@58] - // [350] phi main::w#2 = main::w#1 [phi:main::@232->main::@58#0] -- register_copy - jmp __b58 + // [270] phi from main::@113 to main::@19 [phi:main::@113->main::@19] + // [270] phi main::w#2 = main::w#1 [phi:main::@113->main::@19#0] -- register_copy + jmp __b19 // main::vera_display_set_border_color4 vera_display_set_border_color4: // *VERA_CTRL &= ~VERA_DCSEL - // [378] *VERA_CTRL = *VERA_CTRL & ~VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 + // [298] *VERA_CTRL = *VERA_CTRL & ~VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 lda #VERA_DCSEL^$ff and VERA_CTRL sta VERA_CTRL // *VERA_DC_BORDER = color - // [379] *VERA_DC_BORDER = YELLOW -- _deref_pbuc1=vbuc2 + // [299] *VERA_DC_BORDER = YELLOW -- _deref_pbuc1=vbuc2 lda #YELLOW sta VERA_DC_BORDER - // [380] phi from main::vera_display_set_border_color4 to main::@94 [phi:main::vera_display_set_border_color4->main::@94] - // main::@94 + // [300] phi from main::vera_display_set_border_color4 to main::@46 [phi:main::vera_display_set_border_color4->main::@46] + // main::@46 // display_action_progress("Update issues, your CX16 is not updated!") - // [381] call display_action_progress - // [904] phi from main::@94 to display_action_progress [phi:main::@94->display_action_progress] - // [904] phi display_action_progress::info_text#27 = main::info_text36 [phi:main::@94->display_action_progress#0] -- pbuz1=pbuc1 - lda #display_action_progress] + // [559] phi display_action_progress::info_text#19 = main::info_text21 [phi:main::@46->display_action_progress#0] -- pbuz1=pbuc1 + lda #info_text36 + lda #>info_text21 sta.z display_action_progress.info_text+1 jsr display_action_progress - jmp __b4 + jmp __b2 // main::vera_display_set_border_color3 vera_display_set_border_color3: // *VERA_CTRL &= ~VERA_DCSEL - // [382] *VERA_CTRL = *VERA_CTRL & ~VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 + // [302] *VERA_CTRL = *VERA_CTRL & ~VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 lda #VERA_DCSEL^$ff and VERA_CTRL sta VERA_CTRL // *VERA_DC_BORDER = color - // [383] *VERA_DC_BORDER = RED -- _deref_pbuc1=vbuc2 + // [303] *VERA_DC_BORDER = RED -- _deref_pbuc1=vbuc2 lda #RED sta VERA_DC_BORDER - // [384] phi from main::vera_display_set_border_color3 to main::@92 [phi:main::vera_display_set_border_color3->main::@92] - // main::@92 + // [304] phi from main::vera_display_set_border_color3 to main::@44 [phi:main::vera_display_set_border_color3->main::@44] + // main::@44 // display_action_progress("Update Failure! Your CX16 may no longer boot!") - // [385] call display_action_progress - // [904] phi from main::@92 to display_action_progress [phi:main::@92->display_action_progress] - // [904] phi display_action_progress::info_text#27 = main::info_text34 [phi:main::@92->display_action_progress#0] -- pbuz1=pbuc1 - lda #display_action_progress] + // [559] phi display_action_progress::info_text#19 = main::info_text19 [phi:main::@44->display_action_progress#0] -- pbuz1=pbuc1 + lda #info_text34 + lda #>info_text19 sta.z display_action_progress.info_text+1 jsr display_action_progress - // [386] phi from main::@92 to main::@222 [phi:main::@92->main::@222] - // main::@222 + // [306] phi from main::@44 to main::@103 [phi:main::@44->main::@103] + // main::@103 // display_action_text("Take a photo of this screen, shut down power and retry!") - // [387] call display_action_text - // [1357] phi from main::@222 to display_action_text [phi:main::@222->display_action_text] - // [1357] phi display_action_text::info_text#25 = main::info_text35 [phi:main::@222->display_action_text#0] -- pbuz1=pbuc1 - lda #display_action_text] + // [845] phi display_action_text::info_text#17 = main::info_text20 [phi:main::@103->display_action_text#0] -- pbuz1=pbuc1 + lda #info_text35 + lda #>info_text20 sta.z display_action_text.info_text+1 jsr display_action_text - // [388] phi from main::@222 main::@63 to main::@63 [phi:main::@222/main::@63->main::@63] - // main::@63 - __b63: - jmp __b63 - // main::@264 - __b264: + // [308] phi from main::@103 main::@23 to main::@23 [phi:main::@103/main::@23->main::@23] + // main::@23 + __b23: + jmp __b23 + // main::@139 + __b139: // if((check_status_smc(STATUS_SKIP) || check_status_smc(STATUS_NONE)) && // (check_status_vera(STATUS_SKIP) || check_status_vera(STATUS_NONE)) && // (check_status_roms_less(STATUS_SKIP)) ) - // [389] if(0!=main::check_status_vera6_return#0) goto main::@263 -- 0_neq_vbum1_then_la1 + // [309] if(0!=main::check_status_vera6_return#0) goto main::@138 -- 0_neq_vbum1_then_la1 lda check_status_vera6_return - bne __b263 - // main::@271 - // [390] if(0==main::check_status_vera7_return#0) goto main::check_status_smc15 -- 0_eq_vbum1_then_la1 + bne __b138 + // main::@145 + // [310] if(0==main::check_status_vera7_return#0) goto main::check_status_smc11 -- 0_eq_vbum1_then_la1 lda check_status_vera7_return - bne !check_status_smc15+ - jmp check_status_smc15 - !check_status_smc15: - // main::@263 - __b263: - // [391] if(0!=main::$84) goto main::vera_display_set_border_color2 -- 0_neq_vbum1_then_la1 - lda main__84 + bne !check_status_smc11+ + jmp check_status_smc11 + !check_status_smc11: + // main::@138 + __b138: + // [311] if(0!=main::$69) goto main::vera_display_set_border_color2 -- 0_neq_vbuz1_then_la1 + lda.z main__69 bne vera_display_set_border_color2 - jmp check_status_smc15 + jmp check_status_smc11 // main::vera_display_set_border_color2 vera_display_set_border_color2: // *VERA_CTRL &= ~VERA_DCSEL - // [392] *VERA_CTRL = *VERA_CTRL & ~VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 + // [312] *VERA_CTRL = *VERA_CTRL & ~VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 lda #VERA_DCSEL^$ff and VERA_CTRL sta VERA_CTRL // *VERA_DC_BORDER = color - // [393] *VERA_DC_BORDER = BLACK -- _deref_pbuc1=vbuc2 + // [313] *VERA_DC_BORDER = BLACK -- _deref_pbuc1=vbuc2 lda #BLACK sta VERA_DC_BORDER - // [394] phi from main::vera_display_set_border_color2 to main::@90 [phi:main::vera_display_set_border_color2->main::@90] - // main::@90 + // [314] phi from main::vera_display_set_border_color2 to main::@42 [phi:main::vera_display_set_border_color2->main::@42] + // main::@42 // display_action_progress("No CX16 component has been updated with new firmware!") - // [395] call display_action_progress - // [904] phi from main::@90 to display_action_progress [phi:main::@90->display_action_progress] - // [904] phi display_action_progress::info_text#27 = main::info_text33 [phi:main::@90->display_action_progress#0] -- pbuz1=pbuc1 - lda #display_action_progress] + // [559] phi display_action_progress::info_text#19 = main::info_text18 [phi:main::@42->display_action_progress#0] -- pbuz1=pbuc1 + lda #info_text33 + lda #>info_text18 sta.z display_action_progress.info_text+1 jsr display_action_progress - jmp __b4 - // main::@255 - __b255: + jmp __b2 + // main::@133 + __b133: // if(!check_status_smc(STATUS_ISSUE) && !check_status_vera(STATUS_ISSUE) && !check_status_roms(STATUS_ISSUE) && // !check_status_smc(STATUS_ERROR) && !check_status_vera(STATUS_ERROR) && !check_status_roms(STATUS_ERROR)) - // [396] if(0!=main::$62) goto main::check_status_vera3 -- 0_neq_vbum1_then_la1 - lda main__62 + // [316] if(0!=main::$47) goto main::check_status_vera3 -- 0_neq_vbuz1_then_la1 + lda.z main__47 beq !check_status_vera3+ jmp check_status_vera3 !check_status_vera3: - // main::@254 - // [397] if(0==main::check_status_smc8_return#0) goto main::@253 -- 0_eq_vbum1_then_la1 - lda check_status_smc8_return - beq __b253 + // main::@132 + // [317] if(0==main::check_status_smc7_return#0) goto main::@131 -- 0_eq_vbum1_then_la1 + lda check_status_smc7_return + beq __b131 jmp check_status_vera3 - // main::@253 - __b253: - // [398] if(0!=main::check_status_vera2_return#0) goto main::check_status_vera3 -- 0_neq_vbum1_then_la1 + // main::@131 + __b131: + // [318] if(0!=main::check_status_vera2_return#0) goto main::check_status_vera3 -- 0_neq_vbum1_then_la1 lda check_status_vera2_return beq !check_status_vera3+ jmp check_status_vera3 !check_status_vera3: - // main::@252 - // [399] if(0==main::$71) goto main::check_status_vera4 -- 0_eq_vbum1_then_la1 - lda main__71 + // main::@130 + // [319] if(0==main::$56) goto main::check_status_vera4 -- 0_eq_vbuz1_then_la1 + lda.z main__56 beq check_status_vera4 jmp check_status_vera3 // main::check_status_vera4 check_status_vera4: // status_vera == status - // [400] main::check_status_vera4_$0 = status_vera#127 == STATUS_FLASH -- vbom1=vbum2_eq_vbuc1 + // [320] main::check_status_vera4_$0 = status_vera#127 == STATUS_FLASH -- vboz1=vbum2_eq_vbuc1 lda status_vera eor #STATUS_FLASH beq !+ lda #1 !: eor #1 - sta check_status_vera4_main__0 + sta.z check_status_vera4_main__0 // return (unsigned char)(status_vera == status); - // [401] main::check_status_vera4_return#0 = (char)main::check_status_vera4_$0 -- vbum1=vbum2 + // [321] main::check_status_vera4_return#0 = (char)main::check_status_vera4_$0 -- vbum1=vbuz2 sta check_status_vera4_return - // main::check_status_smc9 + // main::check_status_smc8 // status_smc == status - // [402] main::check_status_smc9_$0 = status_smc#0 == STATUS_FLASH -- vbom1=vbum2_eq_vbuc1 + // [322] main::check_status_smc8_$0 = status_smc#0 == STATUS_FLASH -- vboz1=vbum2_eq_vbuc1 lda status_smc eor #STATUS_FLASH beq !+ lda #1 !: eor #1 - sta check_status_smc9_main__0 + sta.z check_status_smc8_main__0 // return (unsigned char)(status_smc == status); - // [403] main::check_status_smc9_return#0 = (char)main::check_status_smc9_$0 -- vbum1=vbum2 - sta check_status_smc9_return - // [404] phi from main::check_status_smc9 to main::check_status_cx16_rom5 [phi:main::check_status_smc9->main::check_status_cx16_rom5] + // [323] main::check_status_smc8_return#0 = (char)main::check_status_smc8_$0 -- vbum1=vbuz2 + sta check_status_smc8_return + // [324] phi from main::check_status_smc8 to main::check_status_cx16_rom5 [phi:main::check_status_smc8->main::check_status_cx16_rom5] // main::check_status_cx16_rom5 // main::check_status_cx16_rom5_check_status_rom1 // status_rom[rom_chip] == status - // [405] main::check_status_cx16_rom5_check_status_rom1_$0 = *status_rom == STATUS_FLASH -- vbom1=_deref_pbuc1_eq_vbuc2 + // [325] main::check_status_cx16_rom5_check_status_rom1_$0 = *status_rom == STATUS_FLASH -- vboz1=_deref_pbuc1_eq_vbuc2 lda status_rom eor #STATUS_FLASH beq !+ lda #1 !: eor #1 - sta check_status_cx16_rom5_check_status_rom1_main__0 + sta.z check_status_cx16_rom5_check_status_rom1_main__0 // return (unsigned char)(status_rom[rom_chip] == status); - // [406] main::check_status_cx16_rom5_check_status_rom1_return#0 = (char)main::check_status_cx16_rom5_check_status_rom1_$0 -- vbum1=vbum2 + // [326] main::check_status_cx16_rom5_check_status_rom1_return#0 = (char)main::check_status_cx16_rom5_check_status_rom1_$0 -- vbum1=vbuz2 sta check_status_cx16_rom5_check_status_rom1_return - // [407] phi from main::check_status_cx16_rom5_check_status_rom1 to main::@81 [phi:main::check_status_cx16_rom5_check_status_rom1->main::@81] - // main::@81 + // [327] phi from main::check_status_cx16_rom5_check_status_rom1 to main::@37 [phi:main::check_status_cx16_rom5_check_status_rom1->main::@37] + // main::@37 // check_status_card_roms(STATUS_FLASH) - // [408] call check_status_card_roms - // [1380] phi from main::@81 to check_status_card_roms [phi:main::@81->check_status_card_roms] + // [328] call check_status_card_roms + // [868] phi from main::@37 to check_status_card_roms [phi:main::@37->check_status_card_roms] jsr check_status_card_roms // check_status_card_roms(STATUS_FLASH) - // [409] check_status_card_roms::return#3 = check_status_card_roms::return#2 - // main::@177 - // [410] main::$186 = check_status_card_roms::return#3 -- vbum1=vbum2 + // [329] check_status_card_roms::return#3 = check_status_card_roms::return#2 + // main::@83 + // [330] main::$111 = check_status_card_roms::return#3 -- vbuz1=vbum2 lda check_status_card_roms.return - sta main__186 + sta.z main__111 // if(check_status_vera(STATUS_FLASH) || check_status_smc(STATUS_FLASH) || check_status_cx16_rom(STATUS_FLASH) || check_status_card_roms(STATUS_FLASH)) - // [411] if(0!=main::check_status_vera4_return#0) goto main::@9 -- 0_neq_vbum1_then_la1 + // [331] if(0!=main::check_status_vera4_return#0) goto main::@7 -- 0_neq_vbum1_then_la1 lda check_status_vera4_return - beq !__b9+ - jmp __b9 - !__b9: - // main::@259 - // [412] if(0!=main::check_status_smc9_return#0) goto main::@9 -- 0_neq_vbum1_then_la1 - lda check_status_smc9_return - beq !__b9+ - jmp __b9 - !__b9: - // main::@258 - // [413] if(0!=main::check_status_cx16_rom5_check_status_rom1_return#0) goto main::@9 -- 0_neq_vbum1_then_la1 + bne __b7 + // main::@137 + // [332] if(0!=main::check_status_smc8_return#0) goto main::@7 -- 0_neq_vbum1_then_la1 + lda check_status_smc8_return + bne __b7 + // main::@136 + // [333] if(0!=main::check_status_cx16_rom5_check_status_rom1_return#0) goto main::@7 -- 0_neq_vbum1_then_la1 lda check_status_cx16_rom5_check_status_rom1_return - beq !__b9+ - jmp __b9 - !__b9: - // main::@257 - // [414] if(0!=main::$186) goto main::@9 -- 0_neq_vbum1_then_la1 - lda main__186 - beq !__b9+ - jmp __b9 - !__b9: + bne __b7 + // main::@135 + // [334] if(0!=main::$111) goto main::@7 -- 0_neq_vbuz1_then_la1 + lda.z main__111 + bne __b7 // main::bank_set_bram1 bank_set_bram1: // BRAM = bank - // [415] BRAM = main::bank_set_bram1_bank#0 -- vbuz1=vbuc1 + // [335] BRAM = main::bank_set_bram1_bank#0 -- vbuz1=vbuc1 lda #bank_set_bram1_bank sta.z BRAM - // main::SEI4 + // main::SEI2 // asm // asm { sei } sei - // main::bank_set_brom7 + // main::bank_set_brom3 // BROM = bank - // [417] BROM = main::bank_set_brom7_bank#0 -- vbuz1=vbuc1 - lda #bank_set_brom7_bank + // [337] BROM = main::bank_set_brom3_bank#0 -- vbuz1=vbuc1 + lda #bank_set_brom3_bank sta.z BROM - // main::CLI5 + // main::CLI2 // asm // asm { cli } cli // main::check_status_vera5 // status_vera == status - // [419] main::check_status_vera5_$0 = status_vera#127 == STATUS_FLASH -- vbom1=vbum2_eq_vbuc1 + // [339] main::check_status_vera5_$0 = status_vera#127 == STATUS_FLASH -- vboz1=vbum2_eq_vbuc1 lda status_vera eor #STATUS_FLASH beq !+ lda #1 !: eor #1 - sta check_status_vera5_main__0 + sta.z check_status_vera5_main__0 // return (unsigned char)(status_vera == status); - // [420] main::check_status_vera5_return#0 = (char)main::check_status_vera5_$0 -- vbum1=vbum2 + // [340] main::check_status_vera5_return#0 = (char)main::check_status_vera5_$0 -- vbum1=vbuz2 sta check_status_vera5_return - // main::@82 + // main::@38 // if(check_status_vera(STATUS_FLASH)) - // [421] if(0==main::check_status_vera5_return#0) goto main::SEI5 -- 0_eq_vbum1_then_la1 - beq SEI5 - // [422] phi from main::@82 to main::@51 [phi:main::@82->main::@51] - // main::@51 + // [341] if(0==main::check_status_vera5_return#0) goto main::SEI3 -- 0_eq_vbum1_then_la1 + beq SEI3 + // [342] phi from main::@38 to main::@17 [phi:main::@38->main::@17] + // main::@17 // display_progress_text(display_jp1_spi_vera_text, display_jp1_spi_vera_count) - // [423] call display_progress_text - // [1331] phi from main::@51 to display_progress_text [phi:main::@51->display_progress_text] - // [1331] phi display_progress_text::text#13 = display_jp1_spi_vera_text [phi:main::@51->display_progress_text#0] -- qbuz1=qbuc1 + // [343] call display_progress_text + // [815] phi from main::@17 to display_progress_text [phi:main::@17->display_progress_text] + // [815] phi display_progress_text::text#11 = display_jp1_spi_vera_text [phi:main::@17->display_progress_text#0] -- qbuz1=qbuc1 lda #display_jp1_spi_vera_text sta.z display_progress_text.text+1 - // [1331] phi display_progress_text::lines#12 = display_jp1_spi_vera_count [phi:main::@51->display_progress_text#1] -- vbum1=vbuc1 + // [815] phi display_progress_text::lines#10 = display_jp1_spi_vera_count [phi:main::@17->display_progress_text#1] -- vbum1=vbuc1 lda #display_jp1_spi_vera_count sta display_progress_text.lines jsr display_progress_text - // [424] phi from main::@51 to main::@183 [phi:main::@51->main::@183] - // main::@183 + // [344] phi from main::@17 to main::@89 [phi:main::@17->main::@89] + // main::@89 // util_wait_space() - // [425] call util_wait_space - // [1389] phi from main::@183 to util_wait_space [phi:main::@183->util_wait_space] + // [345] call util_wait_space + // [877] phi from main::@89 to util_wait_space [phi:main::@89->util_wait_space] jsr util_wait_space - // [426] phi from main::@183 to main::@184 [phi:main::@183->main::@184] - // main::@184 + // [346] phi from main::@89 to main::@90 [phi:main::@89->main::@90] + // main::@90 // main_vera_flash() - // [427] call main_vera_flash - // [1392] phi from main::@184 to main_vera_flash [phi:main::@184->main_vera_flash] + // [347] call main_vera_flash + // [880] phi from main::@90 to main_vera_flash [phi:main::@90->main_vera_flash] jsr main_vera_flash - // [428] phi from main::@184 main::@82 to main::SEI5 [phi:main::@184/main::@82->main::SEI5] - // [428] phi __stdio_filecount#113 = __stdio_filecount#36 [phi:main::@184/main::@82->main::SEI5#0] -- register_copy - // [428] phi __errno#117 = __errno#123 [phi:main::@184/main::@82->main::SEI5#1] -- register_copy - // main::SEI5 - SEI5: + // main::SEI3 + SEI3: // asm // asm { sei } sei - // main::bank_set_brom8 + // main::bank_set_brom4 // BROM = bank - // [430] BROM = main::bank_set_brom8_bank#0 -- vbuz1=vbuc1 - lda #bank_set_brom8_bank + // [349] BROM = main::bank_set_brom4_bank#0 -- vbuz1=vbuc1 + lda #bank_set_brom4_bank sta.z BROM - // [431] phi from main::bank_set_brom8 to main::@83 [phi:main::bank_set_brom8->main::@83] - // main::@83 + // [350] phi from main::bank_set_brom4 to main::@39 [phi:main::bank_set_brom4->main::@39] + // main::@39 // display_progress_clear() - // [432] call display_progress_clear - // [918] phi from main::@83 to display_progress_clear [phi:main::@83->display_progress_clear] + // [351] call display_progress_clear + // [573] phi from main::@39 to display_progress_clear [phi:main::@39->display_progress_clear] jsr display_progress_clear - // main::check_status_smc10 - // status_smc == status - // [433] main::check_status_smc10_$0 = status_smc#0 == STATUS_FLASH -- vbom1=vbum2_eq_vbuc1 - lda status_smc - eor #STATUS_FLASH - beq !+ - lda #1 - !: - eor #1 - sta check_status_smc10_main__0 - // return (unsigned char)(status_smc == status); - // [434] main::check_status_smc10_return#0 = (char)main::check_status_smc10_$0 -- vbum1=vbum2 - sta check_status_smc10_return - // [435] phi from main::check_status_smc10 to main::check_status_cx16_rom6 [phi:main::check_status_smc10->main::check_status_cx16_rom6] - // main::check_status_cx16_rom6 - // main::check_status_cx16_rom6_check_status_rom1 - // status_rom[rom_chip] == status - // [436] main::check_status_cx16_rom6_check_status_rom1_$0 = *status_rom == STATUS_FLASH -- vbom1=_deref_pbuc1_eq_vbuc2 - lda status_rom - eor #STATUS_FLASH - beq !+ - lda #1 - !: - eor #1 - sta check_status_cx16_rom6_check_status_rom1_main__0 - // return (unsigned char)(status_rom[rom_chip] == status); - // [437] main::check_status_cx16_rom6_check_status_rom1_return#0 = (char)main::check_status_cx16_rom6_check_status_rom1_$0 -- vbum1=vbum2 - sta check_status_cx16_rom6_check_status_rom1_return - // main::@84 - // if (check_status_smc(STATUS_FLASH) && check_status_cx16_rom(STATUS_FLASH)) - // [438] if(0==main::check_status_smc10_return#0) goto main::SEI6 -- 0_eq_vbum1_then_la1 - lda check_status_smc10_return - beq SEI6 - // main::@260 - // [439] if(0!=main::check_status_cx16_rom6_check_status_rom1_return#0) goto main::@52 -- 0_neq_vbum1_then_la1 - lda check_status_cx16_rom6_check_status_rom1_return - beq !__b52+ - jmp __b52 - !__b52: - // [440] phi from main::@260 to main::SEI6 [phi:main::@260->main::SEI6] - // [440] phi from main::@187 main::@40 main::@41 main::@55 main::@84 to main::SEI6 [phi:main::@187/main::@40/main::@41/main::@55/main::@84->main::SEI6] - // [440] phi __stdio_filecount#582 = __stdio_filecount#39 [phi:main::@187/main::@40/main::@41/main::@55/main::@84->main::SEI6#0] -- register_copy - // [440] phi __errno#589 = __errno#123 [phi:main::@187/main::@40/main::@41/main::@55/main::@84->main::SEI6#1] -- register_copy - // main::SEI6 - SEI6: + // main::SEI4 // asm // asm { sei } sei - // [442] phi from main::SEI6 to main::@42 [phi:main::SEI6->main::@42] - // [442] phi __stdio_filecount#114 = __stdio_filecount#582 [phi:main::SEI6->main::@42#0] -- register_copy - // [442] phi __errno#118 = __errno#589 [phi:main::SEI6->main::@42#1] -- register_copy - // [442] phi main::rom_chip4#10 = 7 [phi:main::SEI6->main::@42#2] -- vbuz1=vbuc1 - lda #7 - sta.z rom_chip4 - // Flash the ROM chips. - // We loop first all the ROM chips and read the file contents. - // Then we verify the file contents and flash the ROM only for the differences. - // If the file contents are the same as the ROM contents, then no flashing is required. - // IMPORTANT! We start to flash the ROMs on the extension card. - // The last ROM flashed is the CX16 ROM on the CX16 board! - // main::@42 - __b42: - // for(unsigned char rom_chip = 7; rom_chip != 255; rom_chip--) - // [443] if(main::rom_chip4#10!=$ff) goto main::check_status_rom1 -- vbuz1_neq_vbuc1_then_la1 - lda #$ff - cmp.z rom_chip4 - bne check_status_rom1 - // [444] phi from main::@42 to main::@43 [phi:main::@42->main::@43] - // main::@43 - // display_progress_clear() - // [445] call display_progress_clear - // [918] phi from main::@43 to display_progress_clear [phi:main::@43->display_progress_clear] - jsr display_progress_clear jmp check_status_vera3 - // main::check_status_rom1 - check_status_rom1: - // status_rom[rom_chip] == status - // [446] main::check_status_rom1_$0 = status_rom[main::rom_chip4#10] == STATUS_FLASH -- vboz1=pbuc1_derefidx_vbuz2_eq_vbuc2 - lda #STATUS_FLASH - ldy.z rom_chip4 - eor status_rom,y - beq !+ - lda #1 - !: - eor #1 - sta.z check_status_rom1_main__0 - // return (unsigned char)(status_rom[rom_chip] == status); - // [447] main::check_status_rom1_return#0 = (char)main::check_status_rom1_$0 -- vbum1=vbuz2 - sta check_status_rom1_return + // [353] phi from main::@135 main::@136 main::@137 main::@83 to main::@7 [phi:main::@135/main::@136/main::@137/main::@83->main::@7] + // main::@7 + __b7: + // display_action_progress("Chipsets have been detected and update files validated!") + // [354] call display_action_progress + // [559] phi from main::@7 to display_action_progress [phi:main::@7->display_action_progress] + // [559] phi display_action_progress::info_text#19 = main::info_text12 [phi:main::@7->display_action_progress#0] -- pbuz1=pbuc1 + lda #info_text12 + sta.z display_action_progress.info_text+1 + jsr display_action_progress + // [355] phi from main::@7 to main::@84 [phi:main::@7->main::@84] + // main::@84 + // unsigned char ch = util_wait_key("Continue with update of highlighted chipsets? [Y/N]", "nyNY") + // [356] call util_wait_key + // [1034] phi from main::@84 to util_wait_key [phi:main::@84->util_wait_key] + // [1034] phi util_wait_key::filter#13 = main::filter1 [phi:main::@84->util_wait_key#0] -- pbuz1=pbuc1 + lda #filter1 + sta.z util_wait_key.filter+1 + // [1034] phi util_wait_key::info_text#3 = main::info_text13 [phi:main::@84->util_wait_key#1] -- pbuz1=pbuc1 + lda #info_text13 + sta.z util_wait_key.info_text+1 + jsr util_wait_key + // unsigned char ch = util_wait_key("Continue with update of highlighted chipsets? [Y/N]", "nyNY") + // [357] util_wait_key::return#4 = util_wait_key::ch#4 -- vbum1=vwum2 + lda util_wait_key.ch + sta util_wait_key.return_1 // main::@85 - // if(check_status_rom(rom_chip, STATUS_FLASH)) - // [448] if(0==main::check_status_rom1_return#0) goto main::@44 -- 0_eq_vbum1_then_la1 - beq __b44 - // main::check_status_smc11 - // status_smc == status - // [449] main::check_status_smc11_$0 = status_smc#0 == STATUS_FLASHED -- vboz1=vbum2_eq_vbuc1 - lda status_smc - eor #STATUS_FLASHED - beq !+ - lda #1 - !: - eor #1 - sta.z check_status_smc11_main__0 - // return (unsigned char)(status_smc == status); - // [450] main::check_status_smc11_return#0 = (char)main::check_status_smc11_$0 -- vbum1=vbuz2 - sta check_status_smc11_return - // main::check_status_smc12 - // status_smc == status - // [451] main::check_status_smc12_$0 = status_smc#0 == STATUS_SKIP -- vboz1=vbum2_eq_vbuc1 - lda status_smc - eor #STATUS_SKIP - beq !+ - lda #1 - !: - eor #1 - sta.z check_status_smc12_main__0 - // return (unsigned char)(status_smc == status); - // [452] main::check_status_smc12_return#0 = (char)main::check_status_smc12_$0 -- vbum1=vbuz2 - sta check_status_smc12_return + // [358] main::ch1#0 = util_wait_key::return#4 -- vbuz1=vbum2 + sta.z ch1 + // strchr("nN", ch) + // [359] strchr::c#1 = main::ch1#0 -- vbum1=vbuz2 + sta strchr.c + // [360] call strchr + // [1058] phi from main::@85 to strchr [phi:main::@85->strchr] + // [1058] phi strchr::c#4 = strchr::c#1 [phi:main::@85->strchr#0] -- register_copy + // [1058] phi strchr::str#2 = (const void *)main::$208 [phi:main::@85->strchr#1] -- pvoz1=pvoc1 + lda #main__208 + sta.z strchr.str+1 + jsr strchr + // strchr("nN", ch) + // [361] strchr::return#4 = strchr::return#2 // main::@86 - // if((rom_chip == 0 && (check_status_smc(STATUS_FLASHED) || check_status_smc(STATUS_SKIP))) || (rom_chip != 0)) - // [453] if(main::rom_chip4#10==0) goto main::@262 -- vbuz1_eq_0_then_la1 - // IMPORTANT! We only flash the CX16 ROM chip if the SMC got flashed succesfully! - lda.z rom_chip4 - bne !__b262+ - jmp __b262 - !__b262: - // main::@261 - __b261: - // [454] if(main::rom_chip4#10!=0) goto main::bank_set_brom9 -- vbuz1_neq_0_then_la1 - lda.z rom_chip4 - bne bank_set_brom9 - // main::@50 - // display_info_rom(rom_chip, STATUS_ISSUE, "SMC Update failed!") - // [455] display_info_rom::rom_chip#11 = main::rom_chip4#10 -- vbum1=vbuz2 + // [362] main::$116 = strchr::return#4 + // if(strchr("nN", ch)) + // [363] if((void *)0==main::$116) goto main::bank_set_bram1 -- pvoc1_eq_pvoz1_then_la1 + lda.z main__116 + cmp #<0 + bne !+ + lda.z main__116+1 + cmp #>0 + beq bank_set_bram1 + !: + // [364] phi from main::@86 to main::@8 [phi:main::@86->main::@8] + // main::@8 + // display_info_smc(STATUS_SKIP, "Cancelled") + // [365] call display_info_smc + // We cancel all updates, the updates are skipped. + // [617] phi from main::@8 to display_info_smc [phi:main::@8->display_info_smc] + // [617] phi display_info_smc::info_text#10 = main::info_text14 [phi:main::@8->display_info_smc#0] -- pbuz1=pbuc1 + lda #info_text14 + sta.z display_info_smc.info_text+1 + // [617] phi display_info_smc::info_status#10 = STATUS_SKIP [phi:main::@8->display_info_smc#1] -- vbum1=vbuc1 + lda #STATUS_SKIP + sta display_info_smc.info_status + jsr display_info_smc + // main::@87 + // [366] spi_manufacturer#407 = spi_read::return#0 -- vbum1=vbum2 + lda spi_read.return + sta spi_manufacturer + // [367] spi_memory_type#408 = spi_read::return#1 -- vbum1=vbum2 + lda spi_read.return_1 + sta spi_memory_type + // [368] spi_memory_capacity#409 = spi_read::return#2 -- vbum1=vbum2 + lda spi_read.return_2 + sta spi_memory_capacity + // display_info_vera(STATUS_SKIP, "Cancelled") + // [369] call display_info_vera + // [653] phi from main::@87 to display_info_vera [phi:main::@87->display_info_vera] + // [653] phi display_info_vera::info_text#19 = main::info_text14 [phi:main::@87->display_info_vera#0] -- pbuz1=pbuc1 + lda #info_text14 + sta.z display_info_vera.info_text+1 + // [653] phi spi_memory_capacity#110 = spi_memory_capacity#409 [phi:main::@87->display_info_vera#1] -- register_copy + // [653] phi spi_memory_type#111 = spi_memory_type#408 [phi:main::@87->display_info_vera#2] -- register_copy + // [653] phi spi_manufacturer#100 = spi_manufacturer#407 [phi:main::@87->display_info_vera#3] -- register_copy + // [653] phi display_info_vera::info_status#19 = STATUS_SKIP [phi:main::@87->display_info_vera#4] -- vbum1=vbuc1 + lda #STATUS_SKIP + sta display_info_vera.info_status + jsr display_info_vera + // [370] phi from main::@87 to main::@14 [phi:main::@87->main::@14] + // [370] phi main::rom_chip1#2 = 0 [phi:main::@87->main::@14#0] -- vbuz1=vbuc1 + lda #0 + sta.z rom_chip1 + // main::@14 + __b14: + // for(unsigned char rom_chip = 0; rom_chip < 8; rom_chip++) + // [371] if(main::rom_chip1#2<8) goto main::@15 -- vbuz1_lt_vbuc1_then_la1 + lda.z rom_chip1 + cmp #8 + bcc __b15 + // [372] phi from main::@14 to main::@16 [phi:main::@14->main::@16] + // main::@16 + // display_action_text("You have selected not to cancel the update ... ") + // [373] call display_action_text + // [845] phi from main::@16 to display_action_text [phi:main::@16->display_action_text] + // [845] phi display_action_text::info_text#17 = main::info_text17 [phi:main::@16->display_action_text#0] -- pbuz1=pbuc1 + lda #info_text17 + sta.z display_action_text.info_text+1 + jsr display_action_text + jmp bank_set_bram1 + // main::@15 + __b15: + // display_info_rom(rom_chip, STATUS_SKIP, "Cancelled") + // [374] display_info_rom::rom_chip#3 = main::rom_chip1#2 -- vbum1=vbuz2 + lda.z rom_chip1 sta display_info_rom.rom_chip - // [456] call display_info_rom - // [1546] phi from main::@50 to display_info_rom [phi:main::@50->display_info_rom] - // [1546] phi display_info_rom::info_text#17 = main::info_text29 [phi:main::@50->display_info_rom#0] -- pbuz1=pbuc1 - lda #display_info_rom] + // [1067] phi display_info_rom::info_text#10 = main::info_text14 [phi:main::@15->display_info_rom#0] -- pbuz1=pbuc1 + lda #info_text29 + lda #>info_text14 sta.z display_info_rom.info_text+1 - // [1546] phi display_info_rom::rom_chip#17 = display_info_rom::rom_chip#11 [phi:main::@50->display_info_rom#1] -- register_copy - // [1546] phi display_info_rom::info_status#17 = STATUS_ISSUE [phi:main::@50->display_info_rom#2] -- vbum1=vbuc1 - lda #STATUS_ISSUE + // [1067] phi display_info_rom::rom_chip#10 = display_info_rom::rom_chip#3 [phi:main::@15->display_info_rom#1] -- register_copy + // [1067] phi display_info_rom::info_status#10 = STATUS_SKIP [phi:main::@15->display_info_rom#2] -- vbum1=vbuc1 + lda #STATUS_SKIP sta display_info_rom.info_status jsr display_info_rom - // [457] phi from main::@198 main::@209 main::@45 main::@49 main::@50 main::@85 to main::@44 [phi:main::@198/main::@209/main::@45/main::@49/main::@50/main::@85->main::@44] - // [457] phi __stdio_filecount#583 = __stdio_filecount#12 [phi:main::@198/main::@209/main::@45/main::@49/main::@50/main::@85->main::@44#0] -- register_copy - // [457] phi __errno#590 = __errno#123 [phi:main::@198/main::@209/main::@45/main::@49/main::@50/main::@85->main::@44#1] -- register_copy - // main::@44 - __b44: - // for(unsigned char rom_chip = 7; rom_chip != 255; rom_chip--) - // [458] main::rom_chip4#1 = -- main::rom_chip4#10 -- vbuz1=_dec_vbuz1 - dec.z rom_chip4 - // [442] phi from main::@44 to main::@42 [phi:main::@44->main::@42] - // [442] phi __stdio_filecount#114 = __stdio_filecount#583 [phi:main::@44->main::@42#0] -- register_copy - // [442] phi __errno#118 = __errno#590 [phi:main::@44->main::@42#1] -- register_copy - // [442] phi main::rom_chip4#10 = main::rom_chip4#1 [phi:main::@44->main::@42#2] -- register_copy - jmp __b42 - // main::bank_set_brom9 - bank_set_brom9: - // BROM = bank - // [459] BROM = main::bank_set_brom9_bank#0 -- vbuz1=vbuc1 - lda #bank_set_brom9_bank - sta.z BROM - // [460] phi from main::bank_set_brom9 to main::@87 [phi:main::bank_set_brom9->main::@87] - // main::@87 - // display_progress_clear() - // [461] call display_progress_clear - // [918] phi from main::@87 to display_progress_clear [phi:main::@87->display_progress_clear] - jsr display_progress_clear - // main::@191 - // unsigned char rom_bank = rom_chip * 32 - // [462] main::rom_bank1#0 = main::rom_chip4#10 << 5 -- vbum1=vbuz2_rol_5 - lda.z rom_chip4 - asl - asl - asl - asl - asl - sta rom_bank1 - // unsigned char* file = rom_file(rom_chip) - // [463] rom_file::rom_chip#1 = main::rom_chip4#10 -- vbum1=vbuz2 - lda.z rom_chip4 - sta rom_file.rom_chip - // [464] call rom_file - // [1591] phi from main::@191 to rom_file [phi:main::@191->rom_file] - // [1591] phi rom_file::rom_chip#2 = rom_file::rom_chip#1 [phi:main::@191->rom_file#0] -- register_copy - jsr rom_file - // unsigned char* file = rom_file(rom_chip) - // [465] rom_file::return#5 = rom_file::return#2 - // main::@192 - // [466] main::file1#0 = rom_file::return#5 - // sprintf(info_text, "Reading %s ... (.) data ( ) empty", file) - // [467] call snprintf_init - // [1205] phi from main::@192 to snprintf_init [phi:main::@192->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:main::@192->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 - jsr snprintf_init - // [468] phi from main::@192 to main::@193 [phi:main::@192->main::@193] - // main::@193 - // sprintf(info_text, "Reading %s ... (.) data ( ) empty", file) - // [469] call printf_str - // [1210] phi from main::@193 to printf_str [phi:main::@193->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main::@193->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main::s11 [phi:main::@193->printf_str#1] -- pbuz1=pbuc1 - lda #s11 - sta.z printf_str.s+1 - jsr printf_str - // main::@194 - // sprintf(info_text, "Reading %s ... (.) data ( ) empty", file) - // [470] printf_string::str#25 = main::file1#0 -- pbuz1=pbuz2 - lda.z file1 - sta.z printf_string.str - lda.z file1+1 - sta.z printf_string.str+1 - // [471] call printf_string - // [1219] phi from main::@194 to printf_string [phi:main::@194->printf_string] - // [1219] phi printf_string::putc#26 = &snputc [phi:main::@194->printf_string#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#25 [phi:main::@194->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 0 [phi:main::@194->printf_string#2] -- vbum1=vbuc1 - lda #0 - sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = 0 [phi:main::@194->printf_string#3] -- vbum1=vbuc1 - sta printf_string.format_min_length - jsr printf_string - // [472] phi from main::@194 to main::@195 [phi:main::@194->main::@195] - // main::@195 - // sprintf(info_text, "Reading %s ... (.) data ( ) empty", file) - // [473] call printf_str - // [1210] phi from main::@195 to printf_str [phi:main::@195->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main::@195->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main::s12 [phi:main::@195->printf_str#1] -- pbuz1=pbuc1 - lda #s12 - sta.z printf_str.s+1 - jsr printf_str - // main::@196 - // sprintf(info_text, "Reading %s ... (.) data ( ) empty", file) - // [474] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 - lda #0 - pha - // [475] callexecute snputc -- call_vprc1 - jsr snputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // display_action_progress(info_text) - // [477] call display_action_progress - // [904] phi from main::@196 to display_action_progress [phi:main::@196->display_action_progress] - // [904] phi display_action_progress::info_text#27 = info_text [phi:main::@196->display_action_progress#0] -- pbuz1=pbuc1 - lda #<@info_text + // main::@88 + // for(unsigned char rom_chip = 0; rom_chip < 8; rom_chip++) + // [376] main::rom_chip1#1 = ++ main::rom_chip1#2 -- vbuz1=_inc_vbuz1 + inc.z rom_chip1 + // [370] phi from main::@88 to main::@14 [phi:main::@88->main::@14] + // [370] phi main::rom_chip1#2 = main::rom_chip1#1 [phi:main::@88->main::@14#0] -- register_copy + jmp __b14 + // [377] phi from main::@33 to main::@6 [phi:main::@33->main::@6] + // main::@6 + __b6: + // display_action_progress("The SMC chip and SMC.BIN versions are equal, no flash required!") + // [378] call display_action_progress + // [559] phi from main::@6 to display_action_progress [phi:main::@6->display_action_progress] + // [559] phi display_action_progress::info_text#19 = main::info_text10 [phi:main::@6->display_action_progress#0] -- pbuz1=pbuc1 + lda #@info_text + lda #>info_text10 sta.z display_action_progress.info_text+1 jsr display_action_progress - // main::@197 - // unsigned long rom_bytes_read = rom_read(rom_chip, file, STATUS_READING, rom_bank, rom_sizes[rom_chip]) - // [478] main::$317 = main::rom_chip4#10 << 2 -- vbum1=vbuz2_rol_2 - lda.z rom_chip4 - asl - asl - sta main__317 - // [479] rom_read::rom_chip#1 = main::rom_chip4#10 -- vbum1=vbuz2 - lda.z rom_chip4 - sta rom_read.rom_chip - // [480] rom_read::file#1 = main::file1#0 -- pbuz1=pbuz2 - lda.z file1 - sta.z rom_read.file - lda.z file1+1 - sta.z rom_read.file+1 - // [481] rom_read::brom_bank_start#2 = main::rom_bank1#0 -- vbum1=vbum2 - lda rom_bank1 - sta rom_read.brom_bank_start - // [482] rom_read::rom_size#1 = rom_sizes[main::$317] -- vdum1=pduc1_derefidx_vbum2 - ldy main__317 - lda rom_sizes,y - sta rom_read.rom_size - lda rom_sizes+1,y - sta rom_read.rom_size+1 - lda rom_sizes+2,y - sta rom_read.rom_size+2 - lda rom_sizes+3,y - sta rom_read.rom_size+3 - // [483] call rom_read - // [1597] phi from main::@197 to rom_read [phi:main::@197->rom_read] - // [1597] phi rom_read::rom_chip#20 = rom_read::rom_chip#1 [phi:main::@197->rom_read#0] -- register_copy - // [1597] phi rom_read::rom_size#12 = rom_read::rom_size#1 [phi:main::@197->rom_read#1] -- register_copy - // [1597] phi __errno#105 = __errno#118 [phi:main::@197->rom_read#2] -- register_copy - // [1597] phi __stdio_filecount#100 = __stdio_filecount#114 [phi:main::@197->rom_read#3] -- register_copy - // [1597] phi rom_read::file#10 = rom_read::file#1 [phi:main::@197->rom_read#4] -- register_copy - // [1597] phi rom_read::brom_bank_start#10 = rom_read::brom_bank_start#2 [phi:main::@197->rom_read#5] -- register_copy - // [1597] phi rom_read::info_status#11 = STATUS_READING [phi:main::@197->rom_read#6] -- vbum1=vbuc1 - lda #STATUS_READING - sta rom_read.info_status - jsr rom_read - // unsigned long rom_bytes_read = rom_read(rom_chip, file, STATUS_READING, rom_bank, rom_sizes[rom_chip]) - // [484] rom_read::return#3 = rom_read::return#0 - // main::@198 - // [485] main::rom_bytes_read1#0 = rom_read::return#3 -- vduz1=vdum2 - lda rom_read.return - sta.z rom_bytes_read1 - lda rom_read.return+1 - sta.z rom_bytes_read1+1 - lda rom_read.return+2 - sta.z rom_bytes_read1+2 - lda rom_read.return+3 - sta.z rom_bytes_read1+3 - // if(rom_bytes_read) - // [486] if(0==main::rom_bytes_read1#0) goto main::@44 -- 0_eq_vduz1_then_la1 - lda.z rom_bytes_read1 - ora.z rom_bytes_read1+1 - ora.z rom_bytes_read1+2 - ora.z rom_bytes_read1+3 - bne !__b44+ - jmp __b44 - !__b44: - // [487] phi from main::@198 to main::@47 [phi:main::@198->main::@47] - // main::@47 - // display_action_progress("Comparing ... (.) data, (=) same, (*) different.") - // [488] call display_action_progress - // Now we compare the RAM with the actual ROM contents. - // [904] phi from main::@47 to display_action_progress [phi:main::@47->display_action_progress] - // [904] phi display_action_progress::info_text#27 = main::info_text30 [phi:main::@47->display_action_progress#0] -- pbuz1=pbuc1 - lda #main::@81] + // main::@81 + // util_wait_space() + // [380] call util_wait_space + // [877] phi from main::@81 to util_wait_space [phi:main::@81->util_wait_space] + jsr util_wait_space + // [381] phi from main::@81 to main::@82 [phi:main::@81->main::@82] + // main::@82 + // display_info_smc(STATUS_SKIP, "SMC.BIN and SMC equal.") + // [382] call display_info_smc + // [617] phi from main::@82 to display_info_smc [phi:main::@82->display_info_smc] + // [617] phi display_info_smc::info_text#10 = main::info_text11 [phi:main::@82->display_info_smc#0] -- pbuz1=pbuc1 + lda #info_text11 + sta.z display_info_smc.info_text+1 + // [617] phi display_info_smc::info_status#10 = STATUS_SKIP [phi:main::@82->display_info_smc#1] -- vbum1=vbuc1 + lda #STATUS_SKIP + sta display_info_smc.info_status + jsr display_info_smc + jmp check_status_smc6 + // [383] phi from main::@128 to main::@4 [phi:main::@128->main::@4] + // main::@4 + __b4: + // display_action_progress("Compatibility between ROM.BIN and SMC.BIN can't be assured!") + // [384] call display_action_progress + // [559] phi from main::@4 to display_action_progress [phi:main::@4->display_action_progress] + // [559] phi display_action_progress::info_text#19 = main::info_text8 [phi:main::@4->display_action_progress#0] -- pbuz1=pbuc1 + lda #info_text30 + lda #>info_text8 sta.z display_action_progress.info_text+1 jsr display_action_progress - // main::@199 - // display_info_rom(rom_chip, STATUS_COMPARING, "") - // [489] display_info_rom::rom_chip#12 = main::rom_chip4#10 -- vbum1=vbuz2 - lda.z rom_chip4 - sta display_info_rom.rom_chip - // [490] call display_info_rom - // [1546] phi from main::@199 to display_info_rom [phi:main::@199->display_info_rom] - // [1546] phi display_info_rom::info_text#17 = str [phi:main::@199->display_info_rom#0] -- pbuz1=pbuc1 - lda #str - sta.z display_info_rom.info_text+1 - // [1546] phi display_info_rom::rom_chip#17 = display_info_rom::rom_chip#12 [phi:main::@199->display_info_rom#1] -- register_copy - // [1546] phi display_info_rom::info_status#17 = STATUS_COMPARING [phi:main::@199->display_info_rom#2] -- vbum1=vbuc1 - lda #STATUS_COMPARING - sta display_info_rom.info_status - jsr display_info_rom - // main::@200 - // unsigned long rom_differences = rom_verify( - // rom_chip, rom_bank, file_sizes[rom_chip]) - // [491] rom_verify::rom_chip#0 = main::rom_chip4#10 -- vbum1=vbuz2 - lda.z rom_chip4 - sta rom_verify.rom_chip - // [492] rom_verify::rom_bank_start#0 = main::rom_bank1#0 -- vbum1=vbum2 - lda rom_bank1 - sta rom_verify.rom_bank_start - // [493] rom_verify::file_size#0 = file_sizes[main::$317] -- vdum1=pduc1_derefidx_vbum2 - ldy main__317 - lda file_sizes,y - sta rom_verify.file_size - lda file_sizes+1,y - sta rom_verify.file_size+1 - lda file_sizes+2,y - sta rom_verify.file_size+2 - lda file_sizes+3,y - sta rom_verify.file_size+3 - // [494] call rom_verify - // Verify the ROM... - // [1677] phi from main::@200 to rom_verify [phi:main::@200->rom_verify] - jsr rom_verify - // unsigned long rom_differences = rom_verify( - // rom_chip, rom_bank, file_sizes[rom_chip]) - // [495] rom_verify::return#2 = rom_verify::rom_different_bytes#11 - // main::@201 - // [496] main::rom_differences#0 = rom_verify::return#2 -- vduz1=vdum2 - lda rom_verify.return - sta.z rom_differences - lda rom_verify.return+1 - sta.z rom_differences+1 - lda rom_verify.return+2 - sta.z rom_differences+2 - lda rom_verify.return+3 - sta.z rom_differences+3 - // if (!rom_differences) - // [497] if(0==main::rom_differences#0) goto main::@45 -- 0_eq_vduz1_then_la1 - lda.z rom_differences - ora.z rom_differences+1 - ora.z rom_differences+2 - ora.z rom_differences+3 - bne !__b45+ - jmp __b45 - !__b45: - // [498] phi from main::@201 to main::@48 [phi:main::@201->main::@48] - // main::@48 - // sprintf(info_text, "%05x differences!", rom_differences) - // [499] call snprintf_init - // [1205] phi from main::@48 to snprintf_init [phi:main::@48->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:main::@48->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 - jsr snprintf_init - // main::@202 - // sprintf(info_text, "%05x differences!", rom_differences) - // [500] printf_ulong::uvalue#13 = main::rom_differences#0 -- vdum1=vduz2 - lda.z rom_differences - sta printf_ulong.uvalue - lda.z rom_differences+1 - sta printf_ulong.uvalue+1 - lda.z rom_differences+2 - sta printf_ulong.uvalue+2 - lda.z rom_differences+3 - sta printf_ulong.uvalue+3 - // [501] call printf_ulong - // [1741] phi from main::@202 to printf_ulong [phi:main::@202->printf_ulong] - // [1741] phi printf_ulong::format_zero_padding#15 = 1 [phi:main::@202->printf_ulong#0] -- vbum1=vbuc1 - lda #1 - sta printf_ulong.format_zero_padding - // [1741] phi printf_ulong::format_min_length#15 = 5 [phi:main::@202->printf_ulong#1] -- vbum1=vbuc1 - lda #5 - sta printf_ulong.format_min_length - // [1741] phi printf_ulong::format_radix#15 = HEXADECIMAL [phi:main::@202->printf_ulong#2] -- vbum1=vbuc1 - lda #HEXADECIMAL - sta printf_ulong.format_radix - // [1741] phi printf_ulong::uvalue#15 = printf_ulong::uvalue#13 [phi:main::@202->printf_ulong#3] -- register_copy - jsr printf_ulong - // [502] phi from main::@202 to main::@203 [phi:main::@202->main::@203] - // main::@203 - // sprintf(info_text, "%05x differences!", rom_differences) - // [503] call printf_str - // [1210] phi from main::@203 to printf_str [phi:main::@203->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main::@203->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s13 [phi:main::@203->printf_str#1] -- pbuz1=pbuc1 - lda #s13 - sta.z printf_str.s+1 - jsr printf_str - // main::@204 - // sprintf(info_text, "%05x differences!", rom_differences) - // [504] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 - lda #0 - pha - // [505] callexecute snputc -- call_vprc1 - jsr snputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // display_info_rom(rom_chip, STATUS_FLASH, info_text) - // [507] display_info_rom::rom_chip#14 = main::rom_chip4#10 -- vbum1=vbuz2 - lda.z rom_chip4 - sta display_info_rom.rom_chip - // [508] call display_info_rom - // [1546] phi from main::@204 to display_info_rom [phi:main::@204->display_info_rom] - // [1546] phi display_info_rom::info_text#17 = info_text [phi:main::@204->display_info_rom#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z display_info_rom.info_text - lda #>@info_text - sta.z display_info_rom.info_text+1 - // [1546] phi display_info_rom::rom_chip#17 = display_info_rom::rom_chip#14 [phi:main::@204->display_info_rom#1] -- register_copy - // [1546] phi display_info_rom::info_status#17 = STATUS_FLASH [phi:main::@204->display_info_rom#2] -- vbum1=vbuc1 - lda #STATUS_FLASH - sta display_info_rom.info_status - jsr display_info_rom - // main::@205 - // unsigned long rom_flash_errors = rom_flash( - // rom_chip, rom_bank, file_sizes[rom_chip]) - // [509] rom_flash::rom_chip#0 = main::rom_chip4#10 -- vbum1=vbuz2 - lda.z rom_chip4 - sta rom_flash.rom_chip - // [510] rom_flash::rom_bank_start#0 = main::rom_bank1#0 -- vbum1=vbum2 - lda rom_bank1 - sta rom_flash.rom_bank_start - // [511] rom_flash::file_size#0 = file_sizes[main::$317] -- vdum1=pduc1_derefidx_vbum2 - ldy main__317 - lda file_sizes,y - sta rom_flash.file_size - lda file_sizes+1,y - sta rom_flash.file_size+1 - lda file_sizes+2,y - sta rom_flash.file_size+2 - lda file_sizes+3,y - sta rom_flash.file_size+3 - // [512] call rom_flash - // [1751] phi from main::@205 to rom_flash [phi:main::@205->rom_flash] - jsr rom_flash - // unsigned long rom_flash_errors = rom_flash( - // rom_chip, rom_bank, file_sizes[rom_chip]) - // [513] rom_flash::return#2 = rom_flash::flash_errors#12 - // main::@206 - // [514] main::rom_flash_errors#0 = rom_flash::return#2 -- vdum1=vdum2 - lda rom_flash.return - sta rom_flash_errors - lda rom_flash.return+1 - sta rom_flash_errors+1 - lda rom_flash.return+2 - sta rom_flash_errors+2 - lda rom_flash.return+3 - sta rom_flash_errors+3 - // if(rom_flash_errors) - // [515] if(0!=main::rom_flash_errors#0) goto main::@46 -- 0_neq_vdum1_then_la1 - lda rom_flash_errors - ora rom_flash_errors+1 - ora rom_flash_errors+2 - ora rom_flash_errors+3 - bne __b46 - // main::@49 - // display_info_rom(rom_chip, STATUS_FLASHED, NULL) - // [516] display_info_rom::rom_chip#16 = main::rom_chip4#10 -- vbum1=vbuz2 - lda.z rom_chip4 - sta display_info_rom.rom_chip - // [517] call display_info_rom - // RFL3 | Flash ROM and all ok - // [1546] phi from main::@49 to display_info_rom [phi:main::@49->display_info_rom] - // [1546] phi display_info_rom::info_text#17 = 0 [phi:main::@49->display_info_rom#0] -- pbuz1=vbuc1 - lda #<0 - sta.z display_info_rom.info_text - sta.z display_info_rom.info_text+1 - // [1546] phi display_info_rom::rom_chip#17 = display_info_rom::rom_chip#16 [phi:main::@49->display_info_rom#1] -- register_copy - // [1546] phi display_info_rom::info_status#17 = STATUS_FLASHED [phi:main::@49->display_info_rom#2] -- vbum1=vbuc1 - lda #STATUS_FLASHED - sta display_info_rom.info_status - jsr display_info_rom - jmp __b44 - // [518] phi from main::@206 to main::@46 [phi:main::@206->main::@46] - // main::@46 - __b46: - // sprintf(info_text, "%u flash errors!", rom_flash_errors) - // [519] call snprintf_init - // [1205] phi from main::@46 to snprintf_init [phi:main::@46->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:main::@46->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 - jsr snprintf_init - // main::@207 - // sprintf(info_text, "%u flash errors!", rom_flash_errors) - // [520] printf_ulong::uvalue#14 = main::rom_flash_errors#0 -- vdum1=vdum2 - lda rom_flash_errors - sta printf_ulong.uvalue - lda rom_flash_errors+1 - sta printf_ulong.uvalue+1 - lda rom_flash_errors+2 - sta printf_ulong.uvalue+2 - lda rom_flash_errors+3 - sta printf_ulong.uvalue+3 - // [521] call printf_ulong - // [1741] phi from main::@207 to printf_ulong [phi:main::@207->printf_ulong] - // [1741] phi printf_ulong::format_zero_padding#15 = 0 [phi:main::@207->printf_ulong#0] -- vbum1=vbuc1 - lda #0 - sta printf_ulong.format_zero_padding - // [1741] phi printf_ulong::format_min_length#15 = 0 [phi:main::@207->printf_ulong#1] -- vbum1=vbuc1 - sta printf_ulong.format_min_length - // [1741] phi printf_ulong::format_radix#15 = DECIMAL [phi:main::@207->printf_ulong#2] -- vbum1=vbuc1 - lda #DECIMAL - sta printf_ulong.format_radix - // [1741] phi printf_ulong::uvalue#15 = printf_ulong::uvalue#14 [phi:main::@207->printf_ulong#3] -- register_copy - jsr printf_ulong - // [522] phi from main::@207 to main::@208 [phi:main::@207->main::@208] - // main::@208 - // sprintf(info_text, "%u flash errors!", rom_flash_errors) - // [523] call printf_str - // [1210] phi from main::@208 to printf_str [phi:main::@208->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main::@208->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main::s14 [phi:main::@208->printf_str#1] -- pbuz1=pbuc1 - lda #s14 - sta.z printf_str.s+1 - jsr printf_str - // main::@209 - // sprintf(info_text, "%u flash errors!", rom_flash_errors) - // [524] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 - lda #0 - pha - // [525] callexecute snputc -- call_vprc1 - jsr snputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // display_info_rom(rom_chip, STATUS_ERROR, info_text) - // [527] display_info_rom::rom_chip#15 = main::rom_chip4#10 -- vbum1=vbuz2 - lda.z rom_chip4 - sta display_info_rom.rom_chip - // [528] call display_info_rom - // [1546] phi from main::@209 to display_info_rom [phi:main::@209->display_info_rom] - // [1546] phi display_info_rom::info_text#17 = info_text [phi:main::@209->display_info_rom#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z display_info_rom.info_text - lda #>@info_text - sta.z display_info_rom.info_text+1 - // [1546] phi display_info_rom::rom_chip#17 = display_info_rom::rom_chip#15 [phi:main::@209->display_info_rom#1] -- register_copy - // [1546] phi display_info_rom::info_status#17 = STATUS_ERROR [phi:main::@209->display_info_rom#2] -- vbum1=vbuc1 - lda #STATUS_ERROR - sta display_info_rom.info_status - jsr display_info_rom - jmp __b44 - // main::@45 - __b45: - // display_info_rom(rom_chip, STATUS_SKIP, "No update required") - // [529] display_info_rom::rom_chip#13 = main::rom_chip4#10 -- vbum1=vbuz2 - lda.z rom_chip4 - sta display_info_rom.rom_chip - // [530] call display_info_rom - // RFL1 | ROM and ROM.BIN equal | Display that there are no differences between the ROM and ROM.BIN. Set ROM to Flashed. | None - // [1546] phi from main::@45 to display_info_rom [phi:main::@45->display_info_rom] - // [1546] phi display_info_rom::info_text#17 = info_text6 [phi:main::@45->display_info_rom#0] -- pbuz1=pbuc1 - lda #<@info_text6 - sta.z display_info_rom.info_text - lda #>@info_text6 - sta.z display_info_rom.info_text+1 - // [1546] phi display_info_rom::rom_chip#17 = display_info_rom::rom_chip#13 [phi:main::@45->display_info_rom#1] -- register_copy - // [1546] phi display_info_rom::info_status#17 = STATUS_SKIP [phi:main::@45->display_info_rom#2] -- vbum1=vbuc1 - lda #STATUS_SKIP - sta display_info_rom.info_status - jsr display_info_rom - jmp __b44 - // main::@262 - __b262: - // if((rom_chip == 0 && (check_status_smc(STATUS_FLASHED) || check_status_smc(STATUS_SKIP))) || (rom_chip != 0)) - // [531] if(0!=main::check_status_smc11_return#0) goto main::bank_set_brom9 -- 0_neq_vbum1_then_la1 - lda check_status_smc11_return - beq !bank_set_brom9+ - jmp bank_set_brom9 - !bank_set_brom9: - // main::@270 - // [532] if(0!=main::check_status_smc12_return#0) goto main::bank_set_brom9 -- 0_neq_vbum1_then_la1 - lda check_status_smc12_return - beq !bank_set_brom9+ - jmp bank_set_brom9 - !bank_set_brom9: - jmp __b261 - // [533] phi from main::@260 to main::@52 [phi:main::@260->main::@52] - // main::@52 - __b52: - // display_action_progress("Reading SMC.BIN ... (.) data, ( ) empty") - // [534] call display_action_progress - // [904] phi from main::@52 to display_action_progress [phi:main::@52->display_action_progress] - // [904] phi display_action_progress::info_text#27 = main::info_text23 [phi:main::@52->display_action_progress#0] -- pbuz1=pbuc1 - lda #info_text23 - sta.z display_action_progress.info_text+1 - jsr display_action_progress - // [535] phi from main::@52 to main::@185 [phi:main::@52->main::@185] - // main::@185 - // display_progress_clear() - // [536] call display_progress_clear - // [918] phi from main::@185 to display_progress_clear [phi:main::@185->display_progress_clear] - jsr display_progress_clear - // [537] phi from main::@185 to main::@186 [phi:main::@185->main::@186] - // main::@186 - // smc_read(STATUS_READING) - // [538] call smc_read - // [1155] phi from main::@186 to smc_read [phi:main::@186->smc_read] - // [1155] phi __errno#102 = __errno#117 [phi:main::@186->smc_read#0] -- register_copy - // [1155] phi __stdio_filecount#128 = __stdio_filecount#113 [phi:main::@186->smc_read#1] -- register_copy - // [1155] phi smc_read::info_status#10 = STATUS_READING [phi:main::@186->smc_read#2] -- vbum1=vbuc1 - lda #STATUS_READING - sta smc_read.info_status - jsr smc_read - // smc_read(STATUS_READING) - // [539] smc_read::return#3 = smc_read::return#0 - // main::@187 - // smc_file_size = smc_read(STATUS_READING) - // [540] smc_file_size#1 = smc_read::return#3 -- vwum1=vwum2 - lda smc_read.return - sta smc_file_size_1 - lda smc_read.return+1 - sta smc_file_size_1+1 - // if(smc_file_size) - // [541] if(0==smc_file_size#1) goto main::SEI6 -- 0_eq_vwum1_then_la1 - lda smc_file_size_1 - ora smc_file_size_1+1 - bne !SEI6+ - jmp SEI6 - !SEI6: - // [542] phi from main::@187 to main::@53 [phi:main::@187->main::@53] - // main::@53 - // display_action_text("Press both POWER/RESET buttons on the CX16 board!") - // [543] call display_action_text - // Flash the SMC chip. - // [1357] phi from main::@53 to display_action_text [phi:main::@53->display_action_text] - // [1357] phi display_action_text::info_text#25 = main::info_text24 [phi:main::@53->display_action_text#0] -- pbuz1=pbuc1 - lda #info_text24 - sta.z display_action_text.info_text+1 - jsr display_action_text - // main::@188 - // [544] smc_bootloader#510 = smc_bootloader#0 -- vwum1=vwum2 - lda smc_bootloader - sta smc_bootloader_1 - lda smc_bootloader+1 - sta smc_bootloader_1+1 - // display_info_smc(STATUS_FLASHING, "Press POWER/RESET!") - // [545] call display_info_smc - // [962] phi from main::@188 to display_info_smc [phi:main::@188->display_info_smc] - // [962] phi display_info_smc::info_text#20 = main::info_text25 [phi:main::@188->display_info_smc#0] -- pbuz1=pbuc1 - lda #info_text25 - sta.z display_info_smc.info_text+1 - // [962] phi smc_bootloader#14 = smc_bootloader#510 [phi:main::@188->display_info_smc#1] -- register_copy - // [962] phi display_info_smc::info_status#20 = STATUS_FLASHING [phi:main::@188->display_info_smc#2] -- vbum1=vbuc1 - lda #STATUS_FLASHING - sta display_info_smc.info_status - jsr display_info_smc - // main::@189 - // unsigned int flashed_bytes = smc_flash(smc_file_size) - // [546] smc_flash::smc_bytes_total#0 = smc_file_size#1 -- vwum1=vwum2 - lda smc_file_size_1 - sta smc_flash.smc_bytes_total - lda smc_file_size_1+1 - sta smc_flash.smc_bytes_total+1 - // [547] call smc_flash - // [1850] phi from main::@189 to smc_flash [phi:main::@189->smc_flash] - jsr smc_flash - // unsigned int flashed_bytes = smc_flash(smc_file_size) - // [548] smc_flash::return#5 = smc_flash::return#1 - // main::@190 - // [549] main::flashed_bytes#0 = smc_flash::return#5 -- vwuz1=vwum2 - lda smc_flash.return - sta.z flashed_bytes - lda smc_flash.return+1 - sta.z flashed_bytes+1 - // if(flashed_bytes) - // [550] if(0!=main::flashed_bytes#0) goto main::@40 -- 0_neq_vwuz1_then_la1 - lda.z flashed_bytes - ora.z flashed_bytes+1 - bne __b40 - // main::@54 - // if(flashed_bytes == (unsigned int)0xFFFF) - // [551] if(main::flashed_bytes#0==$ffff) goto main::@41 -- vwuz1_eq_vwuc1_then_la1 - lda.z flashed_bytes - cmp #<$ffff - bne !+ - lda.z flashed_bytes+1 - cmp #>$ffff - beq __b41 - !: - // main::@55 - // [552] smc_bootloader#516 = smc_bootloader#0 -- vwum1=vwum2 - lda smc_bootloader - sta smc_bootloader_1 - lda smc_bootloader+1 - sta smc_bootloader_1+1 - // display_info_smc(STATUS_ISSUE, "POWER/RESET not pressed!") - // [553] call display_info_smc - // SFL2 | no action on POWER/RESET press request - // [962] phi from main::@55 to display_info_smc [phi:main::@55->display_info_smc] - // [962] phi display_info_smc::info_text#20 = main::info_text28 [phi:main::@55->display_info_smc#0] -- pbuz1=pbuc1 - lda #info_text28 - sta.z display_info_smc.info_text+1 - // [962] phi smc_bootloader#14 = smc_bootloader#516 [phi:main::@55->display_info_smc#1] -- register_copy - // [962] phi display_info_smc::info_status#20 = STATUS_ISSUE [phi:main::@55->display_info_smc#2] -- vbum1=vbuc1 - lda #STATUS_ISSUE - sta display_info_smc.info_status - jsr display_info_smc - jmp SEI6 - // main::@41 - __b41: - // [554] smc_bootloader#515 = smc_bootloader#0 -- vwum1=vwum2 - lda smc_bootloader - sta smc_bootloader_1 - lda smc_bootloader+1 - sta smc_bootloader_1+1 - // display_info_smc(STATUS_ERROR, "SMC has errors!") - // [555] call display_info_smc - // SFL3 | errors during flash - // [962] phi from main::@41 to display_info_smc [phi:main::@41->display_info_smc] - // [962] phi display_info_smc::info_text#20 = main::info_text27 [phi:main::@41->display_info_smc#0] -- pbuz1=pbuc1 - lda #info_text27 - sta.z display_info_smc.info_text+1 - // [962] phi smc_bootloader#14 = smc_bootloader#515 [phi:main::@41->display_info_smc#1] -- register_copy - // [962] phi display_info_smc::info_status#20 = STATUS_ERROR [phi:main::@41->display_info_smc#2] -- vbum1=vbuc1 - lda #STATUS_ERROR - sta display_info_smc.info_status - jsr display_info_smc - jmp SEI6 - // main::@40 - __b40: - // [556] smc_bootloader#514 = smc_bootloader#0 -- vwum1=vwum2 - lda smc_bootloader - sta smc_bootloader_1 - lda smc_bootloader+1 - sta smc_bootloader_1+1 - // display_info_smc(STATUS_FLASHED, "") - // [557] call display_info_smc - // SFL1 | and POWER/RESET pressed - // [962] phi from main::@40 to display_info_smc [phi:main::@40->display_info_smc] - // [962] phi display_info_smc::info_text#20 = str [phi:main::@40->display_info_smc#0] -- pbuz1=pbuc1 - lda #str - sta.z display_info_smc.info_text+1 - // [962] phi smc_bootloader#14 = smc_bootloader#514 [phi:main::@40->display_info_smc#1] -- register_copy - // [962] phi display_info_smc::info_status#20 = STATUS_FLASHED [phi:main::@40->display_info_smc#2] -- vbum1=vbuc1 - lda #STATUS_FLASHED - sta display_info_smc.info_status - jsr display_info_smc - jmp SEI6 - // [558] phi from main::@177 main::@257 main::@258 main::@259 to main::@9 [phi:main::@177/main::@257/main::@258/main::@259->main::@9] - // main::@9 - __b9: - // display_action_progress("Chipsets have been detected and update files validated!") - // [559] call display_action_progress - // [904] phi from main::@9 to display_action_progress [phi:main::@9->display_action_progress] - // [904] phi display_action_progress::info_text#27 = main::info_text17 [phi:main::@9->display_action_progress#0] -- pbuz1=pbuc1 - lda #info_text17 - sta.z display_action_progress.info_text+1 - jsr display_action_progress - // [560] phi from main::@9 to main::@178 [phi:main::@9->main::@178] - // main::@178 - // unsigned char ch = util_wait_key("Continue with update of highlighted chipsets? [Y/N]", "nyNY") - // [561] call util_wait_key - // [1999] phi from main::@178 to util_wait_key [phi:main::@178->util_wait_key] - // [1999] phi util_wait_key::filter#13 = main::filter1 [phi:main::@178->util_wait_key#0] -- pbuz1=pbuc1 - lda #filter1 - sta.z util_wait_key.filter+1 - // [1999] phi util_wait_key::info_text#3 = main::info_text18 [phi:main::@178->util_wait_key#1] -- pbuz1=pbuc1 - lda #info_text18 - sta.z util_wait_key.info_text+1 - jsr util_wait_key - // unsigned char ch = util_wait_key("Continue with update of highlighted chipsets? [Y/N]", "nyNY") - // [562] util_wait_key::return#4 = util_wait_key::ch#4 -- vbum1=vwum2 - lda util_wait_key.ch - sta util_wait_key.return_1 - // main::@179 - // [563] main::ch1#0 = util_wait_key::return#4 -- vbum1=vbum2 - sta ch1 - // strchr("nN", ch) - // [564] strchr::c#1 = main::ch1#0 -- vbum1=vbum2 - sta strchr.c - // [565] call strchr - // [2023] phi from main::@179 to strchr [phi:main::@179->strchr] - // [2023] phi strchr::c#4 = strchr::c#1 [phi:main::@179->strchr#0] -- register_copy - // [2023] phi strchr::str#2 = (const void *)main::$344 [phi:main::@179->strchr#1] -- pvoz1=pvoc1 - lda #main__344 - sta.z strchr.str+1 - jsr strchr - // strchr("nN", ch) - // [566] strchr::return#4 = strchr::return#2 - // main::@180 - // [567] main::$191 = strchr::return#4 - // if(strchr("nN", ch)) - // [568] if((void *)0==main::$191) goto main::bank_set_bram1 -- pvoc1_eq_pvoz1_then_la1 - lda.z main__191 - cmp #<0 - bne !+ - lda.z main__191+1 - cmp #>0 - bne !bank_set_bram1+ - jmp bank_set_bram1 - !bank_set_bram1: - !: - // main::@10 - // [569] smc_bootloader#504 = smc_bootloader#0 -- vwum1=vwum2 - lda smc_bootloader - sta smc_bootloader_1 - lda smc_bootloader+1 - sta smc_bootloader_1+1 - // display_info_smc(STATUS_SKIP, "Cancelled") - // [570] call display_info_smc - // We cancel all updates, the updates are skipped. - // [962] phi from main::@10 to display_info_smc [phi:main::@10->display_info_smc] - // [962] phi display_info_smc::info_text#20 = main::info_text19 [phi:main::@10->display_info_smc#0] -- pbuz1=pbuc1 - lda #info_text19 - sta.z display_info_smc.info_text+1 - // [962] phi smc_bootloader#14 = smc_bootloader#504 [phi:main::@10->display_info_smc#1] -- register_copy - // [962] phi display_info_smc::info_status#20 = STATUS_SKIP [phi:main::@10->display_info_smc#2] -- vbum1=vbuc1 - lda #STATUS_SKIP - sta display_info_smc.info_status - jsr display_info_smc - // main::@181 - // [571] spi_manufacturer#581 = spi_read::return#0 -- vbum1=vbum2 - lda spi_read.return - sta spi_manufacturer - // [572] spi_memory_type#582 = spi_read::return#1 -- vbum1=vbum2 - lda spi_read.return_1 - sta spi_memory_type - // [573] spi_memory_capacity#583 = spi_read::return#2 -- vbum1=vbum2 - lda spi_read.return_2 - sta spi_memory_capacity - // display_info_vera(STATUS_SKIP, "Cancelled") - // [574] call display_info_vera - // [998] phi from main::@181 to display_info_vera [phi:main::@181->display_info_vera] - // [998] phi display_info_vera::info_text#19 = main::info_text19 [phi:main::@181->display_info_vera#0] -- pbuz1=pbuc1 - lda #info_text19 - sta.z display_info_vera.info_text+1 - // [998] phi spi_memory_capacity#106 = spi_memory_capacity#583 [phi:main::@181->display_info_vera#1] -- register_copy - // [998] phi spi_memory_type#107 = spi_memory_type#582 [phi:main::@181->display_info_vera#2] -- register_copy - // [998] phi spi_manufacturer#108 = spi_manufacturer#581 [phi:main::@181->display_info_vera#3] -- register_copy - // [998] phi display_info_vera::info_status#19 = STATUS_SKIP [phi:main::@181->display_info_vera#4] -- vbum1=vbuc1 - lda #STATUS_SKIP - sta display_info_vera.info_status - jsr display_info_vera - // [575] phi from main::@181 to main::@37 [phi:main::@181->main::@37] - // [575] phi main::rom_chip3#2 = 0 [phi:main::@181->main::@37#0] -- vbuz1=vbuc1 - lda #0 - sta.z rom_chip3 - // main::@37 - __b37: - // for(unsigned char rom_chip = 0; rom_chip < 8; rom_chip++) - // [576] if(main::rom_chip3#2<8) goto main::@38 -- vbuz1_lt_vbuc1_then_la1 - lda.z rom_chip3 - cmp #8 - bcc __b38 - // [577] phi from main::@37 to main::@39 [phi:main::@37->main::@39] - // main::@39 - // display_action_text("You have selected not to cancel the update ... ") - // [578] call display_action_text - // [1357] phi from main::@39 to display_action_text [phi:main::@39->display_action_text] - // [1357] phi display_action_text::info_text#25 = main::info_text22 [phi:main::@39->display_action_text#0] -- pbuz1=pbuc1 - lda #info_text22 - sta.z display_action_text.info_text+1 - jsr display_action_text - jmp bank_set_bram1 - // main::@38 - __b38: - // display_info_rom(rom_chip, STATUS_SKIP, "Cancelled") - // [579] display_info_rom::rom_chip#10 = main::rom_chip3#2 -- vbum1=vbuz2 - lda.z rom_chip3 - sta display_info_rom.rom_chip - // [580] call display_info_rom - // [1546] phi from main::@38 to display_info_rom [phi:main::@38->display_info_rom] - // [1546] phi display_info_rom::info_text#17 = main::info_text19 [phi:main::@38->display_info_rom#0] -- pbuz1=pbuc1 - lda #info_text19 - sta.z display_info_rom.info_text+1 - // [1546] phi display_info_rom::rom_chip#17 = display_info_rom::rom_chip#10 [phi:main::@38->display_info_rom#1] -- register_copy - // [1546] phi display_info_rom::info_status#17 = STATUS_SKIP [phi:main::@38->display_info_rom#2] -- vbum1=vbuc1 - lda #STATUS_SKIP - sta display_info_rom.info_status - jsr display_info_rom - // main::@182 - // for(unsigned char rom_chip = 0; rom_chip < 8; rom_chip++) - // [581] main::rom_chip3#1 = ++ main::rom_chip3#2 -- vbuz1=_inc_vbuz1 - inc.z rom_chip3 - // [575] phi from main::@182 to main::@37 [phi:main::@182->main::@37] - // [575] phi main::rom_chip3#2 = main::rom_chip3#1 [phi:main::@182->main::@37#0] -- register_copy - jmp __b37 - // main::@250 - __b250: - // if(check_status_smc(STATUS_FLASH) && smc_release == smc_file_release && smc_major == smc_file_major && smc_minor == smc_file_minor) - // [582] if(smc_major#399!=smc_file_major#301) goto main::check_status_smc7 -- vbum1_neq_vbum2_then_la1 - lda smc_major - cmp smc_file_major - beq !check_status_smc7+ - jmp check_status_smc7 - !check_status_smc7: - // main::@249 - // [583] if(smc_minor#398==smc_file_minor#301) goto main::@8 -- vbum1_eq_vbum2_then_la1 - lda smc_minor - cmp smc_file_minor - beq __b8 - jmp check_status_smc7 - // [584] phi from main::@249 to main::@8 [phi:main::@249->main::@8] - // main::@8 - __b8: - // display_action_progress("The SMC chip and SMC.BIN versions are equal, no flash required!") - // [585] call display_action_progress - // [904] phi from main::@8 to display_action_progress [phi:main::@8->display_action_progress] - // [904] phi display_action_progress::info_text#27 = main::info_text15 [phi:main::@8->display_action_progress#0] -- pbuz1=pbuc1 - lda #info_text15 - sta.z display_action_progress.info_text+1 - jsr display_action_progress - // [586] phi from main::@8 to main::@175 [phi:main::@8->main::@175] - // main::@175 - // util_wait_space() - // [587] call util_wait_space - // [1389] phi from main::@175 to util_wait_space [phi:main::@175->util_wait_space] - jsr util_wait_space - // main::@176 - // [588] smc_bootloader#509 = smc_bootloader#0 -- vwum1=vwum2 - lda smc_bootloader - sta smc_bootloader_1 - lda smc_bootloader+1 - sta smc_bootloader_1+1 - // display_info_smc(STATUS_SKIP, "SMC.BIN and SMC equal.") - // [589] call display_info_smc - // [962] phi from main::@176 to display_info_smc [phi:main::@176->display_info_smc] - // [962] phi display_info_smc::info_text#20 = main::info_text16 [phi:main::@176->display_info_smc#0] -- pbuz1=pbuc1 - lda #info_text16 - sta.z display_info_smc.info_text+1 - // [962] phi smc_bootloader#14 = smc_bootloader#509 [phi:main::@176->display_info_smc#1] -- register_copy - // [962] phi display_info_smc::info_status#20 = STATUS_SKIP [phi:main::@176->display_info_smc#2] -- vbum1=vbuc1 - lda #STATUS_SKIP - sta display_info_smc.info_status - jsr display_info_smc - jmp check_status_smc7 - // [590] phi from main::@247 to main::@6 [phi:main::@247->main::@6] - // main::@6 - __b6: - // display_action_progress("Compatibility between ROM.BIN and SMC.BIN can't be assured!") - // [591] call display_action_progress - // [904] phi from main::@6 to display_action_progress [phi:main::@6->display_action_progress] - // [904] phi display_action_progress::info_text#27 = main::info_text13 [phi:main::@6->display_action_progress#0] -- pbuz1=pbuc1 - lda #info_text13 - sta.z display_action_progress.info_text+1 - jsr display_action_progress - // [592] phi from main::@6 to main::@169 [phi:main::@6->main::@169] - // main::@169 + // [385] phi from main::@4 to main::@75 [phi:main::@4->main::@75] + // main::@75 // display_progress_text(display_smc_unsupported_rom_text, display_smc_unsupported_rom_count) - // [593] call display_progress_text - // [1331] phi from main::@169 to display_progress_text [phi:main::@169->display_progress_text] - // [1331] phi display_progress_text::text#13 = display_smc_unsupported_rom_text [phi:main::@169->display_progress_text#0] -- qbuz1=qbuc1 + // [386] call display_progress_text + // [815] phi from main::@75 to display_progress_text [phi:main::@75->display_progress_text] + // [815] phi display_progress_text::text#11 = display_smc_unsupported_rom_text [phi:main::@75->display_progress_text#0] -- qbuz1=qbuc1 lda #display_smc_unsupported_rom_text sta.z display_progress_text.text+1 - // [1331] phi display_progress_text::lines#12 = display_smc_unsupported_rom_count [phi:main::@169->display_progress_text#1] -- vbum1=vbuc1 + // [815] phi display_progress_text::lines#10 = display_smc_unsupported_rom_count [phi:main::@75->display_progress_text#1] -- vbum1=vbuc1 lda #display_smc_unsupported_rom_count sta display_progress_text.lines jsr display_progress_text - // [594] phi from main::@169 to main::@170 [phi:main::@169->main::@170] - // main::@170 + // [387] phi from main::@75 to main::@76 [phi:main::@75->main::@76] + // main::@76 // unsigned char ch = util_wait_key("Continue with flashing anyway? [Y/N]", "YN") - // [595] call util_wait_key - // [1999] phi from main::@170 to util_wait_key [phi:main::@170->util_wait_key] - // [1999] phi util_wait_key::filter#13 = main::filter [phi:main::@170->util_wait_key#0] -- pbuz1=pbuc1 + // [388] call util_wait_key + // [1034] phi from main::@76 to util_wait_key [phi:main::@76->util_wait_key] + // [1034] phi util_wait_key::filter#13 = main::filter [phi:main::@76->util_wait_key#0] -- pbuz1=pbuc1 lda #filter sta.z util_wait_key.filter+1 - // [1999] phi util_wait_key::info_text#3 = main::info_text14 [phi:main::@170->util_wait_key#1] -- pbuz1=pbuc1 - lda #util_wait_key#1] -- pbuz1=pbuc1 + lda #info_text14 + lda #>info_text9 sta.z util_wait_key.info_text+1 jsr util_wait_key // unsigned char ch = util_wait_key("Continue with flashing anyway? [Y/N]", "YN") - // [596] util_wait_key::return#3 = util_wait_key::ch#4 -- vbum1=vwum2 + // [389] util_wait_key::return#3 = util_wait_key::ch#4 -- vbum1=vwum2 lda util_wait_key.ch sta util_wait_key.return - // main::@171 - // [597] main::ch#0 = util_wait_key::return#3 -- vbum1=vbum2 - sta ch + // main::@77 + // [390] main::ch#0 = util_wait_key::return#3 -- vbuz1=vbum2 + sta.z ch // if(ch == 'N') - // [598] if(main::ch#0!='N') goto main::check_status_smc6 -- vbum1_neq_vbuc1_then_la1 + // [391] if(main::ch#0!='N') goto main::check_status_smc5 -- vbuz1_neq_vbuc1_then_la1 lda #'N' - cmp ch - beq !check_status_smc6+ - jmp check_status_smc6 - !check_status_smc6: - // main::@7 - // [599] smc_bootloader#501 = smc_bootloader#0 -- vwum1=vwum2 - lda smc_bootloader - sta smc_bootloader_1 - lda smc_bootloader+1 - sta smc_bootloader_1+1 + cmp.z ch + beq !check_status_smc5+ + jmp check_status_smc5 + !check_status_smc5: + // [392] phi from main::@77 to main::@5 [phi:main::@77->main::@5] + // main::@5 // display_info_smc(STATUS_ISSUE, NULL) - // [600] call display_info_smc + // [393] call display_info_smc // Cancel flash - // [962] phi from main::@7 to display_info_smc [phi:main::@7->display_info_smc] - // [962] phi display_info_smc::info_text#20 = 0 [phi:main::@7->display_info_smc#0] -- pbuz1=vbuc1 + // [617] phi from main::@5 to display_info_smc [phi:main::@5->display_info_smc] + // [617] phi display_info_smc::info_text#10 = 0 [phi:main::@5->display_info_smc#0] -- pbuz1=vbuc1 lda #<0 sta.z display_info_smc.info_text sta.z display_info_smc.info_text+1 - // [962] phi smc_bootloader#14 = smc_bootloader#501 [phi:main::@7->display_info_smc#1] -- register_copy - // [962] phi display_info_smc::info_status#20 = STATUS_ISSUE [phi:main::@7->display_info_smc#2] -- vbum1=vbuc1 + // [617] phi display_info_smc::info_status#10 = STATUS_ISSUE [phi:main::@5->display_info_smc#1] -- vbum1=vbuc1 lda #STATUS_ISSUE sta display_info_smc.info_status jsr display_info_smc - // [601] phi from main::@7 to main::@172 [phi:main::@7->main::@172] - // main::@172 + // [394] phi from main::@5 to main::@78 [phi:main::@5->main::@78] + // main::@78 // display_info_cx16_rom(STATUS_ISSUE, NULL) - // [602] call display_info_cx16_rom - // [2032] phi from main::@172 to display_info_cx16_rom [phi:main::@172->display_info_cx16_rom] - // [2032] phi display_info_cx16_rom::info_text#4 = 0 [phi:main::@172->display_info_cx16_rom#0] -- pbuz1=vbuc1 + // [395] call display_info_cx16_rom + // [1112] phi from main::@78 to display_info_cx16_rom [phi:main::@78->display_info_cx16_rom] + // [1112] phi display_info_cx16_rom::info_text#4 = 0 [phi:main::@78->display_info_cx16_rom#0] -- pbuz1=vbuc1 lda #<0 sta.z display_info_cx16_rom.info_text sta.z display_info_cx16_rom.info_text+1 - // [2032] phi display_info_cx16_rom::info_status#4 = STATUS_ISSUE [phi:main::@172->display_info_cx16_rom#1] -- vbum1=vbuc1 + // [1112] phi display_info_cx16_rom::info_status#4 = STATUS_ISSUE [phi:main::@78->display_info_cx16_rom#1] -- vbum1=vbuc1 lda #STATUS_ISSUE sta display_info_cx16_rom.info_status jsr display_info_cx16_rom - jmp check_status_smc6 - // [603] phi from main::@246 to main::@5 [phi:main::@246->main::@5] - // main::@5 - __b5: + jmp check_status_smc5 + // [396] phi from main::@127 to main::@3 [phi:main::@127->main::@3] + // main::@3 + __b3: // display_action_progress("CX16 ROM update issue!") - // [604] call display_action_progress - // [904] phi from main::@5 to display_action_progress [phi:main::@5->display_action_progress] - // [904] phi display_action_progress::info_text#27 = main::info_text11 [phi:main::@5->display_action_progress#0] -- pbuz1=pbuc1 - lda #display_action_progress] + // [559] phi display_action_progress::info_text#19 = main::info_text6 [phi:main::@3->display_action_progress#0] -- pbuz1=pbuc1 + lda #info_text11 + lda #>info_text6 sta.z display_action_progress.info_text+1 jsr display_action_progress - // [605] phi from main::@5 to main::@164 [phi:main::@5->main::@164] - // main::@164 + // [398] phi from main::@3 to main::@70 [phi:main::@3->main::@70] + // main::@70 // display_progress_text(display_smc_rom_issue_text, display_smc_rom_issue_count) - // [606] call display_progress_text - // [1331] phi from main::@164 to display_progress_text [phi:main::@164->display_progress_text] - // [1331] phi display_progress_text::text#13 = display_smc_rom_issue_text [phi:main::@164->display_progress_text#0] -- qbuz1=qbuc1 + // [399] call display_progress_text + // [815] phi from main::@70 to display_progress_text [phi:main::@70->display_progress_text] + // [815] phi display_progress_text::text#11 = display_smc_rom_issue_text [phi:main::@70->display_progress_text#0] -- qbuz1=qbuc1 lda #display_smc_rom_issue_text sta.z display_progress_text.text+1 - // [1331] phi display_progress_text::lines#12 = display_smc_rom_issue_count [phi:main::@164->display_progress_text#1] -- vbum1=vbuc1 + // [815] phi display_progress_text::lines#10 = display_smc_rom_issue_count [phi:main::@70->display_progress_text#1] -- vbum1=vbuc1 lda #display_smc_rom_issue_count sta display_progress_text.lines jsr display_progress_text - // main::@165 - // [607] smc_bootloader#508 = smc_bootloader#0 -- vwum1=vwum2 - lda smc_bootloader - sta smc_bootloader_1 - lda smc_bootloader+1 - sta smc_bootloader_1+1 + // [400] phi from main::@70 to main::@71 [phi:main::@70->main::@71] + // main::@71 // display_info_smc(STATUS_SKIP, "Issue with main CX16 ROM!") - // [608] call display_info_smc - // [962] phi from main::@165 to display_info_smc [phi:main::@165->display_info_smc] - // [962] phi display_info_smc::info_text#20 = main::info_text9 [phi:main::@165->display_info_smc#0] -- pbuz1=pbuc1 - lda #display_info_smc] + // [617] phi display_info_smc::info_text#10 = main::info_text4 [phi:main::@71->display_info_smc#0] -- pbuz1=pbuc1 + lda #info_text9 + lda #>info_text4 sta.z display_info_smc.info_text+1 - // [962] phi smc_bootloader#14 = smc_bootloader#508 [phi:main::@165->display_info_smc#1] -- register_copy - // [962] phi display_info_smc::info_status#20 = STATUS_SKIP [phi:main::@165->display_info_smc#2] -- vbum1=vbuc1 + // [617] phi display_info_smc::info_status#10 = STATUS_SKIP [phi:main::@71->display_info_smc#1] -- vbum1=vbuc1 lda #STATUS_SKIP sta display_info_smc.info_status jsr display_info_smc - // [609] phi from main::@165 to main::@166 [phi:main::@165->main::@166] - // main::@166 + // [402] phi from main::@71 to main::@72 [phi:main::@71->main::@72] + // main::@72 // display_info_cx16_rom(STATUS_ISSUE, NULL) - // [610] call display_info_cx16_rom - // [2032] phi from main::@166 to display_info_cx16_rom [phi:main::@166->display_info_cx16_rom] - // [2032] phi display_info_cx16_rom::info_text#4 = 0 [phi:main::@166->display_info_cx16_rom#0] -- pbuz1=vbuc1 + // [403] call display_info_cx16_rom + // [1112] phi from main::@72 to display_info_cx16_rom [phi:main::@72->display_info_cx16_rom] + // [1112] phi display_info_cx16_rom::info_text#4 = 0 [phi:main::@72->display_info_cx16_rom#0] -- pbuz1=vbuc1 lda #<0 sta.z display_info_cx16_rom.info_text sta.z display_info_cx16_rom.info_text+1 - // [2032] phi display_info_cx16_rom::info_status#4 = STATUS_ISSUE [phi:main::@166->display_info_cx16_rom#1] -- vbum1=vbuc1 + // [1112] phi display_info_cx16_rom::info_status#4 = STATUS_ISSUE [phi:main::@72->display_info_cx16_rom#1] -- vbum1=vbuc1 lda #STATUS_ISSUE sta display_info_cx16_rom.info_status jsr display_info_cx16_rom - // [611] phi from main::@166 to main::@167 [phi:main::@166->main::@167] - // main::@167 + // [404] phi from main::@72 to main::@73 [phi:main::@72->main::@73] + // main::@73 // util_wait_space() - // [612] call util_wait_space - // [1389] phi from main::@167 to util_wait_space [phi:main::@167->util_wait_space] + // [405] call util_wait_space + // [877] phi from main::@73 to util_wait_space [phi:main::@73->util_wait_space] jsr util_wait_space - jmp check_status_smc5 - // [613] phi from main::@245 to main::@3 [phi:main::@245->main::@3] - // main::@3 - __b3: + jmp check_status_smc4 + // [406] phi from main::@126 to main::@1 [phi:main::@126->main::@1] + // main::@1 + __b1: // display_action_progress("CX16 ROM update issue, ROM not detected!") - // [614] call display_action_progress - // [904] phi from main::@3 to display_action_progress [phi:main::@3->display_action_progress] - // [904] phi display_action_progress::info_text#27 = main::info_text8 [phi:main::@3->display_action_progress#0] -- pbuz1=pbuc1 - lda #display_action_progress] + // [559] phi display_action_progress::info_text#19 = main::info_text3 [phi:main::@1->display_action_progress#0] -- pbuz1=pbuc1 + lda #info_text8 + lda #>info_text3 sta.z display_action_progress.info_text+1 jsr display_action_progress - // [615] phi from main::@3 to main::@160 [phi:main::@3->main::@160] - // main::@160 + // [408] phi from main::@1 to main::@66 [phi:main::@1->main::@66] + // main::@66 // display_progress_text(display_smc_rom_issue_text, display_smc_rom_issue_count) - // [616] call display_progress_text - // [1331] phi from main::@160 to display_progress_text [phi:main::@160->display_progress_text] - // [1331] phi display_progress_text::text#13 = display_smc_rom_issue_text [phi:main::@160->display_progress_text#0] -- qbuz1=qbuc1 + // [409] call display_progress_text + // [815] phi from main::@66 to display_progress_text [phi:main::@66->display_progress_text] + // [815] phi display_progress_text::text#11 = display_smc_rom_issue_text [phi:main::@66->display_progress_text#0] -- qbuz1=qbuc1 lda #display_smc_rom_issue_text sta.z display_progress_text.text+1 - // [1331] phi display_progress_text::lines#12 = display_smc_rom_issue_count [phi:main::@160->display_progress_text#1] -- vbum1=vbuc1 + // [815] phi display_progress_text::lines#10 = display_smc_rom_issue_count [phi:main::@66->display_progress_text#1] -- vbum1=vbuc1 lda #display_smc_rom_issue_count sta display_progress_text.lines jsr display_progress_text - // main::@161 - // [617] smc_bootloader#507 = smc_bootloader#0 -- vwum1=vwum2 - lda smc_bootloader - sta smc_bootloader_1 - lda smc_bootloader+1 - sta smc_bootloader_1+1 + // [410] phi from main::@66 to main::@67 [phi:main::@66->main::@67] + // main::@67 // display_info_smc(STATUS_SKIP, "Issue with main CX16 ROM!") - // [618] call display_info_smc - // [962] phi from main::@161 to display_info_smc [phi:main::@161->display_info_smc] - // [962] phi display_info_smc::info_text#20 = main::info_text9 [phi:main::@161->display_info_smc#0] -- pbuz1=pbuc1 - lda #display_info_smc] + // [617] phi display_info_smc::info_text#10 = main::info_text4 [phi:main::@67->display_info_smc#0] -- pbuz1=pbuc1 + lda #info_text9 + lda #>info_text4 sta.z display_info_smc.info_text+1 - // [962] phi smc_bootloader#14 = smc_bootloader#507 [phi:main::@161->display_info_smc#1] -- register_copy - // [962] phi display_info_smc::info_status#20 = STATUS_SKIP [phi:main::@161->display_info_smc#2] -- vbum1=vbuc1 + // [617] phi display_info_smc::info_status#10 = STATUS_SKIP [phi:main::@67->display_info_smc#1] -- vbum1=vbuc1 lda #STATUS_SKIP sta display_info_smc.info_status jsr display_info_smc - // [619] phi from main::@161 to main::@162 [phi:main::@161->main::@162] - // main::@162 + // [412] phi from main::@67 to main::@68 [phi:main::@67->main::@68] + // main::@68 // display_info_cx16_rom(STATUS_ISSUE, "Are J1 jumper pins closed?") - // [620] call display_info_cx16_rom - // [2032] phi from main::@162 to display_info_cx16_rom [phi:main::@162->display_info_cx16_rom] - // [2032] phi display_info_cx16_rom::info_text#4 = main::info_text10 [phi:main::@162->display_info_cx16_rom#0] -- pbuz1=pbuc1 - lda #display_info_cx16_rom] + // [1112] phi display_info_cx16_rom::info_text#4 = main::info_text5 [phi:main::@68->display_info_cx16_rom#0] -- pbuz1=pbuc1 + lda #info_text10 + lda #>info_text5 sta.z display_info_cx16_rom.info_text+1 - // [2032] phi display_info_cx16_rom::info_status#4 = STATUS_ISSUE [phi:main::@162->display_info_cx16_rom#1] -- vbum1=vbuc1 + // [1112] phi display_info_cx16_rom::info_status#4 = STATUS_ISSUE [phi:main::@68->display_info_cx16_rom#1] -- vbum1=vbuc1 lda #STATUS_ISSUE sta display_info_cx16_rom.info_status jsr display_info_cx16_rom - // [621] phi from main::@162 to main::@163 [phi:main::@162->main::@163] - // main::@163 + // [414] phi from main::@68 to main::@69 [phi:main::@68->main::@69] + // main::@69 // util_wait_space() - // [622] call util_wait_space - // [1389] phi from main::@163 to util_wait_space [phi:main::@163->util_wait_space] + // [415] call util_wait_space + // [877] phi from main::@69 to util_wait_space [phi:main::@69->util_wait_space] jsr util_wait_space - jmp check_status_smc5 - // [623] phi from main::@244 to main::@36 [phi:main::@244->main::@36] - // main::@36 - __b36: + jmp check_status_smc4 + // [416] phi from main::@125 to main::@13 [phi:main::@125->main::@13] + // main::@13 + __b13: // display_action_progress("SMC update issue!") - // [624] call display_action_progress - // [904] phi from main::@36 to display_action_progress [phi:main::@36->display_action_progress] - // [904] phi display_action_progress::info_text#27 = main::info_text6 [phi:main::@36->display_action_progress#0] -- pbuz1=pbuc1 - lda #display_action_progress] + // [559] phi display_action_progress::info_text#19 = main::info_text1 [phi:main::@13->display_action_progress#0] -- pbuz1=pbuc1 + lda #info_text6 + lda #>info_text1 sta.z display_action_progress.info_text+1 jsr display_action_progress - // [625] phi from main::@36 to main::@156 [phi:main::@36->main::@156] - // main::@156 + // [418] phi from main::@13 to main::@62 [phi:main::@13->main::@62] + // main::@62 // display_progress_text(display_smc_rom_issue_text, display_smc_rom_issue_count) - // [626] call display_progress_text - // [1331] phi from main::@156 to display_progress_text [phi:main::@156->display_progress_text] - // [1331] phi display_progress_text::text#13 = display_smc_rom_issue_text [phi:main::@156->display_progress_text#0] -- qbuz1=qbuc1 + // [419] call display_progress_text + // [815] phi from main::@62 to display_progress_text [phi:main::@62->display_progress_text] + // [815] phi display_progress_text::text#11 = display_smc_rom_issue_text [phi:main::@62->display_progress_text#0] -- qbuz1=qbuc1 lda #display_smc_rom_issue_text sta.z display_progress_text.text+1 - // [1331] phi display_progress_text::lines#12 = display_smc_rom_issue_count [phi:main::@156->display_progress_text#1] -- vbum1=vbuc1 + // [815] phi display_progress_text::lines#10 = display_smc_rom_issue_count [phi:main::@62->display_progress_text#1] -- vbum1=vbuc1 lda #display_smc_rom_issue_count sta display_progress_text.lines jsr display_progress_text - // [627] phi from main::@156 to main::@157 [phi:main::@156->main::@157] - // main::@157 + // [420] phi from main::@62 to main::@63 [phi:main::@62->main::@63] + // main::@63 // display_info_cx16_rom(STATUS_SKIP, "Issue with SMC!") - // [628] call display_info_cx16_rom - // [2032] phi from main::@157 to display_info_cx16_rom [phi:main::@157->display_info_cx16_rom] - // [2032] phi display_info_cx16_rom::info_text#4 = main::info_text7 [phi:main::@157->display_info_cx16_rom#0] -- pbuz1=pbuc1 - lda #display_info_cx16_rom] + // [1112] phi display_info_cx16_rom::info_text#4 = main::info_text2 [phi:main::@63->display_info_cx16_rom#0] -- pbuz1=pbuc1 + lda #info_text7 + lda #>info_text2 sta.z display_info_cx16_rom.info_text+1 - // [2032] phi display_info_cx16_rom::info_status#4 = STATUS_SKIP [phi:main::@157->display_info_cx16_rom#1] -- vbum1=vbuc1 + // [1112] phi display_info_cx16_rom::info_status#4 = STATUS_SKIP [phi:main::@63->display_info_cx16_rom#1] -- vbum1=vbuc1 lda #STATUS_SKIP sta display_info_cx16_rom.info_status jsr display_info_cx16_rom - // main::@158 - // [629] smc_bootloader#506 = smc_bootloader#0 -- vwum1=vwum2 - lda smc_bootloader - sta smc_bootloader_1 - lda smc_bootloader+1 - sta smc_bootloader_1+1 + // [422] phi from main::@63 to main::@64 [phi:main::@63->main::@64] + // main::@64 // display_info_smc(STATUS_ISSUE, NULL) - // [630] call display_info_smc - // [962] phi from main::@158 to display_info_smc [phi:main::@158->display_info_smc] - // [962] phi display_info_smc::info_text#20 = 0 [phi:main::@158->display_info_smc#0] -- pbuz1=vbuc1 + // [423] call display_info_smc + // [617] phi from main::@64 to display_info_smc [phi:main::@64->display_info_smc] + // [617] phi display_info_smc::info_text#10 = 0 [phi:main::@64->display_info_smc#0] -- pbuz1=vbuc1 lda #<0 sta.z display_info_smc.info_text sta.z display_info_smc.info_text+1 - // [962] phi smc_bootloader#14 = smc_bootloader#506 [phi:main::@158->display_info_smc#1] -- register_copy - // [962] phi display_info_smc::info_status#20 = STATUS_ISSUE [phi:main::@158->display_info_smc#2] -- vbum1=vbuc1 + // [617] phi display_info_smc::info_status#10 = STATUS_ISSUE [phi:main::@64->display_info_smc#1] -- vbum1=vbuc1 lda #STATUS_ISSUE sta display_info_smc.info_status jsr display_info_smc - // [631] phi from main::@158 to main::@159 [phi:main::@158->main::@159] - // main::@159 + // [424] phi from main::@64 to main::@65 [phi:main::@64->main::@65] + // main::@65 // util_wait_space() - // [632] call util_wait_space - // [1389] phi from main::@159 to util_wait_space [phi:main::@159->util_wait_space] + // [425] call util_wait_space + // [877] phi from main::@65 to util_wait_space [phi:main::@65->util_wait_space] jsr util_wait_space - jmp check_status_smc3 - // main::bank_set_brom5 - bank_set_brom5: - // BROM = bank - // [633] BROM = main::bank_set_brom5_bank#0 -- vbuz1=vbuc1 - lda #bank_set_brom5_bank - sta.z BROM - // main::@72 - // if(rom_device_ids[rom_chip] != UNKNOWN) - // [634] if(rom_device_ids[main::rom_chip2#10]==$55) goto main::@30 -- pbuc1_derefidx_vbuz1_eq_vbuc2_then_la1 - ldy.z rom_chip2 - lda rom_device_ids,y - cmp #$55 - bne !__b30+ - jmp __b30 - !__b30: - // [635] phi from main::@72 to main::@33 [phi:main::@72->main::@33] - // main::@33 - // display_progress_clear() - // [636] call display_progress_clear - // [918] phi from main::@33 to display_progress_clear [phi:main::@33->display_progress_clear] - jsr display_progress_clear - // main::@134 - // unsigned char rom_bank = rom_chip * 32 - // [637] main::rom_bank#0 = main::rom_chip2#10 << 5 -- vbum1=vbuz2_rol_5 - lda.z rom_chip2 - asl - asl - asl - asl - asl - sta rom_bank - // unsigned char* file = rom_file(rom_chip) - // [638] rom_file::rom_chip#0 = main::rom_chip2#10 -- vbum1=vbuz2 - lda.z rom_chip2 - sta rom_file.rom_chip - // [639] call rom_file - // [1591] phi from main::@134 to rom_file [phi:main::@134->rom_file] - // [1591] phi rom_file::rom_chip#2 = rom_file::rom_chip#0 [phi:main::@134->rom_file#0] -- register_copy - jsr rom_file - // unsigned char* file = rom_file(rom_chip) - // [640] rom_file::return#4 = rom_file::return#2 - // main::@135 - // [641] main::file#0 = rom_file::return#4 -- pbum1=pbuz2 - lda.z rom_file.return - sta file - lda.z rom_file.return+1 - sta file+1 - // sprintf(info_text, "Checking %s ...", file) - // [642] call snprintf_init - // [1205] phi from main::@135 to snprintf_init [phi:main::@135->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:main::@135->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 - jsr snprintf_init - // [643] phi from main::@135 to main::@136 [phi:main::@135->main::@136] - // main::@136 - // sprintf(info_text, "Checking %s ...", file) - // [644] call printf_str - // [1210] phi from main::@136 to printf_str [phi:main::@136->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main::@136->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main::s5 [phi:main::@136->printf_str#1] -- pbuz1=pbuc1 - lda #s5 - sta.z printf_str.s+1 - jsr printf_str - // main::@137 - // sprintf(info_text, "Checking %s ...", file) - // [645] printf_string::str#20 = main::file#0 -- pbuz1=pbum2 - lda file - sta.z printf_string.str - lda file+1 - sta.z printf_string.str+1 - // [646] call printf_string - // [1219] phi from main::@137 to printf_string [phi:main::@137->printf_string] - // [1219] phi printf_string::putc#26 = &snputc [phi:main::@137->printf_string#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#20 [phi:main::@137->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 0 [phi:main::@137->printf_string#2] -- vbum1=vbuc1 - lda #0 - sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = 0 [phi:main::@137->printf_string#3] -- vbum1=vbuc1 - sta printf_string.format_min_length - jsr printf_string - // [647] phi from main::@137 to main::@138 [phi:main::@137->main::@138] - // main::@138 - // sprintf(info_text, "Checking %s ...", file) - // [648] call printf_str - // [1210] phi from main::@138 to printf_str [phi:main::@138->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main::@138->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s6 [phi:main::@138->printf_str#1] -- pbuz1=pbuc1 - lda #s6 - sta.z printf_str.s+1 - jsr printf_str - // main::@139 - // sprintf(info_text, "Checking %s ...", file) - // [649] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 - lda #0 - pha - // [650] callexecute snputc -- call_vprc1 - jsr snputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // display_action_progress(info_text) - // [652] call display_action_progress - // [904] phi from main::@139 to display_action_progress [phi:main::@139->display_action_progress] - // [904] phi display_action_progress::info_text#27 = info_text [phi:main::@139->display_action_progress#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z display_action_progress.info_text - lda #>@info_text - sta.z display_action_progress.info_text+1 - jsr display_action_progress - // main::@140 - // unsigned long rom_bytes_read = rom_read(rom_chip, file, STATUS_CHECKING, rom_bank, rom_sizes[rom_chip]) - // [653] main::$315 = main::rom_chip2#10 << 2 -- vbum1=vbuz2_rol_2 - lda.z rom_chip2 - asl - asl - sta main__315 - // [654] rom_read::rom_chip#0 = main::rom_chip2#10 -- vbum1=vbuz2 - lda.z rom_chip2 - sta rom_read.rom_chip - // [655] rom_read::file#0 = main::file#0 -- pbuz1=pbum2 - lda file - sta.z rom_read.file - lda file+1 - sta.z rom_read.file+1 - // [656] rom_read::brom_bank_start#1 = main::rom_bank#0 -- vbum1=vbum2 - lda rom_bank - sta rom_read.brom_bank_start - // [657] rom_read::rom_size#0 = rom_sizes[main::$315] -- vdum1=pduc1_derefidx_vbum2 - ldy main__315 - lda rom_sizes,y - sta rom_read.rom_size - lda rom_sizes+1,y - sta rom_read.rom_size+1 - lda rom_sizes+2,y - sta rom_read.rom_size+2 - lda rom_sizes+3,y - sta rom_read.rom_size+3 - // [658] call rom_read - // Read the ROM(n).BIN file. - // [1597] phi from main::@140 to rom_read [phi:main::@140->rom_read] - // [1597] phi rom_read::rom_chip#20 = rom_read::rom_chip#0 [phi:main::@140->rom_read#0] -- register_copy - // [1597] phi rom_read::rom_size#12 = rom_read::rom_size#0 [phi:main::@140->rom_read#1] -- register_copy - // [1597] phi __errno#105 = __errno#115 [phi:main::@140->rom_read#2] -- register_copy - // [1597] phi __stdio_filecount#100 = __stdio_filecount#111 [phi:main::@140->rom_read#3] -- register_copy - // [1597] phi rom_read::file#10 = rom_read::file#0 [phi:main::@140->rom_read#4] -- register_copy - // [1597] phi rom_read::brom_bank_start#10 = rom_read::brom_bank_start#1 [phi:main::@140->rom_read#5] -- register_copy - // [1597] phi rom_read::info_status#11 = STATUS_CHECKING [phi:main::@140->rom_read#6] -- vbum1=vbuc1 - lda #STATUS_CHECKING - sta rom_read.info_status - jsr rom_read - // unsigned long rom_bytes_read = rom_read(rom_chip, file, STATUS_CHECKING, rom_bank, rom_sizes[rom_chip]) - // [659] rom_read::return#2 = rom_read::return#0 - // main::@141 - // [660] main::rom_bytes_read#0 = rom_read::return#2 -- vduz1=vdum2 - lda rom_read.return - sta.z rom_bytes_read - lda rom_read.return+1 - sta.z rom_bytes_read+1 - lda rom_read.return+2 - sta.z rom_bytes_read+2 - lda rom_read.return+3 - sta.z rom_bytes_read+3 - // if (!rom_bytes_read) - // [661] if(0==main::rom_bytes_read#0) goto main::@31 -- 0_eq_vduz1_then_la1 - // In case no file was found, set the status to none and skip to the next, else, mention the amount of bytes read. - lda.z rom_bytes_read - ora.z rom_bytes_read+1 - ora.z rom_bytes_read+2 - ora.z rom_bytes_read+3 - bne !__b31+ - jmp __b31 - !__b31: - // main::@34 - // unsigned long rom_file_modulo = rom_bytes_read % 0x4000 - // [662] main::rom_file_modulo#0 = main::rom_bytes_read#0 & $4000-1 -- vduz1=vduz2_band_vduc1 - lda.z rom_bytes_read - and #<$4000-1 - sta.z rom_file_modulo - lda.z rom_bytes_read+1 - and #>$4000-1 - sta.z rom_file_modulo+1 - lda.z rom_bytes_read+2 - and #<$4000-1>>$10 - sta.z rom_file_modulo+2 - lda.z rom_bytes_read+3 - and #>$4000-1>>$10 - sta.z rom_file_modulo+3 - // if(rom_file_modulo) - // [663] if(0!=main::rom_file_modulo#0) goto main::@32 -- 0_neq_vduz1_then_la1 - lda.z rom_file_modulo - ora.z rom_file_modulo+1 - ora.z rom_file_modulo+2 - ora.z rom_file_modulo+3 - beq !__b32+ - jmp __b32 - !__b32: - // main::@35 - // file_sizes[rom_chip] = rom_bytes_read - // [664] file_sizes[main::$315] = main::rom_bytes_read#0 -- pduc1_derefidx_vbum1=vduz2 - // RF5 | ROM.BIN all ok | Display the ROM.BIN release version and github commit id (if any) and set ROM to Flash | Flash - // We know the file size, so we indicate it in the status panel. - ldy main__315 - lda.z rom_bytes_read - sta file_sizes,y - lda.z rom_bytes_read+1 - sta file_sizes+1,y - lda.z rom_bytes_read+2 - sta file_sizes+2,y - lda.z rom_bytes_read+3 - sta file_sizes+3,y - // 8*rom_chip - // [665] main::$140 = main::rom_chip2#10 << 3 -- vbuz1=vbuz2_rol_3 - lda.z rom_chip2 + jmp check_status_smc2 + // main::@11 + __b11: + // rom_chip*13 + // [426] main::$231 = main::rom_chip#2 << 1 -- vbuz1=vbuz2_rol_1 + lda.z rom_chip asl + sta.z main__231 + // [427] main::$232 = main::$231 + main::rom_chip#2 -- vbuz1=vbuz1_plus_vbuz2 + lda.z main__232 + clc + adc.z rom_chip + sta.z main__232 + // [428] main::$233 = main::$232 << 2 -- vbuz1=vbuz1_rol_2 + lda.z main__233 asl asl - sta.z main__140 - // unsigned char* rom_file_github_id = &rom_file_github[8*rom_chip] - // [666] main::rom_file_github_id#0 = rom_file_github + main::$140 -- pbuz1=pbuc1_plus_vbuz2 - // Fill the version data ... + sta.z main__233 + // [429] main::$72 = main::$233 + main::rom_chip#2 -- vbuz1=vbuz1_plus_vbuz2 + lda.z main__72 + clc + adc.z rom_chip + sta.z main__72 + // strcpy(&rom_release_text[rom_chip*13], " " ) + // [430] strcpy::destination#1 = rom_release_text + main::$72 -- pbuz1=pbuc1_plus_vbuz2 clc - adc #rom_file_github + adc #rom_release_text adc #0 - sta.z rom_file_github_id+1 - // unsigned char rom_file_release_id = rom_get_release(rom_file_release[rom_chip]) - // [667] rom_get_release::release#2 = rom_file_release[main::rom_chip2#10] -- vbum1=pbuc1_derefidx_vbuz2 - ldy.z rom_chip2 - lda rom_file_release,y - sta rom_get_release.release - // [668] call rom_get_release - // [2037] phi from main::@35 to rom_get_release [phi:main::@35->rom_get_release] - // [2037] phi rom_get_release::release#3 = rom_get_release::release#2 [phi:main::@35->rom_get_release#0] -- register_copy - jsr rom_get_release - // unsigned char rom_file_release_id = rom_get_release(rom_file_release[rom_chip]) - // [669] rom_get_release::return#3 = rom_get_release::return#0 - // main::@149 - // [670] main::rom_file_release_id#0 = rom_get_release::return#3 -- vbum1=vbum2 - lda rom_get_release.return - sta rom_file_release_id - // unsigned char rom_file_prefix_id = rom_get_prefix(rom_file_release[rom_chip]) - // [671] rom_get_prefix::release#1 = rom_file_release[main::rom_chip2#10] -- vbum1=pbuc1_derefidx_vbuz2 - ldy.z rom_chip2 - lda rom_file_release,y - sta rom_get_prefix.release - // [672] call rom_get_prefix - // [2044] phi from main::@149 to rom_get_prefix [phi:main::@149->rom_get_prefix] - // [2044] phi rom_get_prefix::release#2 = rom_get_prefix::release#1 [phi:main::@149->rom_get_prefix#0] -- register_copy - jsr rom_get_prefix - // unsigned char rom_file_prefix_id = rom_get_prefix(rom_file_release[rom_chip]) - // [673] rom_get_prefix::return#3 = rom_get_prefix::return#0 - // main::@150 - // [674] main::rom_file_prefix_id#0 = rom_get_prefix::return#3 -- vbuz1=vbum2 - lda rom_get_prefix.return - sta.z rom_file_prefix_id - // rom_get_version_text(rom_file_release_text, rom_file_prefix_id, rom_file_release_id, rom_file_github_id) - // [675] rom_get_version_text::prefix#1 = main::rom_file_prefix_id#0 -- vbum1=vbuz2 - sta rom_get_version_text.prefix - // [676] rom_get_version_text::release#1 = main::rom_file_release_id#0 -- vbum1=vbum2 - lda rom_file_release_id - sta rom_get_version_text.release - // [677] rom_get_version_text::github#1 = main::rom_file_github_id#0 - // [678] call rom_get_version_text - // [2053] phi from main::@150 to rom_get_version_text [phi:main::@150->rom_get_version_text] - // [2053] phi rom_get_version_text::github#2 = rom_get_version_text::github#1 [phi:main::@150->rom_get_version_text#0] -- register_copy - // [2053] phi rom_get_version_text::release#2 = rom_get_version_text::release#1 [phi:main::@150->rom_get_version_text#1] -- register_copy - // [2053] phi rom_get_version_text::prefix#2 = rom_get_version_text::prefix#1 [phi:main::@150->rom_get_version_text#2] -- register_copy - // [2053] phi rom_get_version_text::release_info#2 = main::rom_file_release_text [phi:main::@150->rom_get_version_text#3] -- pbuz1=pbuc1 - lda #rom_file_release_text - sta.z rom_get_version_text.release_info+1 - jsr rom_get_version_text - // [679] phi from main::@150 to main::@151 [phi:main::@150->main::@151] - // main::@151 - // sprintf(info_text, "%s:%s", file, rom_file_release_text) - // [680] call snprintf_init - // [1205] phi from main::@151 to snprintf_init [phi:main::@151->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:main::@151->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 - jsr snprintf_init - // main::@152 - // sprintf(info_text, "%s:%s", file, rom_file_release_text) - // [681] printf_string::str#23 = main::file#0 -- pbuz1=pbum2 - lda file - sta.z printf_string.str - lda file+1 - sta.z printf_string.str+1 - // [682] call printf_string - // [1219] phi from main::@152 to printf_string [phi:main::@152->printf_string] - // [1219] phi printf_string::putc#26 = &snputc [phi:main::@152->printf_string#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#23 [phi:main::@152->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 0 [phi:main::@152->printf_string#2] -- vbum1=vbuc1 - lda #0 - sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = 0 [phi:main::@152->printf_string#3] -- vbum1=vbuc1 - sta printf_string.format_min_length - jsr printf_string - // [683] phi from main::@152 to main::@153 [phi:main::@152->main::@153] - // main::@153 - // sprintf(info_text, "%s:%s", file, rom_file_release_text) - // [684] call printf_str - // [1210] phi from main::@153 to printf_str [phi:main::@153->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main::@153->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s2 [phi:main::@153->printf_str#1] -- pbuz1=pbuc1 - lda #<@s2 - sta.z printf_str.s - lda #>@s2 - sta.z printf_str.s+1 - jsr printf_str - // [685] phi from main::@153 to main::@154 [phi:main::@153->main::@154] - // main::@154 - // sprintf(info_text, "%s:%s", file, rom_file_release_text) - // [686] call printf_string - // [1219] phi from main::@154 to printf_string [phi:main::@154->printf_string] - // [1219] phi printf_string::putc#26 = &snputc [phi:main::@154->printf_string#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = main::rom_file_release_text [phi:main::@154->printf_string#1] -- pbuz1=pbuc1 - lda #rom_file_release_text - sta.z printf_string.str+1 - // [1219] phi printf_string::format_justify_left#26 = 0 [phi:main::@154->printf_string#2] -- vbum1=vbuc1 - lda #0 - sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = 0 [phi:main::@154->printf_string#3] -- vbum1=vbuc1 - sta printf_string.format_min_length - jsr printf_string - // main::@155 - // sprintf(info_text, "%s:%s", file, rom_file_release_text) - // [687] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 - lda #0 - pha - // [688] callexecute snputc -- call_vprc1 - jsr snputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // display_info_rom(rom_chip, STATUS_FLASH, info_text) - // [690] display_info_rom::rom_chip#9 = main::rom_chip2#10 -- vbum1=vbuz2 - lda.z rom_chip2 - sta display_info_rom.rom_chip - // [691] call display_info_rom - // [1546] phi from main::@155 to display_info_rom [phi:main::@155->display_info_rom] - // [1546] phi display_info_rom::info_text#17 = info_text [phi:main::@155->display_info_rom#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z display_info_rom.info_text - lda #>@info_text - sta.z display_info_rom.info_text+1 - // [1546] phi display_info_rom::rom_chip#17 = display_info_rom::rom_chip#9 [phi:main::@155->display_info_rom#1] -- register_copy - // [1546] phi display_info_rom::info_status#17 = STATUS_FLASH [phi:main::@155->display_info_rom#2] -- vbum1=vbuc1 - lda #STATUS_FLASH - sta display_info_rom.info_status - jsr display_info_rom - // [692] phi from main::@144 main::@148 main::@155 main::@72 to main::@30 [phi:main::@144/main::@148/main::@155/main::@72->main::@30] - // [692] phi __stdio_filecount#404 = __stdio_filecount#12 [phi:main::@144/main::@148/main::@155/main::@72->main::@30#0] -- register_copy - // [692] phi __errno#389 = __errno#123 [phi:main::@144/main::@148/main::@155/main::@72->main::@30#1] -- register_copy - // main::@30 - __b30: - // for(unsigned char rom_chip = 0; rom_chip < 8; rom_chip++) - // [693] main::rom_chip2#1 = ++ main::rom_chip2#10 -- vbuz1=_inc_vbuz1 - inc.z rom_chip2 - // [180] phi from main::@30 to main::@29 [phi:main::@30->main::@29] - // [180] phi __stdio_filecount#111 = __stdio_filecount#404 [phi:main::@30->main::@29#0] -- register_copy - // [180] phi __errno#115 = __errno#389 [phi:main::@30->main::@29#1] -- register_copy - // [180] phi main::rom_chip2#10 = main::rom_chip2#1 [phi:main::@30->main::@29#2] -- register_copy - jmp __b29 - // [694] phi from main::@34 to main::@32 [phi:main::@34->main::@32] - // main::@32 - __b32: - // sprintf(info_text, "File %s size error!", file) - // [695] call snprintf_init - // [1205] phi from main::@32 to snprintf_init [phi:main::@32->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:main::@32->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 - jsr snprintf_init - // [696] phi from main::@32 to main::@145 [phi:main::@32->main::@145] - // main::@145 - // sprintf(info_text, "File %s size error!", file) - // [697] call printf_str - // [1210] phi from main::@145 to printf_str [phi:main::@145->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main::@145->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main::s8 [phi:main::@145->printf_str#1] -- pbuz1=pbuc1 - lda #s8 - sta.z printf_str.s+1 - jsr printf_str - // main::@146 - // sprintf(info_text, "File %s size error!", file) - // [698] printf_string::str#22 = main::file#0 -- pbuz1=pbum2 - lda file - sta.z printf_string.str - lda file+1 - sta.z printf_string.str+1 - // [699] call printf_string - // [1219] phi from main::@146 to printf_string [phi:main::@146->printf_string] - // [1219] phi printf_string::putc#26 = &snputc [phi:main::@146->printf_string#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#22 [phi:main::@146->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 0 [phi:main::@146->printf_string#2] -- vbum1=vbuc1 - lda #0 - sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = 0 [phi:main::@146->printf_string#3] -- vbum1=vbuc1 - sta printf_string.format_min_length - jsr printf_string - // [700] phi from main::@146 to main::@147 [phi:main::@146->main::@147] - // main::@147 - // sprintf(info_text, "File %s size error!", file) - // [701] call printf_str - // [1210] phi from main::@147 to printf_str [phi:main::@147->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main::@147->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main::s9 [phi:main::@147->printf_str#1] -- pbuz1=pbuc1 - lda #s9 - sta.z printf_str.s+1 - jsr printf_str - // main::@148 - // sprintf(info_text, "File %s size error!", file) - // [702] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 - lda #0 - pha - // [703] callexecute snputc -- call_vprc1 - jsr snputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // display_info_rom(rom_chip, STATUS_ISSUE, info_text) - // [705] display_info_rom::rom_chip#8 = main::rom_chip2#10 -- vbum1=vbuz2 - lda.z rom_chip2 - sta display_info_rom.rom_chip - // [706] call display_info_rom - // [1546] phi from main::@148 to display_info_rom [phi:main::@148->display_info_rom] - // [1546] phi display_info_rom::info_text#17 = info_text [phi:main::@148->display_info_rom#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z display_info_rom.info_text - lda #>@info_text - sta.z display_info_rom.info_text+1 - // [1546] phi display_info_rom::rom_chip#17 = display_info_rom::rom_chip#8 [phi:main::@148->display_info_rom#1] -- register_copy - // [1546] phi display_info_rom::info_status#17 = STATUS_ISSUE [phi:main::@148->display_info_rom#2] -- vbum1=vbuc1 - lda #STATUS_ISSUE - sta display_info_rom.info_status - jsr display_info_rom - jmp __b30 - // [707] phi from main::@141 to main::@31 [phi:main::@141->main::@31] - // main::@31 - __b31: - // sprintf(info_text, "No %s", file) - // [708] call snprintf_init - // [1205] phi from main::@31 to snprintf_init [phi:main::@31->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:main::@31->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 - jsr snprintf_init - // [709] phi from main::@31 to main::@142 [phi:main::@31->main::@142] - // main::@142 - // sprintf(info_text, "No %s", file) - // [710] call printf_str - // [1210] phi from main::@142 to printf_str [phi:main::@142->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main::@142->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main::s7 [phi:main::@142->printf_str#1] -- pbuz1=pbuc1 - lda #s7 - sta.z printf_str.s+1 - jsr printf_str - // main::@143 - // sprintf(info_text, "No %s", file) - // [711] printf_string::str#21 = main::file#0 -- pbuz1=pbum2 - lda file - sta.z printf_string.str - lda file+1 - sta.z printf_string.str+1 - // [712] call printf_string - // [1219] phi from main::@143 to printf_string [phi:main::@143->printf_string] - // [1219] phi printf_string::putc#26 = &snputc [phi:main::@143->printf_string#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#21 [phi:main::@143->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 0 [phi:main::@143->printf_string#2] -- vbum1=vbuc1 - lda #0 - sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = 0 [phi:main::@143->printf_string#3] -- vbum1=vbuc1 - sta printf_string.format_min_length - jsr printf_string - // main::@144 - // sprintf(info_text, "No %s", file) - // [713] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 - lda #0 - pha - // [714] callexecute snputc -- call_vprc1 - jsr snputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // display_info_rom(rom_chip, STATUS_SKIP, info_text) - // [716] display_info_rom::rom_chip#7 = main::rom_chip2#10 -- vbum1=vbuz2 - lda.z rom_chip2 + sta.z strcpy.destination+1 + // [431] call strcpy + // [1117] phi from main::@11 to strcpy [phi:main::@11->strcpy] + // [1117] phi strcpy::dst#0 = strcpy::destination#1 [phi:main::@11->strcpy#0] -- register_copy + // [1117] phi strcpy::src#0 = main::source [phi:main::@11->strcpy#1] -- pbuz1=pbuc1 + lda #source + sta.z strcpy.src+1 + jsr strcpy + // main::@58 + // display_info_rom(rom_chip, STATUS_NONE, NULL) + // [432] display_info_rom::rom_chip#2 = main::rom_chip#2 -- vbum1=vbuz2 + lda.z rom_chip sta display_info_rom.rom_chip - // [717] call display_info_rom - // [1546] phi from main::@144 to display_info_rom [phi:main::@144->display_info_rom] - // [1546] phi display_info_rom::info_text#17 = info_text [phi:main::@144->display_info_rom#0] -- pbuz1=pbuc1 - lda #<@info_text + // [433] call display_info_rom + // [1067] phi from main::@58 to display_info_rom [phi:main::@58->display_info_rom] + // [1067] phi display_info_rom::info_text#10 = 0 [phi:main::@58->display_info_rom#0] -- pbuz1=vbuc1 + lda #<0 sta.z display_info_rom.info_text - lda #>@info_text sta.z display_info_rom.info_text+1 - // [1546] phi display_info_rom::rom_chip#17 = display_info_rom::rom_chip#7 [phi:main::@144->display_info_rom#1] -- register_copy - // [1546] phi display_info_rom::info_status#17 = STATUS_SKIP [phi:main::@144->display_info_rom#2] -- vbum1=vbuc1 - lda #STATUS_SKIP + // [1067] phi display_info_rom::rom_chip#10 = display_info_rom::rom_chip#2 [phi:main::@58->display_info_rom#1] -- register_copy + // [1067] phi display_info_rom::info_status#10 = STATUS_NONE [phi:main::@58->display_info_rom#2] -- vbum1=vbuc1 + lda #STATUS_NONE sta display_info_rom.info_status jsr display_info_rom - jmp __b30 - // main::@28 - __b28: - // [718] smc_bootloader#513 = smc_bootloader#0 -- vwum1=vwum2 - lda smc_bootloader - sta smc_bootloader_1 - lda smc_bootloader+1 - sta smc_bootloader_1+1 - // display_info_smc(STATUS_ISSUE, "SMC.BIN too large!") - // [719] call display_info_smc - // SF3 | size SMC.BIN is > 0x1E00 | Display SMC.BIN file size issue and don't flash. Ask the user to place a correct SMC.BIN file onto the SDcard. | Issue - // [962] phi from main::@28 to display_info_smc [phi:main::@28->display_info_smc] - // [962] phi display_info_smc::info_text#20 = main::info_text5 [phi:main::@28->display_info_smc#0] -- pbuz1=pbuc1 - lda #info_text5 - sta.z display_info_smc.info_text+1 - // [962] phi smc_bootloader#14 = smc_bootloader#513 [phi:main::@28->display_info_smc#1] -- register_copy - // [962] phi display_info_smc::info_status#20 = STATUS_ISSUE [phi:main::@28->display_info_smc#2] -- vbum1=vbuc1 - lda #STATUS_ISSUE - sta display_info_smc.info_status - jsr display_info_smc - // [169] phi from main::@27 main::@28 to main::CLI2 [phi:main::@27/main::@28->main::CLI2] - __b11: - // [169] phi smc_file_minor#301 = 0 [phi:main::@27/main::@28->main::CLI2#0] -- vbum1=vbuc1 - lda #0 - sta smc_file_minor - // [169] phi smc_file_major#301 = 0 [phi:main::@27/main::@28->main::CLI2#1] -- vbum1=vbuc1 - sta smc_file_major - // [169] phi smc_file_release#301 = 0 [phi:main::@27/main::@28->main::CLI2#2] -- vbum1=vbuc1 - sta smc_file_release - // [169] phi __stdio_filecount#109 = __stdio_filecount#39 [phi:main::@27/main::@28->main::CLI2#3] -- register_copy - // [169] phi __errno#113 = __errno#123 [phi:main::@27/main::@28->main::CLI2#4] -- register_copy - jmp CLI2 - // main::@27 - __b27: - // [720] smc_bootloader#512 = smc_bootloader#0 -- vwum1=vwum2 - lda smc_bootloader - sta smc_bootloader_1 - lda smc_bootloader+1 - sta smc_bootloader_1+1 - // display_info_smc(STATUS_SKIP, "No SMC.BIN!") - // [721] call display_info_smc - // SF1 | no SMC.BIN | Ask user to place an SMC.BIN file onto the SDcard and don't flash. | Issue - // SF2 | size SMC.BIN is 0 | Ask user to place an SMC.BIN file onto the SDcard and don't flash. | Issue - // [962] phi from main::@27 to display_info_smc [phi:main::@27->display_info_smc] - // [962] phi display_info_smc::info_text#20 = main::info_text4 [phi:main::@27->display_info_smc#0] -- pbuz1=pbuc1 - lda #info_text4 - sta.z display_info_smc.info_text+1 - // [962] phi smc_bootloader#14 = smc_bootloader#512 [phi:main::@27->display_info_smc#1] -- register_copy - // [962] phi display_info_smc::info_status#20 = STATUS_SKIP [phi:main::@27->display_info_smc#2] -- vbum1=vbuc1 - lda #STATUS_SKIP - sta display_info_smc.info_status - jsr display_info_smc - jmp __b11 - // main::@21 - __b21: - // if(rom_device_ids[rom_chip] != UNKNOWN) - // [722] if(rom_device_ids[main::rom_chip1#10]!=$55) goto main::@22 -- pbuc1_derefidx_vbuz1_neq_vbuc2_then_la1 - lda #$55 - ldy.z rom_chip1 - cmp rom_device_ids,y - bne __b22 - // main::@23 - __b23: - // for(unsigned char rom_chip = 0; rom_chip < 8; rom_chip++) - // [723] main::rom_chip1#1 = ++ main::rom_chip1#10 -- vbuz1=_inc_vbuz1 - inc.z rom_chip1 - // [136] phi from main::@23 to main::@20 [phi:main::@23->main::@20] - // [136] phi main::rom_chip1#10 = main::rom_chip1#1 [phi:main::@23->main::@20#0] -- register_copy - jmp __b20 - // main::@22 - __b22: - // bank_set_brom(rom_chip*32) - // [724] main::bank_set_brom2_bank#0 = main::rom_chip1#10 << 5 -- vbum1=vbuz2_rol_5 - lda.z rom_chip1 - asl - asl - asl - asl - asl - sta bank_set_brom2_bank - // main::bank_set_brom2 - // BROM = bank - // [725] BROM = main::bank_set_brom2_bank#0 -- vbuz1=vbum2 - sta.z BROM - // main::@70 - // rom_chip*8 - // [726] main::$115 = main::rom_chip1#10 << 3 -- vbum1=vbuz2_rol_3 - lda.z rom_chip1 - asl - asl - asl - sta main__115 - // rom_get_github_commit_id(&rom_github[rom_chip*8], (char*)0xC000) - // [727] rom_get_github_commit_id::commit_id#1 = rom_github + main::$115 -- pbuz1=pbuc1_plus_vbum2 - clc - adc #rom_github - adc #0 - sta.z rom_get_github_commit_id.commit_id+1 - // [728] call rom_get_github_commit_id - // [2069] phi from main::@70 to rom_get_github_commit_id [phi:main::@70->rom_get_github_commit_id] - // [2069] phi rom_get_github_commit_id::commit_id#6 = rom_get_github_commit_id::commit_id#1 [phi:main::@70->rom_get_github_commit_id#0] -- register_copy - // [2069] phi rom_get_github_commit_id::from#6 = (char *) 49152 [phi:main::@70->rom_get_github_commit_id#1] -- pbuz1=pbuc1 - lda #<$c000 - sta.z rom_get_github_commit_id.from - lda #>$c000 - sta.z rom_get_github_commit_id.from+1 - jsr rom_get_github_commit_id - // main::@123 - // rom_get_release(*((char*)0xFF80)) - // [729] rom_get_release::release#1 = *((char *) 65408) -- vbum1=_deref_pbuc1 - lda $ff80 - sta rom_get_release.release - // [730] call rom_get_release - // [2037] phi from main::@123 to rom_get_release [phi:main::@123->rom_get_release] - // [2037] phi rom_get_release::release#3 = rom_get_release::release#1 [phi:main::@123->rom_get_release#0] -- register_copy - jsr rom_get_release - // rom_get_release(*((char*)0xFF80)) - // [731] rom_get_release::return#2 = rom_get_release::return#0 - // main::@124 - // [732] main::$111 = rom_get_release::return#2 -- vbuz1=vbum2 - lda rom_get_release.return - sta.z main__111 - // rom_release[rom_chip] = rom_get_release(*((char*)0xFF80)) - // [733] rom_release[main::rom_chip1#10] = main::$111 -- pbuc1_derefidx_vbuz1=vbuz2 - ldy.z rom_chip1 - sta rom_release,y - // rom_get_prefix(*((char*)0xFF80)) - // [734] rom_get_prefix::release#0 = *((char *) 65408) -- vbum1=_deref_pbuc1 - lda $ff80 - sta rom_get_prefix.release - // [735] call rom_get_prefix - // [2044] phi from main::@124 to rom_get_prefix [phi:main::@124->rom_get_prefix] - // [2044] phi rom_get_prefix::release#2 = rom_get_prefix::release#0 [phi:main::@124->rom_get_prefix#0] -- register_copy - jsr rom_get_prefix - // rom_get_prefix(*((char*)0xFF80)) - // [736] rom_get_prefix::return#2 = rom_get_prefix::return#0 - // main::@125 - // [737] main::$112 = rom_get_prefix::return#2 -- vbuz1=vbum2 - lda rom_get_prefix.return - sta.z main__112 - // rom_prefix[rom_chip] = rom_get_prefix(*((char*)0xFF80)) - // [738] rom_prefix[main::rom_chip1#10] = main::$112 -- pbuc1_derefidx_vbuz1=vbuz2 - ldy.z rom_chip1 - sta rom_prefix,y - // rom_chip*13 - // [739] main::$375 = main::rom_chip1#10 << 1 -- vbuz1=vbuz2_rol_1 - tya - asl - sta.z main__375 - // [740] main::$376 = main::$375 + main::rom_chip1#10 -- vbuz1=vbuz1_plus_vbuz2 - lda.z main__376 - clc - adc.z rom_chip1 - sta.z main__376 - // [741] main::$377 = main::$376 << 2 -- vbuz1=vbuz1_rol_2 - lda.z main__377 - asl - asl - sta.z main__377 - // [742] main::$113 = main::$377 + main::rom_chip1#10 -- vbuz1=vbuz1_plus_vbuz2 - lda.z main__113 - clc - adc.z rom_chip1 - sta.z main__113 - // rom_get_version_text(&rom_release_text[rom_chip*13], rom_prefix[rom_chip], rom_release[rom_chip], &rom_github[rom_chip*8]) - // [743] rom_get_version_text::release_info#0 = rom_release_text + main::$113 -- pbuz1=pbuc1_plus_vbuz2 - clc - adc #rom_release_text - adc #0 - sta.z rom_get_version_text.release_info+1 - // [744] rom_get_version_text::github#0 = rom_github + main::$115 -- pbuz1=pbuc1_plus_vbum2 - lda main__115 - clc - adc #rom_github - adc #0 - sta.z rom_get_version_text.github+1 - // [745] rom_get_version_text::prefix#0 = rom_prefix[main::rom_chip1#10] -- vbum1=pbuc1_derefidx_vbuz2 - lda rom_prefix,y - sta rom_get_version_text.prefix - // [746] rom_get_version_text::release#0 = rom_release[main::rom_chip1#10] -- vbum1=pbuc1_derefidx_vbuz2 - lda rom_release,y - sta rom_get_version_text.release - // [747] call rom_get_version_text - // [2053] phi from main::@125 to rom_get_version_text [phi:main::@125->rom_get_version_text] - // [2053] phi rom_get_version_text::github#2 = rom_get_version_text::github#0 [phi:main::@125->rom_get_version_text#0] -- register_copy - // [2053] phi rom_get_version_text::release#2 = rom_get_version_text::release#0 [phi:main::@125->rom_get_version_text#1] -- register_copy - // [2053] phi rom_get_version_text::prefix#2 = rom_get_version_text::prefix#0 [phi:main::@125->rom_get_version_text#2] -- register_copy - // [2053] phi rom_get_version_text::release_info#2 = rom_get_version_text::release_info#0 [phi:main::@125->rom_get_version_text#3] -- register_copy - jsr rom_get_version_text - // main::@126 - // display_info_rom(rom_chip, STATUS_DETECTED, NULL) - // [748] display_info_rom::rom_chip#6 = main::rom_chip1#10 -- vbum1=vbuz2 - lda.z rom_chip1 - sta display_info_rom.rom_chip - // [749] call display_info_rom - // [1546] phi from main::@126 to display_info_rom [phi:main::@126->display_info_rom] - // [1546] phi display_info_rom::info_text#17 = 0 [phi:main::@126->display_info_rom#0] -- pbuz1=vbuc1 - lda #<0 - sta.z display_info_rom.info_text - sta.z display_info_rom.info_text+1 - // [1546] phi display_info_rom::rom_chip#17 = display_info_rom::rom_chip#6 [phi:main::@126->display_info_rom#1] -- register_copy - // [1546] phi display_info_rom::info_status#17 = STATUS_DETECTED [phi:main::@126->display_info_rom#2] -- vbum1=vbuc1 - lda #STATUS_DETECTED - sta display_info_rom.info_status - jsr display_info_rom - jmp __b23 - // [750] phi from main::@16 to main::@19 [phi:main::@16->main::@19] - // main::@19 - __b19: - // sprintf(info_text, "Bootloader v%02x invalid! !", smc_bootloader) - // [751] call snprintf_init - // [1205] phi from main::@19 to snprintf_init [phi:main::@19->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:main::@19->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 - jsr snprintf_init - // [752] phi from main::@19 to main::@113 [phi:main::@19->main::@113] - // main::@113 - // sprintf(info_text, "Bootloader v%02x invalid! !", smc_bootloader) - // [753] call printf_str - // [1210] phi from main::@113 to printf_str [phi:main::@113->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main::@113->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main::s2 [phi:main::@113->printf_str#1] -- pbuz1=pbuc1 - lda #s2 - sta.z printf_str.s+1 - jsr printf_str - // main::@114 - // sprintf(info_text, "Bootloader v%02x invalid! !", smc_bootloader) - // [754] printf_uint::uvalue#7 = smc_bootloader#0 -- vwum1=vwum2 - lda smc_bootloader - sta printf_uint.uvalue - lda smc_bootloader+1 - sta printf_uint.uvalue+1 - // [755] call printf_uint - // [2086] phi from main::@114 to printf_uint [phi:main::@114->printf_uint] - // [2086] phi printf_uint::format_zero_padding#10 = 1 [phi:main::@114->printf_uint#0] -- vbum1=vbuc1 - lda #1 - sta printf_uint.format_zero_padding - // [2086] phi printf_uint::format_min_length#10 = 2 [phi:main::@114->printf_uint#1] -- vbum1=vbuc1 - lda #2 - sta printf_uint.format_min_length - // [2086] phi printf_uint::putc#10 = &snputc [phi:main::@114->printf_uint#2] -- pprz1=pprc1 - lda #snputc - sta.z printf_uint.putc+1 - // [2086] phi printf_uint::format_radix#10 = HEXADECIMAL [phi:main::@114->printf_uint#3] -- vbum1=vbuc1 - lda #HEXADECIMAL - sta printf_uint.format_radix - // [2086] phi printf_uint::uvalue#10 = printf_uint::uvalue#7 [phi:main::@114->printf_uint#4] -- register_copy - jsr printf_uint - // [756] phi from main::@114 to main::@115 [phi:main::@114->main::@115] - // main::@115 - // sprintf(info_text, "Bootloader v%02x invalid! !", smc_bootloader) - // [757] call printf_str - // [1210] phi from main::@115 to printf_str [phi:main::@115->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main::@115->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main::s3 [phi:main::@115->printf_str#1] -- pbuz1=pbuc1 - lda #s3 - sta.z printf_str.s+1 - jsr printf_str - // main::@116 - // sprintf(info_text, "Bootloader v%02x invalid! !", smc_bootloader) - // [758] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 - lda #0 - pha - // [759] callexecute snputc -- call_vprc1 - jsr snputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // [761] smc_bootloader#502 = smc_bootloader#0 -- vwum1=vwum2 - lda smc_bootloader - sta smc_bootloader_1 - lda smc_bootloader+1 - sta smc_bootloader_1+1 - // display_info_smc(STATUS_ISSUE, info_text) - // [762] call display_info_smc - // [962] phi from main::@116 to display_info_smc [phi:main::@116->display_info_smc] - // [962] phi display_info_smc::info_text#20 = info_text [phi:main::@116->display_info_smc#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z display_info_smc.info_text - lda #>@info_text - sta.z display_info_smc.info_text+1 - // [962] phi smc_bootloader#14 = smc_bootloader#502 [phi:main::@116->display_info_smc#1] -- register_copy - // [962] phi display_info_smc::info_status#20 = STATUS_ISSUE [phi:main::@116->display_info_smc#2] -- vbum1=vbuc1 - lda #STATUS_ISSUE - sta display_info_smc.info_status - jsr display_info_smc - // [763] phi from main::@116 to main::@117 [phi:main::@116->main::@117] - // main::@117 - // display_progress_text(display_no_valid_smc_bootloader_text, display_no_valid_smc_bootloader_count) - // [764] call display_progress_text - // Bootloader is not supported by this utility, but is not error. - // [1331] phi from main::@117 to display_progress_text [phi:main::@117->display_progress_text] - // [1331] phi display_progress_text::text#13 = display_no_valid_smc_bootloader_text [phi:main::@117->display_progress_text#0] -- qbuz1=qbuc1 - lda #display_no_valid_smc_bootloader_text - sta.z display_progress_text.text+1 - // [1331] phi display_progress_text::lines#12 = display_no_valid_smc_bootloader_count [phi:main::@117->display_progress_text#1] -- vbum1=vbuc1 - lda #display_no_valid_smc_bootloader_count - sta display_progress_text.lines - jsr display_progress_text - // [129] phi from main::@112 main::@117 main::@18 to main::@2 [phi:main::@112/main::@117/main::@18->main::@2] - __b14: - // [129] phi smc_minor#398 = 0 [phi:main::@112/main::@117/main::@18->main::@2#0] -- vbum1=vbuc1 - lda #0 - sta smc_minor - // [129] phi smc_major#399 = 0 [phi:main::@112/main::@117/main::@18->main::@2#1] -- vbum1=vbuc1 - sta smc_major - // [129] phi smc_release#400 = 0 [phi:main::@112/main::@117/main::@18->main::@2#2] -- vbum1=vbuc1 - sta smc_release - jmp __b2 - // main::@18 - __b18: - // [765] smc_bootloader#511 = smc_bootloader#0 -- vwum1=vwum2 - lda smc_bootloader - sta smc_bootloader_1 - lda smc_bootloader+1 - sta smc_bootloader_1+1 - // display_info_smc(STATUS_ERROR, "SMC Unreachable!") - // [766] call display_info_smc - // SD2 | SMC chip not detected | Display that the SMC chip is not detected and set SMC to Error. | Error - // [962] phi from main::@18 to display_info_smc [phi:main::@18->display_info_smc] - // [962] phi display_info_smc::info_text#20 = main::info_text2 [phi:main::@18->display_info_smc#0] -- pbuz1=pbuc1 - lda #info_text2 - sta.z display_info_smc.info_text+1 - // [962] phi smc_bootloader#14 = smc_bootloader#511 [phi:main::@18->display_info_smc#1] -- register_copy - // [962] phi display_info_smc::info_status#20 = STATUS_ERROR [phi:main::@18->display_info_smc#2] -- vbum1=vbuc1 - lda #STATUS_ERROR - sta display_info_smc.info_status - jsr display_info_smc - jmp __b14 - // main::@1 - __b1: - // [767] smc_bootloader#500 = smc_bootloader#0 -- vwum1=vwum2 - lda smc_bootloader - sta smc_bootloader_1 - lda smc_bootloader+1 - sta smc_bootloader_1+1 - // display_info_smc(STATUS_ISSUE, "No Bootloader!") - // [768] call display_info_smc - // SD1 | No Bootloader | Display that there is no bootloader and set SMC to Issue. | Issue - // [962] phi from main::@1 to display_info_smc [phi:main::@1->display_info_smc] - // [962] phi display_info_smc::info_text#20 = main::info_text1 [phi:main::@1->display_info_smc#0] -- pbuz1=pbuc1 - lda #info_text1 - sta.z display_info_smc.info_text+1 - // [962] phi smc_bootloader#14 = smc_bootloader#500 [phi:main::@1->display_info_smc#1] -- register_copy - // [962] phi display_info_smc::info_status#20 = STATUS_ISSUE [phi:main::@1->display_info_smc#2] -- vbum1=vbuc1 - lda #STATUS_ISSUE - sta display_info_smc.info_status - jsr display_info_smc - // [769] phi from main::@1 to main::@112 [phi:main::@1->main::@112] - // main::@112 - // display_progress_text(display_no_valid_smc_bootloader_text, display_no_valid_smc_bootloader_count) - // [770] call display_progress_text - // If the CX16 board does not have a bootloader, display info how to flash bootloader. - // [1331] phi from main::@112 to display_progress_text [phi:main::@112->display_progress_text] - // [1331] phi display_progress_text::text#13 = display_no_valid_smc_bootloader_text [phi:main::@112->display_progress_text#0] -- qbuz1=qbuc1 - lda #display_no_valid_smc_bootloader_text - sta.z display_progress_text.text+1 - // [1331] phi display_progress_text::lines#12 = display_no_valid_smc_bootloader_count [phi:main::@112->display_progress_text#1] -- vbum1=vbuc1 - lda #display_no_valid_smc_bootloader_count - sta display_progress_text.lines - jsr display_progress_text - jmp __b14 - // main::@13 - __b13: - // rom_chip*13 - // [771] main::$371 = main::rom_chip#2 << 1 -- vbuz1=vbuz2_rol_1 - lda.z rom_chip - asl - sta.z main__371 - // [772] main::$372 = main::$371 + main::rom_chip#2 -- vbuz1=vbuz1_plus_vbuz2 - lda.z main__372 - clc - adc.z rom_chip - sta.z main__372 - // [773] main::$373 = main::$372 << 2 -- vbuz1=vbuz1_rol_2 - lda.z main__373 - asl - asl - sta.z main__373 - // [774] main::$87 = main::$373 + main::rom_chip#2 -- vbuz1=vbuz1_plus_vbuz2 - lda.z main__87 - clc - adc.z rom_chip - sta.z main__87 - // strcpy(&rom_release_text[rom_chip*13], " " ) - // [775] strcpy::destination#1 = rom_release_text + main::$87 -- pbuz1=pbuc1_plus_vbuz2 - clc - adc #rom_release_text - adc #0 - sta.z strcpy.destination+1 - // [776] call strcpy - // [1066] phi from main::@13 to strcpy [phi:main::@13->strcpy] - // [1066] phi strcpy::dst#0 = strcpy::destination#1 [phi:main::@13->strcpy#0] -- register_copy - // [1066] phi strcpy::src#0 = main::source [phi:main::@13->strcpy#1] -- pbuz1=pbuc1 - lda #source - sta.z strcpy.src+1 - jsr strcpy - // main::@106 - // display_info_rom(rom_chip, STATUS_NONE, NULL) - // [777] display_info_rom::rom_chip#5 = main::rom_chip#2 -- vbum1=vbuz2 - lda.z rom_chip - sta display_info_rom.rom_chip - // [778] call display_info_rom - // [1546] phi from main::@106 to display_info_rom [phi:main::@106->display_info_rom] - // [1546] phi display_info_rom::info_text#17 = 0 [phi:main::@106->display_info_rom#0] -- pbuz1=vbuc1 - lda #<0 - sta.z display_info_rom.info_text - sta.z display_info_rom.info_text+1 - // [1546] phi display_info_rom::rom_chip#17 = display_info_rom::rom_chip#5 [phi:main::@106->display_info_rom#1] -- register_copy - // [1546] phi display_info_rom::info_status#17 = STATUS_NONE [phi:main::@106->display_info_rom#2] -- vbum1=vbuc1 - lda #STATUS_NONE - sta display_info_rom.info_status - jsr display_info_rom - // main::@107 + // main::@59 // for(unsigned char rom_chip=0; rom_chip<8; rom_chip++) - // [779] main::rom_chip#1 = ++ main::rom_chip#2 -- vbuz1=_inc_vbuz1 + // [434] main::rom_chip#1 = ++ main::rom_chip#2 -- vbuz1=_inc_vbuz1 inc.z rom_chip - // [94] phi from main::@107 to main::@12 [phi:main::@107->main::@12] - // [94] phi main::rom_chip#2 = main::rom_chip#1 [phi:main::@107->main::@12#0] -- register_copy - jmp __b12 + // [94] phi from main::@59 to main::@10 [phi:main::@59->main::@10] + // [94] phi main::rom_chip#2 = main::rom_chip#1 [phi:main::@59->main::@10#0] -- register_copy + jmp __b10 .segment Data - smc_file_version_text: .fill $d, 0 - rom_file_release_text: .fill $d, 0 title_text: .text "Commander X16 Update Utility (v3.0.0) " .byte 0 s: .text "# Chip Status Type Curr. Release Update Info" @@ -4984,215 +2633,118 @@ main: { .byte 0 source: .text " " .byte 0 - source1: .text "0.0.0" - .byte 0 - info_text1: .text "No Bootloader!" - .byte 0 - info_text2: .text "SMC Unreachable!" - .byte 0 - s2: .text "Bootloader v" - .byte 0 - s3: .text " invalid! !" - .byte 0 - info_text3: .text "Checking SMC.BIN ..." - .byte 0 - info_text4: .text "No SMC.BIN!" - .byte 0 - info_text5: .text "SMC.BIN too large!" - .byte 0 - s4: .text "SMC.BIN:" - .byte 0 - s5: .text "Checking " + info_text1: .text "SMC update issue!" .byte 0 - s7: .text "No " + info_text2: .text "Issue with SMC!" .byte 0 - s8: .text "File " + info_text3: .text "CX16 ROM update issue, ROM not detected!" .byte 0 - s9: .text " size error!" + info_text4: .text "Issue with main CX16 ROM!" .byte 0 - info_text6: .text "SMC update issue!" + info_text5: .text "Are J1 jumper pins closed?" .byte 0 - info_text7: .text "Issue with SMC!" + info_text6: .text "CX16 ROM update issue!" .byte 0 - info_text8: .text "CX16 ROM update issue, ROM not detected!" + info_text8: .text "Compatibility between ROM.BIN and SMC.BIN can't be assured!" .byte 0 - info_text9: .text "Issue with main CX16 ROM!" - .byte 0 - info_text10: .text "Are J1 jumper pins closed?" - .byte 0 - info_text11: .text "CX16 ROM update issue!" - .byte 0 - info_text13: .text "Compatibility between ROM.BIN and SMC.BIN can't be assured!" - .byte 0 - info_text14: .text "Continue with flashing anyway? [Y/N]" + info_text9: .text "Continue with flashing anyway? [Y/N]" .byte 0 filter: .text "YN" .byte 0 - info_text15: .text "The SMC chip and SMC.BIN versions are equal, no flash required!" + info_text10: .text "The SMC chip and SMC.BIN versions are equal, no flash required!" .byte 0 - info_text16: .text "SMC.BIN and SMC equal." + info_text11: .text "SMC.BIN and SMC equal." .byte 0 - info_text17: .text "Chipsets have been detected and update files validated!" + info_text12: .text "Chipsets have been detected and update files validated!" .byte 0 - info_text18: .text "Continue with update of highlighted chipsets? [Y/N]" + info_text13: .text "Continue with update of highlighted chipsets? [Y/N]" .byte 0 filter1: .text "nyNY" .byte 0 - main__344: .text "nN" - .byte 0 - info_text19: .text "Cancelled" - .byte 0 - info_text22: .text "You have selected not to cancel the update ... " - .byte 0 - info_text23: .text "Reading SMC.BIN ... (.) data, ( ) empty" - .byte 0 - info_text24: .text "Press both POWER/RESET buttons on the CX16 board!" + main__208: .text "nN" .byte 0 - info_text25: .text "Press POWER/RESET!" + info_text14: .text "Cancelled" .byte 0 - info_text27: .text "SMC has errors!" + info_text17: .text "You have selected not to cancel the update ... " .byte 0 - info_text28: .text "POWER/RESET not pressed!" + s2: .text "There was a severe error updating your VERA!" .byte 0 - s11: .text "Reading " + s3: .text @"You are back at the READY prompt without resetting your CX16.\n\n" .byte 0 - s12: .text " ... (.) data ( ) empty" + s4: .text @"Please don't reset or shut down your VERA until you've\n" .byte 0 - info_text29: .text "SMC Update failed!" + s5: .text "managed to either reflash your VERA with the previous firmware " .byte 0 - info_text30: .text "Comparing ... (.) data, (=) same, (*) different." + s6: .text @"or have update successs retrying!\n\n" .byte 0 - s14: .text " flash errors!" + s7: .text @"PLEASE REMOVE THE JP1 JUMPER OR YOUR SDCARD WON'T WORK!\n" .byte 0 - s15: .text "There was a severe error updating your VERA!" + info_text18: .text "No CX16 component has been updated with new firmware!" .byte 0 - s16: .text @"You are back at the READY prompt without resetting your CX16.\n\n" + info_text19: .text "Update Failure! Your CX16 may no longer boot!" .byte 0 - s17: .text @"Please don't reset or shut down your VERA until you've\n" + info_text20: .text "Take a photo of this screen, shut down power and retry!" .byte 0 - s18: .text "managed to either reflash your VERA with the previous firmware " + info_text21: .text "Update issues, your CX16 is not updated!" .byte 0 - s19: .text @"or have update successs retrying!\n\n" - .byte 0 - s20: .text @"PLEASE REMOVE THE JP1 JUMPER OR YOUR SDCARD WON'T WORK!\n" - .byte 0 - info_text33: .text "No CX16 component has been updated with new firmware!" - .byte 0 - info_text34: .text "Update Failure! Your CX16 may no longer boot!" - .byte 0 - info_text35: .text "Take a photo of this screen, shut down power and retry!" - .byte 0 - info_text36: .text "Update issues, your CX16 is not updated!" - .byte 0 - info_text37: .text "Your CX16 update is a success!" + info_text22: .text "Your CX16 update is a success!" .byte 0 text: .text "DON'T DO ANYTHING UNTIL COUNTDOWN FINISHES!" .byte 0 - s22: .text "] Please read carefully the below ..." + s8: .text "[" .byte 0 - s23: .text "Please disconnect your CX16 from power source ..." + s9: .text "] Please read carefully the below ..." .byte 0 - s24: .text "(" + s10: .text "Please disconnect your CX16 from power source ..." .byte 0 - s25: .text ") Your CX16 will reset after countdown ..." + s11: .text "(" + .byte 0 + s12: .text ") Your CX16 will reset after countdown ..." .byte 0 - main__45: .byte 0 - main__62: .byte 0 - main__71: .byte 0 - main__84: .byte 0 - main__115: .byte 0 - main__186: .byte 0 - main__274: .byte 0 - main__279: .byte 0 - main__315: .byte 0 - main__317: .byte 0 - check_status_smc2_main__0: .byte 0 - check_status_cx16_rom1_check_status_rom1_main__0: .byte 0 - check_status_smc3_main__0: .byte 0 - check_status_cx16_rom2_check_status_rom1_main__0: .byte 0 - check_status_smc4_main__0: .byte 0 - check_status_cx16_rom3_check_status_rom1_main__0: .byte 0 - check_status_smc5_main__0: .byte 0 - check_status_cx16_rom4_check_status_rom1_main__0: .byte 0 - check_status_smc6_main__0: .byte 0 - check_status_smc7_main__0: .byte 0 - check_status_vera1_main__0: .byte 0 - check_status_smc8_main__0: .byte 0 - check_status_vera2_main__0: .byte 0 - check_status_vera3_main__0: .byte 0 - check_status_vera4_main__0: .byte 0 - check_status_smc9_main__0: .byte 0 - check_status_cx16_rom5_check_status_rom1_main__0: .byte 0 - check_status_vera5_main__0: .byte 0 - check_status_smc10_main__0: .byte 0 - check_status_cx16_rom6_check_status_rom1_main__0: .byte 0 - check_status_smc13_main__0: .byte 0 - check_status_smc14_main__0: .byte 0 - check_status_vera6_main__0: .byte 0 - check_status_vera7_main__0: .byte 0 - check_status_smc15_main__0: .byte 0 - check_status_vera8_main__0: .byte 0 - check_status_smc16_main__0: .byte 0 - check_status_vera9_main__0: .byte 0 - check_status_smc17_main__0: .byte 0 check_status_smc1_return: .byte 0 - bank_set_brom2_bank: .byte 0 - check_status_smc2_return: .byte 0 check_status_cx16_rom1_check_status_rom1_return: .byte 0 - rom_bank: .byte 0 - file: .word 0 - rom_file_release_id: .byte 0 - check_status_smc3_return: .byte 0 + check_status_smc2_return: .byte 0 check_status_cx16_rom2_check_status_rom1_return: .byte 0 - check_status_smc4_return: .byte 0 + check_status_smc3_return: .byte 0 check_status_cx16_rom3_check_status_rom1_return: .byte 0 - check_status_smc5_return: .byte 0 + check_status_smc4_return: .byte 0 check_status_cx16_rom4_check_status_rom1_return: .byte 0 + check_status_smc5_return: .byte 0 check_status_smc6_return: .byte 0 - ch: .byte 0 - check_status_smc7_return: .byte 0 check_status_vera1_return: .byte 0 - check_status_smc8_return: .byte 0 + check_status_smc7_return: .byte 0 check_status_vera2_return: .byte 0 check_status_vera3_return: .byte 0 check_status_vera4_return: .byte 0 - check_status_smc9_return: .byte 0 + check_status_smc8_return: .byte 0 check_status_cx16_rom5_check_status_rom1_return: .byte 0 check_status_vera5_return: .byte 0 - ch1: .byte 0 + check_status_smc9_return: .byte 0 check_status_smc10_return: .byte 0 - check_status_cx16_rom6_check_status_rom1_return: .byte 0 - check_status_rom1_return: .byte 0 - check_status_smc11_return: .byte 0 - check_status_smc12_return: .byte 0 - rom_bank1: .byte 0 - rom_flash_errors: .dword 0 - check_status_smc13_return: .byte 0 - check_status_smc14_return: .byte 0 check_status_vera6_return: .byte 0 check_status_vera7_return: .byte 0 - check_status_smc15_return: .byte 0 + check_status_smc11_return: .byte 0 check_status_vera8_return: .byte 0 - check_status_smc16_return: .byte 0 + check_status_smc12_return: .byte 0 check_status_vera9_return: .byte 0 - check_status_smc17_return: .byte 0 + check_status_smc13_return: .byte 0 } .segment Code // screenlayer1 // Set the layer with which the conio will interact. screenlayer1: { // screenlayer(1, *VERA_L1_MAPBASE, *VERA_L1_CONFIG) - // [780] screenlayer::mapbase#0 = *VERA_L1_MAPBASE -- vbum1=_deref_pbuc1 + // [435] screenlayer::mapbase#0 = *VERA_L1_MAPBASE -- vbum1=_deref_pbuc1 lda VERA_L1_MAPBASE sta screenlayer.mapbase - // [781] screenlayer::config#0 = *VERA_L1_CONFIG -- vbum1=_deref_pbuc1 + // [436] screenlayer::config#0 = *VERA_L1_CONFIG -- vbum1=_deref_pbuc1 lda VERA_L1_CONFIG sta screenlayer.config - // [782] call screenlayer + // [437] call screenlayer jsr screenlayer // screenlayer1::@return // } - // [783] return + // [438] return rts } // textcolor @@ -5202,24 +2754,24 @@ screenlayer1: { // Note that on the VERA, the transparent color has value 0. // char textcolor(__mem() char color) textcolor: { - .label textcolor__0 = $5c - .label textcolor__1 = $5c + .label textcolor__0 = $55 + .label textcolor__1 = $55 // __conio.color & 0xF0 - // [785] textcolor::$0 = *((char *)&__conio+$d) & $f0 -- vbuz1=_deref_pbuc1_band_vbuc2 + // [440] textcolor::$0 = *((char *)&__conio+$d) & $f0 -- vbuz1=_deref_pbuc1_band_vbuc2 lda #$f0 and __conio+$d sta.z textcolor__0 // __conio.color & 0xF0 | color - // [786] textcolor::$1 = textcolor::$0 | textcolor::color#23 -- vbuz1=vbuz1_bor_vbum2 + // [441] textcolor::$1 = textcolor::$0 | textcolor::color#21 -- vbuz1=vbuz1_bor_vbum2 lda color ora.z textcolor__1 sta.z textcolor__1 // __conio.color = __conio.color & 0xF0 | color - // [787] *((char *)&__conio+$d) = textcolor::$1 -- _deref_pbuc1=vbuz1 + // [442] *((char *)&__conio+$d) = textcolor::$1 -- _deref_pbuc1=vbuz1 sta __conio+$d // textcolor::@return // } - // [788] return + // [443] return rts .segment Data color: .byte 0 @@ -5232,16 +2784,16 @@ textcolor: { // Note that on the VERA, the transparent color has value 0. // char bgcolor(__mem() char color) bgcolor: { - .label bgcolor__0 = $5c - .label bgcolor__1 = $5d - .label bgcolor__2 = $5c + .label bgcolor__0 = $55 + .label bgcolor__1 = $58 + .label bgcolor__2 = $55 // __conio.color & 0x0F - // [790] bgcolor::$0 = *((char *)&__conio+$d) & $f -- vbuz1=_deref_pbuc1_band_vbuc2 + // [445] bgcolor::$0 = *((char *)&__conio+$d) & $f -- vbuz1=_deref_pbuc1_band_vbuc2 lda #$f and __conio+$d sta.z bgcolor__0 // color << 4 - // [791] bgcolor::$1 = bgcolor::color#15 << 4 -- vbuz1=vbum2_rol_4 + // [446] bgcolor::$1 = bgcolor::color#15 << 4 -- vbuz1=vbum2_rol_4 lda color asl asl @@ -5249,16 +2801,16 @@ bgcolor: { asl sta.z bgcolor__1 // __conio.color & 0x0F | color << 4 - // [792] bgcolor::$2 = bgcolor::$0 | bgcolor::$1 -- vbuz1=vbuz1_bor_vbuz2 + // [447] bgcolor::$2 = bgcolor::$0 | bgcolor::$1 -- vbuz1=vbuz1_bor_vbuz2 lda.z bgcolor__2 ora.z bgcolor__1 sta.z bgcolor__2 // __conio.color = __conio.color & 0x0F | color << 4 - // [793] *((char *)&__conio+$d) = bgcolor::$2 -- _deref_pbuc1=vbuz1 + // [448] *((char *)&__conio+$d) = bgcolor::$2 -- _deref_pbuc1=vbuz1 sta __conio+$d // bgcolor::@return // } - // [794] return + // [449] return rts .segment Data color: .byte 0 @@ -5272,12 +2824,12 @@ bgcolor: { cursor: { .const onoff = 0 // __conio.cursor = onoff - // [795] *((char *)&__conio+$c) = cursor::onoff#0 -- _deref_pbuc1=vbuc2 + // [450] *((char *)&__conio+$c) = cursor::onoff#0 -- _deref_pbuc1=vbuc2 lda #onoff sta __conio+$c // cursor::@return // } - // [796] return + // [451] return rts } // cbm_k_plot_get @@ -5287,11 +2839,11 @@ cursor: { */ cbm_k_plot_get: { // __mem unsigned char x - // [797] cbm_k_plot_get::x = 0 -- vbum1=vbuc1 + // [452] cbm_k_plot_get::x = 0 -- vbum1=vbuc1 lda #0 sta x // __mem unsigned char y - // [798] cbm_k_plot_get::y = 0 -- vbum1=vbuc1 + // [453] cbm_k_plot_get::y = 0 -- vbum1=vbuc1 sta y // kickasm // kickasm( uses cbm_k_plot_get::x uses cbm_k_plot_get::y uses CBM_PLOT) {{ sec jsr CBM_PLOT stx y sty x }} @@ -5301,14 +2853,14 @@ cbm_k_plot_get: { sty x // MAKEWORD(x,y) - // [800] cbm_k_plot_get::return#0 = cbm_k_plot_get::x w= cbm_k_plot_get::y -- vwum1=vbum2_word_vbum3 + // [455] cbm_k_plot_get::return#0 = cbm_k_plot_get::x w= cbm_k_plot_get::y -- vwum1=vbum2_word_vbum3 lda x sta return+1 lda y sta return // cbm_k_plot_get::@return // } - // [801] return + // [456] return rts .segment Data x: .byte 0 @@ -5320,63 +2872,63 @@ cbm_k_plot_get: { // Set the cursor to the specified position // void gotoxy(__mem() char x, __mem() char y) gotoxy: { - .label gotoxy__2 = $30 - .label gotoxy__3 = $30 - .label gotoxy__6 = $2f - .label gotoxy__7 = $2f - .label gotoxy__8 = $37 - .label gotoxy__9 = $34 - .label gotoxy__10 = $33 - .label gotoxy__14 = $2f + .label gotoxy__2 = $2c + .label gotoxy__3 = $2c + .label gotoxy__6 = $2b + .label gotoxy__7 = $2b + .label gotoxy__8 = $33 + .label gotoxy__9 = $30 + .label gotoxy__10 = $2f + .label gotoxy__14 = $2b // (x>=__conio.width)?__conio.width:x - // [803] if(gotoxy::x#37>=*((char *)&__conio+6)) goto gotoxy::@1 -- vbum1_ge__deref_pbuc1_then_la1 + // [458] if(gotoxy::x#26>=*((char *)&__conio+6)) goto gotoxy::@1 -- vbum1_ge__deref_pbuc1_then_la1 lda x cmp __conio+6 bcs __b1 - // [805] phi from gotoxy to gotoxy::@2 [phi:gotoxy->gotoxy::@2] - // [805] phi gotoxy::$3 = gotoxy::x#37 [phi:gotoxy->gotoxy::@2#0] -- vbuz1=vbum2 + // [460] phi from gotoxy to gotoxy::@2 [phi:gotoxy->gotoxy::@2] + // [460] phi gotoxy::$3 = gotoxy::x#26 [phi:gotoxy->gotoxy::@2#0] -- vbuz1=vbum2 sta.z gotoxy__3 jmp __b2 // gotoxy::@1 __b1: - // [804] gotoxy::$2 = *((char *)&__conio+6) -- vbuz1=_deref_pbuc1 + // [459] gotoxy::$2 = *((char *)&__conio+6) -- vbuz1=_deref_pbuc1 lda __conio+6 sta.z gotoxy__2 - // [805] phi from gotoxy::@1 to gotoxy::@2 [phi:gotoxy::@1->gotoxy::@2] - // [805] phi gotoxy::$3 = gotoxy::$2 [phi:gotoxy::@1->gotoxy::@2#0] -- register_copy + // [460] phi from gotoxy::@1 to gotoxy::@2 [phi:gotoxy::@1->gotoxy::@2] + // [460] phi gotoxy::$3 = gotoxy::$2 [phi:gotoxy::@1->gotoxy::@2#0] -- register_copy // gotoxy::@2 __b2: // __conio.cursor_x = (x>=__conio.width)?__conio.width:x - // [806] *((char *)&__conio) = gotoxy::$3 -- _deref_pbuc1=vbuz1 + // [461] *((char *)&__conio) = gotoxy::$3 -- _deref_pbuc1=vbuz1 lda.z gotoxy__3 sta __conio // (y>=__conio.height)?__conio.height:y - // [807] if(gotoxy::y#37>=*((char *)&__conio+7)) goto gotoxy::@3 -- vbum1_ge__deref_pbuc1_then_la1 + // [462] if(gotoxy::y#26>=*((char *)&__conio+7)) goto gotoxy::@3 -- vbum1_ge__deref_pbuc1_then_la1 lda y cmp __conio+7 bcs __b3 // gotoxy::@4 - // [808] gotoxy::$14 = gotoxy::y#37 -- vbuz1=vbum2 + // [463] gotoxy::$14 = gotoxy::y#26 -- vbuz1=vbum2 sta.z gotoxy__14 - // [809] phi from gotoxy::@3 gotoxy::@4 to gotoxy::@5 [phi:gotoxy::@3/gotoxy::@4->gotoxy::@5] - // [809] phi gotoxy::$7 = gotoxy::$6 [phi:gotoxy::@3/gotoxy::@4->gotoxy::@5#0] -- register_copy + // [464] phi from gotoxy::@3 gotoxy::@4 to gotoxy::@5 [phi:gotoxy::@3/gotoxy::@4->gotoxy::@5] + // [464] phi gotoxy::$7 = gotoxy::$6 [phi:gotoxy::@3/gotoxy::@4->gotoxy::@5#0] -- register_copy // gotoxy::@5 __b5: // __conio.cursor_y = (y>=__conio.height)?__conio.height:y - // [810] *((char *)&__conio+1) = gotoxy::$7 -- _deref_pbuc1=vbuz1 + // [465] *((char *)&__conio+1) = gotoxy::$7 -- _deref_pbuc1=vbuz1 lda.z gotoxy__7 sta __conio+1 // __conio.cursor_x << 1 - // [811] gotoxy::$8 = *((char *)&__conio) << 1 -- vbuz1=_deref_pbuc1_rol_1 + // [466] gotoxy::$8 = *((char *)&__conio) << 1 -- vbuz1=_deref_pbuc1_rol_1 lda __conio asl sta.z gotoxy__8 // __conio.offsets[y] + __conio.cursor_x << 1 - // [812] gotoxy::$10 = gotoxy::y#37 << 1 -- vbuz1=vbum2_rol_1 + // [467] gotoxy::$10 = gotoxy::y#26 << 1 -- vbuz1=vbum2_rol_1 lda y asl sta.z gotoxy__10 - // [813] gotoxy::$9 = ((unsigned int *)&__conio+$15)[gotoxy::$10] + gotoxy::$8 -- vwuz1=pwuc1_derefidx_vbuz2_plus_vbuz3 + // [468] gotoxy::$9 = ((unsigned int *)&__conio+$15)[gotoxy::$10] + gotoxy::$8 -- vwuz1=pwuc1_derefidx_vbuz2_plus_vbuz3 lda.z gotoxy__8 ldy.z gotoxy__10 clc @@ -5386,19 +2938,19 @@ gotoxy: { adc #0 sta.z gotoxy__9+1 // __conio.offset = __conio.offsets[y] + __conio.cursor_x << 1 - // [814] *((unsigned int *)&__conio+$13) = gotoxy::$9 -- _deref_pwuc1=vwuz1 + // [469] *((unsigned int *)&__conio+$13) = gotoxy::$9 -- _deref_pwuc1=vwuz1 lda.z gotoxy__9 sta __conio+$13 lda.z gotoxy__9+1 sta __conio+$13+1 // gotoxy::@return // } - // [815] return + // [470] return rts // gotoxy::@3 __b3: // (y>=__conio.height)?__conio.height:y - // [816] gotoxy::$6 = *((char *)&__conio+7) -- vbuz1=_deref_pbuc1 + // [471] gotoxy::$6 = *((char *)&__conio+7) -- vbuz1=_deref_pbuc1 lda __conio+7 sta.z gotoxy__6 jmp __b5 @@ -5410,31 +2962,31 @@ gotoxy: { // cputln // Print a newline cputln: { - .label cputln__2 = $49 + .label cputln__2 = $44 // __conio.cursor_x = 0 - // [817] *((char *)&__conio) = 0 -- _deref_pbuc1=vbuc2 + // [472] *((char *)&__conio) = 0 -- _deref_pbuc1=vbuc2 lda #0 sta __conio // __conio.cursor_y++; - // [818] *((char *)&__conio+1) = ++ *((char *)&__conio+1) -- _deref_pbuc1=_inc__deref_pbuc1 + // [473] *((char *)&__conio+1) = ++ *((char *)&__conio+1) -- _deref_pbuc1=_inc__deref_pbuc1 inc __conio+1 // __conio.offset = __conio.offsets[__conio.cursor_y] - // [819] cputln::$2 = *((char *)&__conio+1) << 1 -- vbuz1=_deref_pbuc1_rol_1 + // [474] cputln::$2 = *((char *)&__conio+1) << 1 -- vbuz1=_deref_pbuc1_rol_1 lda __conio+1 asl sta.z cputln__2 - // [820] *((unsigned int *)&__conio+$13) = ((unsigned int *)&__conio+$15)[cputln::$2] -- _deref_pwuc1=pwuc2_derefidx_vbuz1 + // [475] *((unsigned int *)&__conio+$13) = ((unsigned int *)&__conio+$15)[cputln::$2] -- _deref_pwuc1=pwuc2_derefidx_vbuz1 tay lda __conio+$15,y sta __conio+$13 lda __conio+$15+1,y sta __conio+$13+1 // cscroll() - // [821] call cscroll + // [476] call cscroll jsr cscroll // cputln::@return // } - // [822] return + // [477] return rts } // display_frame_init_64 @@ -5446,25 +2998,25 @@ display_frame_init_64: { .const vera_display_set_hstop1_stop = $93 .const vera_display_set_vstart1_start = $13 .const vera_display_set_vstop1_stop = $db - .label cx16_k_screen_set_charset1_offset = $ef + .label cx16_k_screen_set_charset1_offset = $b2 // cx16_k_screen_set_mode(0) - // [823] cx16_k_screen_set_mode::mode = 0 -- vbum1=vbuc1 + // [478] cx16_k_screen_set_mode::mode = 0 -- vbum1=vbuc1 lda #0 sta cx16_k_screen_set_mode.mode - // [824] call cx16_k_screen_set_mode + // [479] call cx16_k_screen_set_mode jsr cx16_k_screen_set_mode - // [825] phi from display_frame_init_64 to display_frame_init_64::@2 [phi:display_frame_init_64->display_frame_init_64::@2] + // [480] phi from display_frame_init_64 to display_frame_init_64::@2 [phi:display_frame_init_64->display_frame_init_64::@2] // display_frame_init_64::@2 // screenlayer1() - // [826] call screenlayer1 + // [481] call screenlayer1 // Default 80 columns mode. jsr screenlayer1 // display_frame_init_64::@3 // cx16_k_screen_set_charset(3, (char *)0) - // [827] display_frame_init_64::cx16_k_screen_set_charset1_charset = 3 -- vbum1=vbuc1 + // [482] display_frame_init_64::cx16_k_screen_set_charset1_charset = 3 -- vbum1=vbuc1 lda #3 sta cx16_k_screen_set_charset1_charset - // [828] display_frame_init_64::cx16_k_screen_set_charset1_offset = (char *) 0 -- pbuz1=pbuc1 + // [483] display_frame_init_64::cx16_k_screen_set_charset1_offset = (char *) 0 -- pbuz1=pbuc1 lda #<0 sta.z cx16_k_screen_set_charset1_offset sta.z cx16_k_screen_set_charset1_offset+1 @@ -5477,107 +3029,107 @@ display_frame_init_64: { jsr CX16_SCREEN_SET_CHARSET // display_frame_init_64::vera_display_set_hstart1 // *VERA_CTRL |= VERA_DCSEL - // [830] *VERA_CTRL = *VERA_CTRL | VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_bor_vbuc2 + // [485] *VERA_CTRL = *VERA_CTRL | VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_bor_vbuc2 lda #VERA_DCSEL ora VERA_CTRL sta VERA_CTRL // *VERA_DC_HSTART = start - // [831] *VERA_DC_HSTART = display_frame_init_64::vera_display_set_hstart1_start#0 -- _deref_pbuc1=vbuc2 + // [486] *VERA_DC_HSTART = display_frame_init_64::vera_display_set_hstart1_start#0 -- _deref_pbuc1=vbuc2 lda #vera_display_set_hstart1_start sta VERA_DC_HSTART // display_frame_init_64::vera_display_set_hstop1 // *VERA_CTRL |= VERA_DCSEL - // [832] *VERA_CTRL = *VERA_CTRL | VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_bor_vbuc2 + // [487] *VERA_CTRL = *VERA_CTRL | VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_bor_vbuc2 lda #VERA_DCSEL ora VERA_CTRL sta VERA_CTRL // *VERA_DC_HSTOP = stop - // [833] *VERA_DC_HSTOP = display_frame_init_64::vera_display_set_hstop1_stop#0 -- _deref_pbuc1=vbuc2 + // [488] *VERA_DC_HSTOP = display_frame_init_64::vera_display_set_hstop1_stop#0 -- _deref_pbuc1=vbuc2 lda #vera_display_set_hstop1_stop sta VERA_DC_HSTOP // display_frame_init_64::vera_display_set_vstart1 // *VERA_CTRL |= VERA_DCSEL - // [834] *VERA_CTRL = *VERA_CTRL | VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_bor_vbuc2 + // [489] *VERA_CTRL = *VERA_CTRL | VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_bor_vbuc2 lda #VERA_DCSEL ora VERA_CTRL sta VERA_CTRL // *VERA_DC_VSTART = start - // [835] *VERA_DC_VSTART = display_frame_init_64::vera_display_set_vstart1_start#0 -- _deref_pbuc1=vbuc2 + // [490] *VERA_DC_VSTART = display_frame_init_64::vera_display_set_vstart1_start#0 -- _deref_pbuc1=vbuc2 lda #vera_display_set_vstart1_start sta VERA_DC_VSTART // display_frame_init_64::vera_display_set_vstop1 // *VERA_CTRL |= VERA_DCSEL - // [836] *VERA_CTRL = *VERA_CTRL | VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_bor_vbuc2 + // [491] *VERA_CTRL = *VERA_CTRL | VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_bor_vbuc2 lda #VERA_DCSEL ora VERA_CTRL sta VERA_CTRL // *VERA_DC_VSTOP = stop - // [837] *VERA_DC_VSTOP = display_frame_init_64::vera_display_set_vstop1_stop#0 -- _deref_pbuc1=vbuc2 + // [492] *VERA_DC_VSTOP = display_frame_init_64::vera_display_set_vstop1_stop#0 -- _deref_pbuc1=vbuc2 lda #vera_display_set_vstop1_stop sta VERA_DC_VSTOP // display_frame_init_64::vera_sprites_hide1 // *VERA_CTRL &= ~VERA_DCSEL - // [838] *VERA_CTRL = *VERA_CTRL & ~VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 + // [493] *VERA_CTRL = *VERA_CTRL & ~VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 lda #VERA_DCSEL^$ff and VERA_CTRL sta VERA_CTRL // *VERA_DC_VIDEO &= ~VERA_SPRITES_ENABLE - // [839] *VERA_DC_VIDEO = *VERA_DC_VIDEO & ~VERA_SPRITES_ENABLE -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 + // [494] *VERA_DC_VIDEO = *VERA_DC_VIDEO & ~VERA_SPRITES_ENABLE -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 lda #VERA_SPRITES_ENABLE^$ff and VERA_DC_VIDEO sta VERA_DC_VIDEO // display_frame_init_64::vera_layer0_hide1 // *VERA_CTRL &= ~VERA_DCSEL - // [840] *VERA_CTRL = *VERA_CTRL & ~VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 + // [495] *VERA_CTRL = *VERA_CTRL & ~VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 lda #VERA_DCSEL^$ff and VERA_CTRL sta VERA_CTRL // *VERA_DC_VIDEO &= ~VERA_LAYER0_ENABLE - // [841] *VERA_DC_VIDEO = *VERA_DC_VIDEO & ~VERA_LAYER0_ENABLE -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 + // [496] *VERA_DC_VIDEO = *VERA_DC_VIDEO & ~VERA_LAYER0_ENABLE -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 lda #VERA_LAYER0_ENABLE^$ff and VERA_DC_VIDEO sta VERA_DC_VIDEO // display_frame_init_64::vera_layer1_show1 // *VERA_CTRL &= ~VERA_DCSEL - // [842] *VERA_CTRL = *VERA_CTRL & ~VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 + // [497] *VERA_CTRL = *VERA_CTRL & ~VERA_DCSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 lda #VERA_DCSEL^$ff and VERA_CTRL sta VERA_CTRL // *VERA_DC_VIDEO |= VERA_LAYER1_ENABLE - // [843] *VERA_DC_VIDEO = *VERA_DC_VIDEO | VERA_LAYER1_ENABLE -- _deref_pbuc1=_deref_pbuc1_bor_vbuc2 + // [498] *VERA_DC_VIDEO = *VERA_DC_VIDEO | VERA_LAYER1_ENABLE -- _deref_pbuc1=_deref_pbuc1_bor_vbuc2 lda #VERA_LAYER1_ENABLE ora VERA_DC_VIDEO sta VERA_DC_VIDEO - // [844] phi from display_frame_init_64::vera_layer1_show1 to display_frame_init_64::@1 [phi:display_frame_init_64::vera_layer1_show1->display_frame_init_64::@1] + // [499] phi from display_frame_init_64::vera_layer1_show1 to display_frame_init_64::@1 [phi:display_frame_init_64::vera_layer1_show1->display_frame_init_64::@1] // display_frame_init_64::@1 // textcolor(WHITE) - // [845] call textcolor + // [500] call textcolor // Layer 1 is the current text canvas. - // [784] phi from display_frame_init_64::@1 to textcolor [phi:display_frame_init_64::@1->textcolor] - // [784] phi textcolor::color#23 = WHITE [phi:display_frame_init_64::@1->textcolor#0] -- vbum1=vbuc1 + // [439] phi from display_frame_init_64::@1 to textcolor [phi:display_frame_init_64::@1->textcolor] + // [439] phi textcolor::color#21 = WHITE [phi:display_frame_init_64::@1->textcolor#0] -- vbum1=vbuc1 lda #WHITE sta textcolor.color jsr textcolor - // [846] phi from display_frame_init_64::@1 to display_frame_init_64::@4 [phi:display_frame_init_64::@1->display_frame_init_64::@4] + // [501] phi from display_frame_init_64::@1 to display_frame_init_64::@4 [phi:display_frame_init_64::@1->display_frame_init_64::@4] // display_frame_init_64::@4 // bgcolor(BLUE) - // [847] call bgcolor + // [502] call bgcolor // Default text color is white. - // [789] phi from display_frame_init_64::@4 to bgcolor [phi:display_frame_init_64::@4->bgcolor] - // [789] phi bgcolor::color#15 = BLUE [phi:display_frame_init_64::@4->bgcolor#0] -- vbum1=vbuc1 + // [444] phi from display_frame_init_64::@4 to bgcolor [phi:display_frame_init_64::@4->bgcolor] + // [444] phi bgcolor::color#15 = BLUE [phi:display_frame_init_64::@4->bgcolor#0] -- vbum1=vbuc1 lda #BLUE sta bgcolor.color jsr bgcolor - // [848] phi from display_frame_init_64::@4 to display_frame_init_64::@5 [phi:display_frame_init_64::@4->display_frame_init_64::@5] + // [503] phi from display_frame_init_64::@4 to display_frame_init_64::@5 [phi:display_frame_init_64::@4->display_frame_init_64::@5] // display_frame_init_64::@5 // clrscr() - // [849] call clrscr + // [504] call clrscr // With a blue background. // cx16-conio.c won't compile scrolling code for this program with the underlying define, resulting in less code overhead! jsr clrscr // display_frame_init_64::@return // } - // [850] return + // [505] return rts .segment Data cx16_k_screen_set_charset1_charset: .byte 0 @@ -5589,328 +3141,328 @@ display_frame_init_64: { */ display_frame_draw: { // textcolor(LIGHT_BLUE) - // [852] call textcolor - // [784] phi from display_frame_draw to textcolor [phi:display_frame_draw->textcolor] - // [784] phi textcolor::color#23 = LIGHT_BLUE [phi:display_frame_draw->textcolor#0] -- vbum1=vbuc1 + // [507] call textcolor + // [439] phi from display_frame_draw to textcolor [phi:display_frame_draw->textcolor] + // [439] phi textcolor::color#21 = LIGHT_BLUE [phi:display_frame_draw->textcolor#0] -- vbum1=vbuc1 lda #LIGHT_BLUE sta textcolor.color jsr textcolor - // [853] phi from display_frame_draw to display_frame_draw::@1 [phi:display_frame_draw->display_frame_draw::@1] + // [508] phi from display_frame_draw to display_frame_draw::@1 [phi:display_frame_draw->display_frame_draw::@1] // display_frame_draw::@1 // bgcolor(BLUE) - // [854] call bgcolor - // [789] phi from display_frame_draw::@1 to bgcolor [phi:display_frame_draw::@1->bgcolor] - // [789] phi bgcolor::color#15 = BLUE [phi:display_frame_draw::@1->bgcolor#0] -- vbum1=vbuc1 + // [509] call bgcolor + // [444] phi from display_frame_draw::@1 to bgcolor [phi:display_frame_draw::@1->bgcolor] + // [444] phi bgcolor::color#15 = BLUE [phi:display_frame_draw::@1->bgcolor#0] -- vbum1=vbuc1 lda #BLUE sta bgcolor.color jsr bgcolor - // [855] phi from display_frame_draw::@1 to display_frame_draw::@2 [phi:display_frame_draw::@1->display_frame_draw::@2] + // [510] phi from display_frame_draw::@1 to display_frame_draw::@2 [phi:display_frame_draw::@1->display_frame_draw::@2] // display_frame_draw::@2 // clrscr() - // [856] call clrscr + // [511] call clrscr jsr clrscr - // [857] phi from display_frame_draw::@2 to display_frame_draw::@3 [phi:display_frame_draw::@2->display_frame_draw::@3] + // [512] phi from display_frame_draw::@2 to display_frame_draw::@3 [phi:display_frame_draw::@2->display_frame_draw::@3] // display_frame_draw::@3 // display_frame(0, 0, 67, 14) - // [858] call display_frame - // [2146] phi from display_frame_draw::@3 to display_frame [phi:display_frame_draw::@3->display_frame] - // [2146] phi display_frame::y#0 = 0 [phi:display_frame_draw::@3->display_frame#0] -- vbum1=vbuc1 + // [513] call display_frame + // [1174] phi from display_frame_draw::@3 to display_frame [phi:display_frame_draw::@3->display_frame] + // [1174] phi display_frame::y#0 = 0 [phi:display_frame_draw::@3->display_frame#0] -- vbum1=vbuc1 lda #0 sta display_frame.y - // [2146] phi display_frame::y1#16 = $e [phi:display_frame_draw::@3->display_frame#1] -- vbum1=vbuc1 + // [1174] phi display_frame::y1#16 = $e [phi:display_frame_draw::@3->display_frame#1] -- vbum1=vbuc1 lda #$e sta display_frame.y1 - // [2146] phi display_frame::x#0 = 0 [phi:display_frame_draw::@3->display_frame#2] -- vbum1=vbuc1 + // [1174] phi display_frame::x#0 = 0 [phi:display_frame_draw::@3->display_frame#2] -- vbum1=vbuc1 lda #0 sta display_frame.x - // [2146] phi display_frame::x1#16 = $43 [phi:display_frame_draw::@3->display_frame#3] -- vbum1=vbuc1 + // [1174] phi display_frame::x1#16 = $43 [phi:display_frame_draw::@3->display_frame#3] -- vbum1=vbuc1 lda #$43 sta display_frame.x1 jsr display_frame - // [859] phi from display_frame_draw::@3 to display_frame_draw::@4 [phi:display_frame_draw::@3->display_frame_draw::@4] + // [514] phi from display_frame_draw::@3 to display_frame_draw::@4 [phi:display_frame_draw::@3->display_frame_draw::@4] // display_frame_draw::@4 // display_frame(0, 0, 67, 2) - // [860] call display_frame - // [2146] phi from display_frame_draw::@4 to display_frame [phi:display_frame_draw::@4->display_frame] - // [2146] phi display_frame::y#0 = 0 [phi:display_frame_draw::@4->display_frame#0] -- vbum1=vbuc1 + // [515] call display_frame + // [1174] phi from display_frame_draw::@4 to display_frame [phi:display_frame_draw::@4->display_frame] + // [1174] phi display_frame::y#0 = 0 [phi:display_frame_draw::@4->display_frame#0] -- vbum1=vbuc1 lda #0 sta display_frame.y - // [2146] phi display_frame::y1#16 = 2 [phi:display_frame_draw::@4->display_frame#1] -- vbum1=vbuc1 + // [1174] phi display_frame::y1#16 = 2 [phi:display_frame_draw::@4->display_frame#1] -- vbum1=vbuc1 lda #2 sta display_frame.y1 - // [2146] phi display_frame::x#0 = 0 [phi:display_frame_draw::@4->display_frame#2] -- vbum1=vbuc1 + // [1174] phi display_frame::x#0 = 0 [phi:display_frame_draw::@4->display_frame#2] -- vbum1=vbuc1 lda #0 sta display_frame.x - // [2146] phi display_frame::x1#16 = $43 [phi:display_frame_draw::@4->display_frame#3] -- vbum1=vbuc1 + // [1174] phi display_frame::x1#16 = $43 [phi:display_frame_draw::@4->display_frame#3] -- vbum1=vbuc1 lda #$43 sta display_frame.x1 jsr display_frame - // [861] phi from display_frame_draw::@4 to display_frame_draw::@5 [phi:display_frame_draw::@4->display_frame_draw::@5] + // [516] phi from display_frame_draw::@4 to display_frame_draw::@5 [phi:display_frame_draw::@4->display_frame_draw::@5] // display_frame_draw::@5 // display_frame(0, 2, 67, 14) - // [862] call display_frame - // [2146] phi from display_frame_draw::@5 to display_frame [phi:display_frame_draw::@5->display_frame] - // [2146] phi display_frame::y#0 = 2 [phi:display_frame_draw::@5->display_frame#0] -- vbum1=vbuc1 + // [517] call display_frame + // [1174] phi from display_frame_draw::@5 to display_frame [phi:display_frame_draw::@5->display_frame] + // [1174] phi display_frame::y#0 = 2 [phi:display_frame_draw::@5->display_frame#0] -- vbum1=vbuc1 lda #2 sta display_frame.y - // [2146] phi display_frame::y1#16 = $e [phi:display_frame_draw::@5->display_frame#1] -- vbum1=vbuc1 + // [1174] phi display_frame::y1#16 = $e [phi:display_frame_draw::@5->display_frame#1] -- vbum1=vbuc1 lda #$e sta display_frame.y1 - // [2146] phi display_frame::x#0 = 0 [phi:display_frame_draw::@5->display_frame#2] -- vbum1=vbuc1 + // [1174] phi display_frame::x#0 = 0 [phi:display_frame_draw::@5->display_frame#2] -- vbum1=vbuc1 lda #0 sta display_frame.x - // [2146] phi display_frame::x1#16 = $43 [phi:display_frame_draw::@5->display_frame#3] -- vbum1=vbuc1 + // [1174] phi display_frame::x1#16 = $43 [phi:display_frame_draw::@5->display_frame#3] -- vbum1=vbuc1 lda #$43 sta display_frame.x1 jsr display_frame - // [863] phi from display_frame_draw::@5 to display_frame_draw::@6 [phi:display_frame_draw::@5->display_frame_draw::@6] + // [518] phi from display_frame_draw::@5 to display_frame_draw::@6 [phi:display_frame_draw::@5->display_frame_draw::@6] // display_frame_draw::@6 // display_frame(0, 2, 8, 14) - // [864] call display_frame + // [519] call display_frame // Chipset areas - // [2146] phi from display_frame_draw::@6 to display_frame [phi:display_frame_draw::@6->display_frame] - // [2146] phi display_frame::y#0 = 2 [phi:display_frame_draw::@6->display_frame#0] -- vbum1=vbuc1 + // [1174] phi from display_frame_draw::@6 to display_frame [phi:display_frame_draw::@6->display_frame] + // [1174] phi display_frame::y#0 = 2 [phi:display_frame_draw::@6->display_frame#0] -- vbum1=vbuc1 lda #2 sta display_frame.y - // [2146] phi display_frame::y1#16 = $e [phi:display_frame_draw::@6->display_frame#1] -- vbum1=vbuc1 + // [1174] phi display_frame::y1#16 = $e [phi:display_frame_draw::@6->display_frame#1] -- vbum1=vbuc1 lda #$e sta display_frame.y1 - // [2146] phi display_frame::x#0 = 0 [phi:display_frame_draw::@6->display_frame#2] -- vbum1=vbuc1 + // [1174] phi display_frame::x#0 = 0 [phi:display_frame_draw::@6->display_frame#2] -- vbum1=vbuc1 lda #0 sta display_frame.x - // [2146] phi display_frame::x1#16 = 8 [phi:display_frame_draw::@6->display_frame#3] -- vbum1=vbuc1 + // [1174] phi display_frame::x1#16 = 8 [phi:display_frame_draw::@6->display_frame#3] -- vbum1=vbuc1 lda #8 sta display_frame.x1 jsr display_frame - // [865] phi from display_frame_draw::@6 to display_frame_draw::@7 [phi:display_frame_draw::@6->display_frame_draw::@7] + // [520] phi from display_frame_draw::@6 to display_frame_draw::@7 [phi:display_frame_draw::@6->display_frame_draw::@7] // display_frame_draw::@7 // display_frame(8, 2, 19, 14) - // [866] call display_frame - // [2146] phi from display_frame_draw::@7 to display_frame [phi:display_frame_draw::@7->display_frame] - // [2146] phi display_frame::y#0 = 2 [phi:display_frame_draw::@7->display_frame#0] -- vbum1=vbuc1 + // [521] call display_frame + // [1174] phi from display_frame_draw::@7 to display_frame [phi:display_frame_draw::@7->display_frame] + // [1174] phi display_frame::y#0 = 2 [phi:display_frame_draw::@7->display_frame#0] -- vbum1=vbuc1 lda #2 sta display_frame.y - // [2146] phi display_frame::y1#16 = $e [phi:display_frame_draw::@7->display_frame#1] -- vbum1=vbuc1 + // [1174] phi display_frame::y1#16 = $e [phi:display_frame_draw::@7->display_frame#1] -- vbum1=vbuc1 lda #$e sta display_frame.y1 - // [2146] phi display_frame::x#0 = 8 [phi:display_frame_draw::@7->display_frame#2] -- vbum1=vbuc1 + // [1174] phi display_frame::x#0 = 8 [phi:display_frame_draw::@7->display_frame#2] -- vbum1=vbuc1 lda #8 sta display_frame.x - // [2146] phi display_frame::x1#16 = $13 [phi:display_frame_draw::@7->display_frame#3] -- vbum1=vbuc1 + // [1174] phi display_frame::x1#16 = $13 [phi:display_frame_draw::@7->display_frame#3] -- vbum1=vbuc1 lda #$13 sta display_frame.x1 jsr display_frame - // [867] phi from display_frame_draw::@7 to display_frame_draw::@8 [phi:display_frame_draw::@7->display_frame_draw::@8] + // [522] phi from display_frame_draw::@7 to display_frame_draw::@8 [phi:display_frame_draw::@7->display_frame_draw::@8] // display_frame_draw::@8 // display_frame(19, 2, 25, 14) - // [868] call display_frame - // [2146] phi from display_frame_draw::@8 to display_frame [phi:display_frame_draw::@8->display_frame] - // [2146] phi display_frame::y#0 = 2 [phi:display_frame_draw::@8->display_frame#0] -- vbum1=vbuc1 + // [523] call display_frame + // [1174] phi from display_frame_draw::@8 to display_frame [phi:display_frame_draw::@8->display_frame] + // [1174] phi display_frame::y#0 = 2 [phi:display_frame_draw::@8->display_frame#0] -- vbum1=vbuc1 lda #2 sta display_frame.y - // [2146] phi display_frame::y1#16 = $e [phi:display_frame_draw::@8->display_frame#1] -- vbum1=vbuc1 + // [1174] phi display_frame::y1#16 = $e [phi:display_frame_draw::@8->display_frame#1] -- vbum1=vbuc1 lda #$e sta display_frame.y1 - // [2146] phi display_frame::x#0 = $13 [phi:display_frame_draw::@8->display_frame#2] -- vbum1=vbuc1 + // [1174] phi display_frame::x#0 = $13 [phi:display_frame_draw::@8->display_frame#2] -- vbum1=vbuc1 lda #$13 sta display_frame.x - // [2146] phi display_frame::x1#16 = $19 [phi:display_frame_draw::@8->display_frame#3] -- vbum1=vbuc1 + // [1174] phi display_frame::x1#16 = $19 [phi:display_frame_draw::@8->display_frame#3] -- vbum1=vbuc1 lda #$19 sta display_frame.x1 jsr display_frame - // [869] phi from display_frame_draw::@8 to display_frame_draw::@9 [phi:display_frame_draw::@8->display_frame_draw::@9] + // [524] phi from display_frame_draw::@8 to display_frame_draw::@9 [phi:display_frame_draw::@8->display_frame_draw::@9] // display_frame_draw::@9 // display_frame(25, 2, 31, 14) - // [870] call display_frame - // [2146] phi from display_frame_draw::@9 to display_frame [phi:display_frame_draw::@9->display_frame] - // [2146] phi display_frame::y#0 = 2 [phi:display_frame_draw::@9->display_frame#0] -- vbum1=vbuc1 + // [525] call display_frame + // [1174] phi from display_frame_draw::@9 to display_frame [phi:display_frame_draw::@9->display_frame] + // [1174] phi display_frame::y#0 = 2 [phi:display_frame_draw::@9->display_frame#0] -- vbum1=vbuc1 lda #2 sta display_frame.y - // [2146] phi display_frame::y1#16 = $e [phi:display_frame_draw::@9->display_frame#1] -- vbum1=vbuc1 + // [1174] phi display_frame::y1#16 = $e [phi:display_frame_draw::@9->display_frame#1] -- vbum1=vbuc1 lda #$e sta display_frame.y1 - // [2146] phi display_frame::x#0 = $19 [phi:display_frame_draw::@9->display_frame#2] -- vbum1=vbuc1 + // [1174] phi display_frame::x#0 = $19 [phi:display_frame_draw::@9->display_frame#2] -- vbum1=vbuc1 lda #$19 sta display_frame.x - // [2146] phi display_frame::x1#16 = $1f [phi:display_frame_draw::@9->display_frame#3] -- vbum1=vbuc1 + // [1174] phi display_frame::x1#16 = $1f [phi:display_frame_draw::@9->display_frame#3] -- vbum1=vbuc1 lda #$1f sta display_frame.x1 jsr display_frame - // [871] phi from display_frame_draw::@9 to display_frame_draw::@10 [phi:display_frame_draw::@9->display_frame_draw::@10] + // [526] phi from display_frame_draw::@9 to display_frame_draw::@10 [phi:display_frame_draw::@9->display_frame_draw::@10] // display_frame_draw::@10 // display_frame(31, 2, 37, 14) - // [872] call display_frame - // [2146] phi from display_frame_draw::@10 to display_frame [phi:display_frame_draw::@10->display_frame] - // [2146] phi display_frame::y#0 = 2 [phi:display_frame_draw::@10->display_frame#0] -- vbum1=vbuc1 + // [527] call display_frame + // [1174] phi from display_frame_draw::@10 to display_frame [phi:display_frame_draw::@10->display_frame] + // [1174] phi display_frame::y#0 = 2 [phi:display_frame_draw::@10->display_frame#0] -- vbum1=vbuc1 lda #2 sta display_frame.y - // [2146] phi display_frame::y1#16 = $e [phi:display_frame_draw::@10->display_frame#1] -- vbum1=vbuc1 + // [1174] phi display_frame::y1#16 = $e [phi:display_frame_draw::@10->display_frame#1] -- vbum1=vbuc1 lda #$e sta display_frame.y1 - // [2146] phi display_frame::x#0 = $1f [phi:display_frame_draw::@10->display_frame#2] -- vbum1=vbuc1 + // [1174] phi display_frame::x#0 = $1f [phi:display_frame_draw::@10->display_frame#2] -- vbum1=vbuc1 lda #$1f sta display_frame.x - // [2146] phi display_frame::x1#16 = $25 [phi:display_frame_draw::@10->display_frame#3] -- vbum1=vbuc1 + // [1174] phi display_frame::x1#16 = $25 [phi:display_frame_draw::@10->display_frame#3] -- vbum1=vbuc1 lda #$25 sta display_frame.x1 jsr display_frame - // [873] phi from display_frame_draw::@10 to display_frame_draw::@11 [phi:display_frame_draw::@10->display_frame_draw::@11] + // [528] phi from display_frame_draw::@10 to display_frame_draw::@11 [phi:display_frame_draw::@10->display_frame_draw::@11] // display_frame_draw::@11 // display_frame(37, 2, 43, 14) - // [874] call display_frame - // [2146] phi from display_frame_draw::@11 to display_frame [phi:display_frame_draw::@11->display_frame] - // [2146] phi display_frame::y#0 = 2 [phi:display_frame_draw::@11->display_frame#0] -- vbum1=vbuc1 + // [529] call display_frame + // [1174] phi from display_frame_draw::@11 to display_frame [phi:display_frame_draw::@11->display_frame] + // [1174] phi display_frame::y#0 = 2 [phi:display_frame_draw::@11->display_frame#0] -- vbum1=vbuc1 lda #2 sta display_frame.y - // [2146] phi display_frame::y1#16 = $e [phi:display_frame_draw::@11->display_frame#1] -- vbum1=vbuc1 + // [1174] phi display_frame::y1#16 = $e [phi:display_frame_draw::@11->display_frame#1] -- vbum1=vbuc1 lda #$e sta display_frame.y1 - // [2146] phi display_frame::x#0 = $25 [phi:display_frame_draw::@11->display_frame#2] -- vbum1=vbuc1 + // [1174] phi display_frame::x#0 = $25 [phi:display_frame_draw::@11->display_frame#2] -- vbum1=vbuc1 lda #$25 sta display_frame.x - // [2146] phi display_frame::x1#16 = $2b [phi:display_frame_draw::@11->display_frame#3] -- vbum1=vbuc1 + // [1174] phi display_frame::x1#16 = $2b [phi:display_frame_draw::@11->display_frame#3] -- vbum1=vbuc1 lda #$2b sta display_frame.x1 jsr display_frame - // [875] phi from display_frame_draw::@11 to display_frame_draw::@12 [phi:display_frame_draw::@11->display_frame_draw::@12] + // [530] phi from display_frame_draw::@11 to display_frame_draw::@12 [phi:display_frame_draw::@11->display_frame_draw::@12] // display_frame_draw::@12 // display_frame(43, 2, 49, 14) - // [876] call display_frame - // [2146] phi from display_frame_draw::@12 to display_frame [phi:display_frame_draw::@12->display_frame] - // [2146] phi display_frame::y#0 = 2 [phi:display_frame_draw::@12->display_frame#0] -- vbum1=vbuc1 + // [531] call display_frame + // [1174] phi from display_frame_draw::@12 to display_frame [phi:display_frame_draw::@12->display_frame] + // [1174] phi display_frame::y#0 = 2 [phi:display_frame_draw::@12->display_frame#0] -- vbum1=vbuc1 lda #2 sta display_frame.y - // [2146] phi display_frame::y1#16 = $e [phi:display_frame_draw::@12->display_frame#1] -- vbum1=vbuc1 + // [1174] phi display_frame::y1#16 = $e [phi:display_frame_draw::@12->display_frame#1] -- vbum1=vbuc1 lda #$e sta display_frame.y1 - // [2146] phi display_frame::x#0 = $2b [phi:display_frame_draw::@12->display_frame#2] -- vbum1=vbuc1 + // [1174] phi display_frame::x#0 = $2b [phi:display_frame_draw::@12->display_frame#2] -- vbum1=vbuc1 lda #$2b sta display_frame.x - // [2146] phi display_frame::x1#16 = $31 [phi:display_frame_draw::@12->display_frame#3] -- vbum1=vbuc1 + // [1174] phi display_frame::x1#16 = $31 [phi:display_frame_draw::@12->display_frame#3] -- vbum1=vbuc1 lda #$31 sta display_frame.x1 jsr display_frame - // [877] phi from display_frame_draw::@12 to display_frame_draw::@13 [phi:display_frame_draw::@12->display_frame_draw::@13] + // [532] phi from display_frame_draw::@12 to display_frame_draw::@13 [phi:display_frame_draw::@12->display_frame_draw::@13] // display_frame_draw::@13 // display_frame(49, 2, 55, 14) - // [878] call display_frame - // [2146] phi from display_frame_draw::@13 to display_frame [phi:display_frame_draw::@13->display_frame] - // [2146] phi display_frame::y#0 = 2 [phi:display_frame_draw::@13->display_frame#0] -- vbum1=vbuc1 + // [533] call display_frame + // [1174] phi from display_frame_draw::@13 to display_frame [phi:display_frame_draw::@13->display_frame] + // [1174] phi display_frame::y#0 = 2 [phi:display_frame_draw::@13->display_frame#0] -- vbum1=vbuc1 lda #2 sta display_frame.y - // [2146] phi display_frame::y1#16 = $e [phi:display_frame_draw::@13->display_frame#1] -- vbum1=vbuc1 + // [1174] phi display_frame::y1#16 = $e [phi:display_frame_draw::@13->display_frame#1] -- vbum1=vbuc1 lda #$e sta display_frame.y1 - // [2146] phi display_frame::x#0 = $31 [phi:display_frame_draw::@13->display_frame#2] -- vbum1=vbuc1 + // [1174] phi display_frame::x#0 = $31 [phi:display_frame_draw::@13->display_frame#2] -- vbum1=vbuc1 lda #$31 sta display_frame.x - // [2146] phi display_frame::x1#16 = $37 [phi:display_frame_draw::@13->display_frame#3] -- vbum1=vbuc1 + // [1174] phi display_frame::x1#16 = $37 [phi:display_frame_draw::@13->display_frame#3] -- vbum1=vbuc1 lda #$37 sta display_frame.x1 jsr display_frame - // [879] phi from display_frame_draw::@13 to display_frame_draw::@14 [phi:display_frame_draw::@13->display_frame_draw::@14] + // [534] phi from display_frame_draw::@13 to display_frame_draw::@14 [phi:display_frame_draw::@13->display_frame_draw::@14] // display_frame_draw::@14 // display_frame(55, 2, 61, 14) - // [880] call display_frame - // [2146] phi from display_frame_draw::@14 to display_frame [phi:display_frame_draw::@14->display_frame] - // [2146] phi display_frame::y#0 = 2 [phi:display_frame_draw::@14->display_frame#0] -- vbum1=vbuc1 + // [535] call display_frame + // [1174] phi from display_frame_draw::@14 to display_frame [phi:display_frame_draw::@14->display_frame] + // [1174] phi display_frame::y#0 = 2 [phi:display_frame_draw::@14->display_frame#0] -- vbum1=vbuc1 lda #2 sta display_frame.y - // [2146] phi display_frame::y1#16 = $e [phi:display_frame_draw::@14->display_frame#1] -- vbum1=vbuc1 + // [1174] phi display_frame::y1#16 = $e [phi:display_frame_draw::@14->display_frame#1] -- vbum1=vbuc1 lda #$e sta display_frame.y1 - // [2146] phi display_frame::x#0 = $37 [phi:display_frame_draw::@14->display_frame#2] -- vbum1=vbuc1 + // [1174] phi display_frame::x#0 = $37 [phi:display_frame_draw::@14->display_frame#2] -- vbum1=vbuc1 lda #$37 sta display_frame.x - // [2146] phi display_frame::x1#16 = $3d [phi:display_frame_draw::@14->display_frame#3] -- vbum1=vbuc1 + // [1174] phi display_frame::x1#16 = $3d [phi:display_frame_draw::@14->display_frame#3] -- vbum1=vbuc1 lda #$3d sta display_frame.x1 jsr display_frame - // [881] phi from display_frame_draw::@14 to display_frame_draw::@15 [phi:display_frame_draw::@14->display_frame_draw::@15] + // [536] phi from display_frame_draw::@14 to display_frame_draw::@15 [phi:display_frame_draw::@14->display_frame_draw::@15] // display_frame_draw::@15 // display_frame(61, 2, 67, 14) - // [882] call display_frame - // [2146] phi from display_frame_draw::@15 to display_frame [phi:display_frame_draw::@15->display_frame] - // [2146] phi display_frame::y#0 = 2 [phi:display_frame_draw::@15->display_frame#0] -- vbum1=vbuc1 + // [537] call display_frame + // [1174] phi from display_frame_draw::@15 to display_frame [phi:display_frame_draw::@15->display_frame] + // [1174] phi display_frame::y#0 = 2 [phi:display_frame_draw::@15->display_frame#0] -- vbum1=vbuc1 lda #2 sta display_frame.y - // [2146] phi display_frame::y1#16 = $e [phi:display_frame_draw::@15->display_frame#1] -- vbum1=vbuc1 + // [1174] phi display_frame::y1#16 = $e [phi:display_frame_draw::@15->display_frame#1] -- vbum1=vbuc1 lda #$e sta display_frame.y1 - // [2146] phi display_frame::x#0 = $3d [phi:display_frame_draw::@15->display_frame#2] -- vbum1=vbuc1 + // [1174] phi display_frame::x#0 = $3d [phi:display_frame_draw::@15->display_frame#2] -- vbum1=vbuc1 lda #$3d sta display_frame.x - // [2146] phi display_frame::x1#16 = $43 [phi:display_frame_draw::@15->display_frame#3] -- vbum1=vbuc1 + // [1174] phi display_frame::x1#16 = $43 [phi:display_frame_draw::@15->display_frame#3] -- vbum1=vbuc1 lda #$43 sta display_frame.x1 jsr display_frame - // [883] phi from display_frame_draw::@15 to display_frame_draw::@16 [phi:display_frame_draw::@15->display_frame_draw::@16] + // [538] phi from display_frame_draw::@15 to display_frame_draw::@16 [phi:display_frame_draw::@15->display_frame_draw::@16] // display_frame_draw::@16 // display_frame(0, 14, 67, PROGRESS_Y-5) - // [884] call display_frame + // [539] call display_frame // Progress area - // [2146] phi from display_frame_draw::@16 to display_frame [phi:display_frame_draw::@16->display_frame] - // [2146] phi display_frame::y#0 = $e [phi:display_frame_draw::@16->display_frame#0] -- vbum1=vbuc1 + // [1174] phi from display_frame_draw::@16 to display_frame [phi:display_frame_draw::@16->display_frame] + // [1174] phi display_frame::y#0 = $e [phi:display_frame_draw::@16->display_frame#0] -- vbum1=vbuc1 lda #$e sta display_frame.y - // [2146] phi display_frame::y1#16 = PROGRESS_Y-5 [phi:display_frame_draw::@16->display_frame#1] -- vbum1=vbuc1 + // [1174] phi display_frame::y1#16 = PROGRESS_Y-5 [phi:display_frame_draw::@16->display_frame#1] -- vbum1=vbuc1 lda #PROGRESS_Y-5 sta display_frame.y1 - // [2146] phi display_frame::x#0 = 0 [phi:display_frame_draw::@16->display_frame#2] -- vbum1=vbuc1 + // [1174] phi display_frame::x#0 = 0 [phi:display_frame_draw::@16->display_frame#2] -- vbum1=vbuc1 lda #0 sta display_frame.x - // [2146] phi display_frame::x1#16 = $43 [phi:display_frame_draw::@16->display_frame#3] -- vbum1=vbuc1 + // [1174] phi display_frame::x1#16 = $43 [phi:display_frame_draw::@16->display_frame#3] -- vbum1=vbuc1 lda #$43 sta display_frame.x1 jsr display_frame - // [885] phi from display_frame_draw::@16 to display_frame_draw::@17 [phi:display_frame_draw::@16->display_frame_draw::@17] + // [540] phi from display_frame_draw::@16 to display_frame_draw::@17 [phi:display_frame_draw::@16->display_frame_draw::@17] // display_frame_draw::@17 // display_frame(0, PROGRESS_Y-5, 67, PROGRESS_Y-2) - // [886] call display_frame - // [2146] phi from display_frame_draw::@17 to display_frame [phi:display_frame_draw::@17->display_frame] - // [2146] phi display_frame::y#0 = PROGRESS_Y-5 [phi:display_frame_draw::@17->display_frame#0] -- vbum1=vbuc1 + // [541] call display_frame + // [1174] phi from display_frame_draw::@17 to display_frame [phi:display_frame_draw::@17->display_frame] + // [1174] phi display_frame::y#0 = PROGRESS_Y-5 [phi:display_frame_draw::@17->display_frame#0] -- vbum1=vbuc1 lda #PROGRESS_Y-5 sta display_frame.y - // [2146] phi display_frame::y1#16 = PROGRESS_Y-2 [phi:display_frame_draw::@17->display_frame#1] -- vbum1=vbuc1 + // [1174] phi display_frame::y1#16 = PROGRESS_Y-2 [phi:display_frame_draw::@17->display_frame#1] -- vbum1=vbuc1 lda #PROGRESS_Y-2 sta display_frame.y1 - // [2146] phi display_frame::x#0 = 0 [phi:display_frame_draw::@17->display_frame#2] -- vbum1=vbuc1 + // [1174] phi display_frame::x#0 = 0 [phi:display_frame_draw::@17->display_frame#2] -- vbum1=vbuc1 lda #0 sta display_frame.x - // [2146] phi display_frame::x1#16 = $43 [phi:display_frame_draw::@17->display_frame#3] -- vbum1=vbuc1 + // [1174] phi display_frame::x1#16 = $43 [phi:display_frame_draw::@17->display_frame#3] -- vbum1=vbuc1 lda #$43 sta display_frame.x1 jsr display_frame - // [887] phi from display_frame_draw::@17 to display_frame_draw::@18 [phi:display_frame_draw::@17->display_frame_draw::@18] + // [542] phi from display_frame_draw::@17 to display_frame_draw::@18 [phi:display_frame_draw::@17->display_frame_draw::@18] // display_frame_draw::@18 // display_frame(0, PROGRESS_Y-2, 67, 49) - // [888] call display_frame - // [2146] phi from display_frame_draw::@18 to display_frame [phi:display_frame_draw::@18->display_frame] - // [2146] phi display_frame::y#0 = PROGRESS_Y-2 [phi:display_frame_draw::@18->display_frame#0] -- vbum1=vbuc1 + // [543] call display_frame + // [1174] phi from display_frame_draw::@18 to display_frame [phi:display_frame_draw::@18->display_frame] + // [1174] phi display_frame::y#0 = PROGRESS_Y-2 [phi:display_frame_draw::@18->display_frame#0] -- vbum1=vbuc1 lda #PROGRESS_Y-2 sta display_frame.y - // [2146] phi display_frame::y1#16 = $31 [phi:display_frame_draw::@18->display_frame#1] -- vbum1=vbuc1 + // [1174] phi display_frame::y1#16 = $31 [phi:display_frame_draw::@18->display_frame#1] -- vbum1=vbuc1 lda #$31 sta display_frame.y1 - // [2146] phi display_frame::x#0 = 0 [phi:display_frame_draw::@18->display_frame#2] -- vbum1=vbuc1 + // [1174] phi display_frame::x#0 = 0 [phi:display_frame_draw::@18->display_frame#2] -- vbum1=vbuc1 lda #0 sta display_frame.x - // [2146] phi display_frame::x1#16 = $43 [phi:display_frame_draw::@18->display_frame#3] -- vbum1=vbuc1 + // [1174] phi display_frame::x1#16 = $43 [phi:display_frame_draw::@18->display_frame#3] -- vbum1=vbuc1 lda #$43 sta display_frame.x1 jsr display_frame - // [889] phi from display_frame_draw::@18 to display_frame_draw::@19 [phi:display_frame_draw::@18->display_frame_draw::@19] + // [544] phi from display_frame_draw::@18 to display_frame_draw::@19 [phi:display_frame_draw::@18->display_frame_draw::@19] // display_frame_draw::@19 // textcolor(WHITE) - // [890] call textcolor - // [784] phi from display_frame_draw::@19 to textcolor [phi:display_frame_draw::@19->textcolor] - // [784] phi textcolor::color#23 = WHITE [phi:display_frame_draw::@19->textcolor#0] -- vbum1=vbuc1 + // [545] call textcolor + // [439] phi from display_frame_draw::@19 to textcolor [phi:display_frame_draw::@19->textcolor] + // [439] phi textcolor::color#21 = WHITE [phi:display_frame_draw::@19->textcolor#0] -- vbum1=vbuc1 lda #WHITE sta textcolor.color jsr textcolor // display_frame_draw::@return // } - // [891] return + // [546] return rts } // display_frame_title @@ -5922,73 +3474,73 @@ display_frame_draw: { // void display_frame_title(char *title_text) display_frame_title: { // gotoxy(2, 1) - // [893] call gotoxy - // [802] phi from display_frame_title to gotoxy [phi:display_frame_title->gotoxy] - // [802] phi gotoxy::y#37 = 1 [phi:display_frame_title->gotoxy#0] -- vbum1=vbuc1 + // [548] call gotoxy + // [457] phi from display_frame_title to gotoxy [phi:display_frame_title->gotoxy] + // [457] phi gotoxy::y#26 = 1 [phi:display_frame_title->gotoxy#0] -- vbum1=vbuc1 lda #1 sta gotoxy.y - // [802] phi gotoxy::x#37 = 2 [phi:display_frame_title->gotoxy#1] -- vbum1=vbuc1 + // [457] phi gotoxy::x#26 = 2 [phi:display_frame_title->gotoxy#1] -- vbum1=vbuc1 lda #2 sta gotoxy.x jsr gotoxy - // [894] phi from display_frame_title to display_frame_title::@1 [phi:display_frame_title->display_frame_title::@1] + // [549] phi from display_frame_title to display_frame_title::@1 [phi:display_frame_title->display_frame_title::@1] // display_frame_title::@1 // printf("%-65s", title_text) - // [895] call printf_string - // [1219] phi from display_frame_title::@1 to printf_string [phi:display_frame_title::@1->printf_string] - // [1219] phi printf_string::putc#26 = &cputc [phi:display_frame_title::@1->printf_string#0] -- pprz1=pprc1 + // [550] call printf_string + // [1308] phi from display_frame_title::@1 to printf_string [phi:display_frame_title::@1->printf_string] + // [1308] phi printf_string::putc#17 = &cputc [phi:display_frame_title::@1->printf_string#0] -- pprz1=pprc1 lda #cputc sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = main::title_text [phi:display_frame_title::@1->printf_string#1] -- pbuz1=pbuc1 + // [1308] phi printf_string::str#17 = main::title_text [phi:display_frame_title::@1->printf_string#1] -- pbuz1=pbuc1 lda #main.title_text sta.z printf_string.str+1 - // [1219] phi printf_string::format_justify_left#26 = 1 [phi:display_frame_title::@1->printf_string#2] -- vbum1=vbuc1 + // [1308] phi printf_string::format_justify_left#17 = 1 [phi:display_frame_title::@1->printf_string#2] -- vbum1=vbuc1 lda #1 sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = $41 [phi:display_frame_title::@1->printf_string#3] -- vbum1=vbuc1 + // [1308] phi printf_string::format_min_length#17 = $41 [phi:display_frame_title::@1->printf_string#3] -- vbum1=vbuc1 lda #$41 sta printf_string.format_min_length jsr printf_string // display_frame_title::@return // } - // [896] return + // [551] return rts } // cputsxy // Move cursor and output a NUL-terminated string // Same as "gotoxy (x, y); puts (s);" -// void cputsxy(__mem() char x, __mem() char y, __zp($6c) const char *s) +// void cputsxy(__mem() char x, __mem() char y, __zp($49) const char *s) cputsxy: { - .label s = $6c + .label s = $49 // gotoxy(x, y) - // [898] gotoxy::x#1 = cputsxy::x#4 -- vbum1=vbum2 + // [553] gotoxy::x#1 = cputsxy::x#3 -- vbum1=vbum2 lda x sta gotoxy.x - // [899] gotoxy::y#1 = cputsxy::y#4 -- vbum1=vbum2 + // [554] gotoxy::y#1 = cputsxy::y#3 -- vbum1=vbum2 lda y sta gotoxy.y - // [900] call gotoxy - // [802] phi from cputsxy to gotoxy [phi:cputsxy->gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#1 [phi:cputsxy->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = gotoxy::x#1 [phi:cputsxy->gotoxy#1] -- register_copy + // [555] call gotoxy + // [457] phi from cputsxy to gotoxy [phi:cputsxy->gotoxy] + // [457] phi gotoxy::y#26 = gotoxy::y#1 [phi:cputsxy->gotoxy#0] -- register_copy + // [457] phi gotoxy::x#26 = gotoxy::x#1 [phi:cputsxy->gotoxy#1] -- register_copy jsr gotoxy // cputsxy::@1 // cputs(s) - // [901] cputs::s#1 = cputsxy::s#4 -- pbuz1=pbuz2 + // [556] cputs::s#1 = cputsxy::s#3 -- pbuz1=pbuz2 lda.z s sta.z cputs.s lda.z s+1 sta.z cputs.s+1 - // [902] call cputs - // [2280] phi from cputsxy::@1 to cputs [phi:cputsxy::@1->cputs] + // [557] call cputs + // [1333] phi from cputsxy::@1 to cputs [phi:cputsxy::@1->cputs] jsr cputs // cputsxy::@return // } - // [903] return + // [558] return rts .segment Data y: .byte 0 @@ -6001,65 +3553,65 @@ cputsxy: { * * @param info_text The progress text to be displayed. */ -// void display_action_progress(__zp($50) char *info_text) +// void display_action_progress(__zp($42) char *info_text) display_action_progress: { - .label info_text = $50 + .label info_text = $42 // unsigned char x = wherex() - // [905] call wherex + // [560] call wherex jsr wherex - // [906] wherex::return#2 = wherex::return#0 + // [561] wherex::return#2 = wherex::return#0 // display_action_progress::@1 - // [907] display_action_progress::x#0 = wherex::return#2 + // [562] display_action_progress::x#0 = wherex::return#2 // unsigned char y = wherey() - // [908] call wherey + // [563] call wherey jsr wherey - // [909] wherey::return#2 = wherey::return#0 + // [564] wherey::return#2 = wherey::return#0 // display_action_progress::@2 - // [910] display_action_progress::y#0 = wherey::return#2 + // [565] display_action_progress::y#0 = wherey::return#2 // gotoxy(2, PROGRESS_Y-4) - // [911] call gotoxy - // [802] phi from display_action_progress::@2 to gotoxy [phi:display_action_progress::@2->gotoxy] - // [802] phi gotoxy::y#37 = PROGRESS_Y-4 [phi:display_action_progress::@2->gotoxy#0] -- vbum1=vbuc1 + // [566] call gotoxy + // [457] phi from display_action_progress::@2 to gotoxy [phi:display_action_progress::@2->gotoxy] + // [457] phi gotoxy::y#26 = PROGRESS_Y-4 [phi:display_action_progress::@2->gotoxy#0] -- vbum1=vbuc1 lda #PROGRESS_Y-4 sta gotoxy.y - // [802] phi gotoxy::x#37 = 2 [phi:display_action_progress::@2->gotoxy#1] -- vbum1=vbuc1 + // [457] phi gotoxy::x#26 = 2 [phi:display_action_progress::@2->gotoxy#1] -- vbum1=vbuc1 lda #2 sta gotoxy.x jsr gotoxy // display_action_progress::@3 // printf("%-65s", info_text) - // [912] printf_string::str#1 = display_action_progress::info_text#27 - // [913] call printf_string - // [1219] phi from display_action_progress::@3 to printf_string [phi:display_action_progress::@3->printf_string] - // [1219] phi printf_string::putc#26 = &cputc [phi:display_action_progress::@3->printf_string#0] -- pprz1=pprc1 + // [567] printf_string::str#1 = display_action_progress::info_text#19 + // [568] call printf_string + // [1308] phi from display_action_progress::@3 to printf_string [phi:display_action_progress::@3->printf_string] + // [1308] phi printf_string::putc#17 = &cputc [phi:display_action_progress::@3->printf_string#0] -- pprz1=pprc1 lda #cputc sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#1 [phi:display_action_progress::@3->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 1 [phi:display_action_progress::@3->printf_string#2] -- vbum1=vbuc1 + // [1308] phi printf_string::str#17 = printf_string::str#1 [phi:display_action_progress::@3->printf_string#1] -- register_copy + // [1308] phi printf_string::format_justify_left#17 = 1 [phi:display_action_progress::@3->printf_string#2] -- vbum1=vbuc1 lda #1 sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = $41 [phi:display_action_progress::@3->printf_string#3] -- vbum1=vbuc1 + // [1308] phi printf_string::format_min_length#17 = $41 [phi:display_action_progress::@3->printf_string#3] -- vbum1=vbuc1 lda #$41 sta printf_string.format_min_length jsr printf_string // display_action_progress::@4 // gotoxy(x, y) - // [914] gotoxy::x#14 = display_action_progress::x#0 -- vbum1=vbum2 + // [569] gotoxy::x#14 = display_action_progress::x#0 -- vbum1=vbum2 lda x sta gotoxy.x - // [915] gotoxy::y#14 = display_action_progress::y#0 -- vbum1=vbum2 + // [570] gotoxy::y#14 = display_action_progress::y#0 -- vbum1=vbum2 lda y sta gotoxy.y - // [916] call gotoxy - // [802] phi from display_action_progress::@4 to gotoxy [phi:display_action_progress::@4->gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#14 [phi:display_action_progress::@4->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = gotoxy::x#14 [phi:display_action_progress::@4->gotoxy#1] -- register_copy + // [571] call gotoxy + // [457] phi from display_action_progress::@4 to gotoxy [phi:display_action_progress::@4->gotoxy] + // [457] phi gotoxy::y#26 = gotoxy::y#14 [phi:display_action_progress::@4->gotoxy#0] -- register_copy + // [457] phi gotoxy::x#26 = gotoxy::x#14 [phi:display_action_progress::@4->gotoxy#1] -- register_copy jsr gotoxy // display_action_progress::@return // } - // [917] return + // [572] return rts .segment Data .label x = wherex.return @@ -6073,85 +3625,85 @@ display_action_progress: { display_progress_clear: { .const h = PROGRESS_Y+PROGRESS_H // textcolor(WHITE) - // [919] call textcolor - // [784] phi from display_progress_clear to textcolor [phi:display_progress_clear->textcolor] - // [784] phi textcolor::color#23 = WHITE [phi:display_progress_clear->textcolor#0] -- vbum1=vbuc1 + // [574] call textcolor + // [439] phi from display_progress_clear to textcolor [phi:display_progress_clear->textcolor] + // [439] phi textcolor::color#21 = WHITE [phi:display_progress_clear->textcolor#0] -- vbum1=vbuc1 lda #WHITE sta textcolor.color jsr textcolor - // [920] phi from display_progress_clear to display_progress_clear::@5 [phi:display_progress_clear->display_progress_clear::@5] + // [575] phi from display_progress_clear to display_progress_clear::@5 [phi:display_progress_clear->display_progress_clear::@5] // display_progress_clear::@5 // bgcolor(BLUE) - // [921] call bgcolor - // [789] phi from display_progress_clear::@5 to bgcolor [phi:display_progress_clear::@5->bgcolor] - // [789] phi bgcolor::color#15 = BLUE [phi:display_progress_clear::@5->bgcolor#0] -- vbum1=vbuc1 + // [576] call bgcolor + // [444] phi from display_progress_clear::@5 to bgcolor [phi:display_progress_clear::@5->bgcolor] + // [444] phi bgcolor::color#15 = BLUE [phi:display_progress_clear::@5->bgcolor#0] -- vbum1=vbuc1 lda #BLUE sta bgcolor.color jsr bgcolor - // [922] phi from display_progress_clear::@5 to display_progress_clear::@1 [phi:display_progress_clear::@5->display_progress_clear::@1] - // [922] phi display_progress_clear::y#2 = PROGRESS_Y [phi:display_progress_clear::@5->display_progress_clear::@1#0] -- vbum1=vbuc1 + // [577] phi from display_progress_clear::@5 to display_progress_clear::@1 [phi:display_progress_clear::@5->display_progress_clear::@1] + // [577] phi display_progress_clear::y#2 = PROGRESS_Y [phi:display_progress_clear::@5->display_progress_clear::@1#0] -- vbum1=vbuc1 lda #PROGRESS_Y sta y // display_progress_clear::@1 __b1: // while (y < h) - // [923] if(display_progress_clear::y#2display_progress_clear::@2] + // [580] phi from display_progress_clear::@1 to display_progress_clear::@2 [phi:display_progress_clear::@1->display_progress_clear::@2] __b4: - // [925] phi display_progress_clear::x#2 = PROGRESS_X [phi:display_progress_clear::@1->display_progress_clear::@2#0] -- vbum1=vbuc1 + // [580] phi display_progress_clear::x#2 = PROGRESS_X [phi:display_progress_clear::@1->display_progress_clear::@2#0] -- vbum1=vbuc1 lda #PROGRESS_X sta x - // [925] phi display_progress_clear::i#2 = 0 [phi:display_progress_clear::@1->display_progress_clear::@2#1] -- vbum1=vbuc1 + // [580] phi display_progress_clear::i#2 = 0 [phi:display_progress_clear::@1->display_progress_clear::@2#1] -- vbum1=vbuc1 lda #0 sta i // display_progress_clear::@2 __b2: // for(unsigned char i = 0; i < w; i++) - // [926] if(display_progress_clear::i#2display_progress_clear::@1] - // [922] phi display_progress_clear::y#2 = display_progress_clear::y#1 [phi:display_progress_clear::@4->display_progress_clear::@1#0] -- register_copy + // [577] phi from display_progress_clear::@4 to display_progress_clear::@1 [phi:display_progress_clear::@4->display_progress_clear::@1] + // [577] phi display_progress_clear::y#2 = display_progress_clear::y#1 [phi:display_progress_clear::@4->display_progress_clear::@1#0] -- register_copy jmp __b1 // display_progress_clear::@3 __b3: // cputcxy(x, y, ' ') - // [928] cputcxy::x#14 = display_progress_clear::x#2 -- vbum1=vbum2 + // [583] cputcxy::x#14 = display_progress_clear::x#2 -- vbum1=vbum2 lda x sta cputcxy.x - // [929] cputcxy::y#14 = display_progress_clear::y#2 -- vbum1=vbum2 + // [584] cputcxy::y#14 = display_progress_clear::y#2 -- vbum1=vbum2 lda y sta cputcxy.y - // [930] call cputcxy - // [2293] phi from display_progress_clear::@3 to cputcxy [phi:display_progress_clear::@3->cputcxy] - // [2293] phi cputcxy::c#17 = ' ' [phi:display_progress_clear::@3->cputcxy#0] -- vbum1=vbuc1 + // [585] call cputcxy + // [1346] phi from display_progress_clear::@3 to cputcxy [phi:display_progress_clear::@3->cputcxy] + // [1346] phi cputcxy::c#15 = ' ' [phi:display_progress_clear::@3->cputcxy#0] -- vbum1=vbuc1 lda #' ' sta cputcxy.c - // [2293] phi cputcxy::y#17 = cputcxy::y#14 [phi:display_progress_clear::@3->cputcxy#1] -- register_copy - // [2293] phi cputcxy::x#17 = cputcxy::x#14 [phi:display_progress_clear::@3->cputcxy#2] -- register_copy + // [1346] phi cputcxy::y#15 = cputcxy::y#14 [phi:display_progress_clear::@3->cputcxy#1] -- register_copy + // [1346] phi cputcxy::x#15 = cputcxy::x#14 [phi:display_progress_clear::@3->cputcxy#2] -- register_copy jsr cputcxy // display_progress_clear::@6 // x++; - // [931] display_progress_clear::x#1 = ++ display_progress_clear::x#2 -- vbum1=_inc_vbum1 + // [586] display_progress_clear::x#1 = ++ display_progress_clear::x#2 -- vbum1=_inc_vbum1 inc x // for(unsigned char i = 0; i < w; i++) - // [932] display_progress_clear::i#1 = ++ display_progress_clear::i#2 -- vbum1=_inc_vbum1 + // [587] display_progress_clear::i#1 = ++ display_progress_clear::i#2 -- vbum1=_inc_vbum1 inc i - // [925] phi from display_progress_clear::@6 to display_progress_clear::@2 [phi:display_progress_clear::@6->display_progress_clear::@2] - // [925] phi display_progress_clear::x#2 = display_progress_clear::x#1 [phi:display_progress_clear::@6->display_progress_clear::@2#0] -- register_copy - // [925] phi display_progress_clear::i#2 = display_progress_clear::i#1 [phi:display_progress_clear::@6->display_progress_clear::@2#1] -- register_copy + // [580] phi from display_progress_clear::@6 to display_progress_clear::@2 [phi:display_progress_clear::@6->display_progress_clear::@2] + // [580] phi display_progress_clear::x#2 = display_progress_clear::x#1 [phi:display_progress_clear::@6->display_progress_clear::@2#0] -- register_copy + // [580] phi display_progress_clear::i#2 = display_progress_clear::i#1 [phi:display_progress_clear::@6->display_progress_clear::@2#1] -- register_copy jmp __b2 .segment Data x: .byte 0 @@ -6162,32 +3714,32 @@ display_progress_clear: { // display_chip_smc display_chip_smc: { // display_smc_led(GREY) - // [934] call display_smc_led - // [2301] phi from display_chip_smc to display_smc_led [phi:display_chip_smc->display_smc_led] - // [2301] phi display_smc_led::c#2 = GREY [phi:display_chip_smc->display_smc_led#0] -- vbum1=vbuc1 + // [589] call display_smc_led + // [1354] phi from display_chip_smc to display_smc_led [phi:display_chip_smc->display_smc_led] + // [1354] phi display_smc_led::c#2 = GREY [phi:display_chip_smc->display_smc_led#0] -- vbum1=vbuc1 lda #GREY sta display_smc_led.c jsr display_smc_led - // [935] phi from display_chip_smc to display_chip_smc::@1 [phi:display_chip_smc->display_chip_smc::@1] + // [590] phi from display_chip_smc to display_chip_smc::@1 [phi:display_chip_smc->display_chip_smc::@1] // display_chip_smc::@1 // display_print_chip(CHIP_SMC_X, CHIP_SMC_Y+2, CHIP_SMC_W, "SMC ") - // [936] call display_print_chip - // [2307] phi from display_chip_smc::@1 to display_print_chip [phi:display_chip_smc::@1->display_print_chip] - // [2307] phi display_print_chip::text#11 = display_chip_smc::text [phi:display_chip_smc::@1->display_print_chip#0] -- pbuz1=pbuc1 + // [591] call display_print_chip + // [1360] phi from display_chip_smc::@1 to display_print_chip [phi:display_chip_smc::@1->display_print_chip] + // [1360] phi display_print_chip::text#11 = display_chip_smc::text [phi:display_chip_smc::@1->display_print_chip#0] -- pbuz1=pbuc1 lda #text sta.z display_print_chip.text_2+1 - // [2307] phi display_print_chip::w#10 = 5 [phi:display_chip_smc::@1->display_print_chip#1] -- vbum1=vbuc1 + // [1360] phi display_print_chip::w#10 = 5 [phi:display_chip_smc::@1->display_print_chip#1] -- vbum1=vbuc1 lda #5 sta display_print_chip.w - // [2307] phi display_print_chip::x#10 = 1 [phi:display_chip_smc::@1->display_print_chip#2] -- vbum1=vbuc1 + // [1360] phi display_print_chip::x#10 = 1 [phi:display_chip_smc::@1->display_print_chip#2] -- vbum1=vbuc1 lda #1 sta display_print_chip.x jsr display_print_chip // display_chip_smc::@return // } - // [937] return + // [592] return rts .segment Data text: .text "SMC " @@ -6197,32 +3749,32 @@ display_chip_smc: { // display_chip_vera display_chip_vera: { // display_vera_led(GREY) - // [939] call display_vera_led - // [2351] phi from display_chip_vera to display_vera_led [phi:display_chip_vera->display_vera_led] - // [2351] phi display_vera_led::c#2 = GREY [phi:display_chip_vera->display_vera_led#0] -- vbum1=vbuc1 + // [594] call display_vera_led + // [1404] phi from display_chip_vera to display_vera_led [phi:display_chip_vera->display_vera_led] + // [1404] phi display_vera_led::c#2 = GREY [phi:display_chip_vera->display_vera_led#0] -- vbum1=vbuc1 lda #GREY sta display_vera_led.c jsr display_vera_led - // [940] phi from display_chip_vera to display_chip_vera::@1 [phi:display_chip_vera->display_chip_vera::@1] + // [595] phi from display_chip_vera to display_chip_vera::@1 [phi:display_chip_vera->display_chip_vera::@1] // display_chip_vera::@1 // display_print_chip(CHIP_VERA_X, CHIP_VERA_Y+2, CHIP_VERA_W, "VERA ") - // [941] call display_print_chip - // [2307] phi from display_chip_vera::@1 to display_print_chip [phi:display_chip_vera::@1->display_print_chip] - // [2307] phi display_print_chip::text#11 = display_chip_vera::text [phi:display_chip_vera::@1->display_print_chip#0] -- pbuz1=pbuc1 + // [596] call display_print_chip + // [1360] phi from display_chip_vera::@1 to display_print_chip [phi:display_chip_vera::@1->display_print_chip] + // [1360] phi display_print_chip::text#11 = display_chip_vera::text [phi:display_chip_vera::@1->display_print_chip#0] -- pbuz1=pbuc1 lda #text sta.z display_print_chip.text_2+1 - // [2307] phi display_print_chip::w#10 = 8 [phi:display_chip_vera::@1->display_print_chip#1] -- vbum1=vbuc1 + // [1360] phi display_print_chip::w#10 = 8 [phi:display_chip_vera::@1->display_print_chip#1] -- vbum1=vbuc1 lda #8 sta display_print_chip.w - // [2307] phi display_print_chip::x#10 = 9 [phi:display_chip_vera::@1->display_print_chip#2] -- vbum1=vbuc1 + // [1360] phi display_print_chip::x#10 = 9 [phi:display_chip_vera::@1->display_print_chip#2] -- vbum1=vbuc1 lda #9 sta display_print_chip.x jsr display_print_chip // display_chip_vera::@return // } - // [942] return + // [597] return rts .segment Data text: .text "VERA " @@ -6235,37 +3787,37 @@ display_chip_vera: { * */ display_chip_rom: { - .label display_chip_rom__4 = $42 - .label display_chip_rom__6 = $2b - .label display_chip_rom__11 = $2b - .label display_chip_rom__12 = $2b - // [944] phi from display_chip_rom to display_chip_rom::@1 [phi:display_chip_rom->display_chip_rom::@1] - // [944] phi display_chip_rom::r#2 = 0 [phi:display_chip_rom->display_chip_rom::@1#0] -- vbum1=vbuc1 + .label display_chip_rom__4 = $4e + .label display_chip_rom__6 = $4d + .label display_chip_rom__11 = $4d + .label display_chip_rom__12 = $4d + // [599] phi from display_chip_rom to display_chip_rom::@1 [phi:display_chip_rom->display_chip_rom::@1] + // [599] phi display_chip_rom::r#2 = 0 [phi:display_chip_rom->display_chip_rom::@1#0] -- vbum1=vbuc1 lda #0 sta r // display_chip_rom::@1 __b1: // for (unsigned char r = 0; r < 8; r++) - // [945] if(display_chip_rom::r#2<8) goto display_chip_rom::@2 -- vbum1_lt_vbuc1_then_la1 + // [600] if(display_chip_rom::r#2<8) goto display_chip_rom::@2 -- vbum1_lt_vbuc1_then_la1 lda r cmp #8 bcc __b2 // display_chip_rom::@return // } - // [946] return + // [601] return rts - // [947] phi from display_chip_rom::@1 to display_chip_rom::@2 [phi:display_chip_rom::@1->display_chip_rom::@2] + // [602] phi from display_chip_rom::@1 to display_chip_rom::@2 [phi:display_chip_rom::@1->display_chip_rom::@2] // display_chip_rom::@2 __b2: // strcpy(rom, "ROM ") - // [948] call strcpy - // [1066] phi from display_chip_rom::@2 to strcpy [phi:display_chip_rom::@2->strcpy] - // [1066] phi strcpy::dst#0 = display_chip_rom::rom [phi:display_chip_rom::@2->strcpy#0] -- pbuz1=pbuc1 + // [603] call strcpy + // [1117] phi from display_chip_rom::@2 to strcpy [phi:display_chip_rom::@2->strcpy] + // [1117] phi strcpy::dst#0 = display_chip_rom::rom [phi:display_chip_rom::@2->strcpy#0] -- pbuz1=pbuc1 lda #rom sta.z strcpy.dst+1 - // [1066] phi strcpy::src#0 = display_chip_rom::source [phi:display_chip_rom::@2->strcpy#1] -- pbuz1=pbuc1 + // [1117] phi strcpy::src#0 = display_chip_rom::source [phi:display_chip_rom::@2->strcpy#1] -- pbuz1=pbuc1 lda #source @@ -6273,80 +3825,80 @@ display_chip_rom: { jsr strcpy // display_chip_rom::@5 // strcat(rom, rom_size_strings[r]) - // [949] display_chip_rom::$11 = display_chip_rom::r#2 << 1 -- vbuz1=vbum2_rol_1 + // [604] display_chip_rom::$11 = display_chip_rom::r#2 << 1 -- vbuz1=vbum2_rol_1 lda r asl sta.z display_chip_rom__11 - // [950] strcat::source#0 = rom_size_strings[display_chip_rom::$11] -- pbuz1=qbuc1_derefidx_vbuz2 + // [605] strcat::source#0 = rom_size_strings[display_chip_rom::$11] -- pbuz1=qbuc1_derefidx_vbuz2 tay lda rom_size_strings,y sta.z strcat.source lda rom_size_strings+1,y sta.z strcat.source+1 - // [951] call strcat - // [2357] phi from display_chip_rom::@5 to strcat [phi:display_chip_rom::@5->strcat] + // [606] call strcat + // [1410] phi from display_chip_rom::@5 to strcat [phi:display_chip_rom::@5->strcat] jsr strcat // display_chip_rom::@6 // if(r) - // [952] if(0==display_chip_rom::r#2) goto display_chip_rom::@3 -- 0_eq_vbum1_then_la1 + // [607] if(0==display_chip_rom::r#2) goto display_chip_rom::@3 -- 0_eq_vbum1_then_la1 lda r beq __b3 // display_chip_rom::@4 // r+'0' - // [953] display_chip_rom::$4 = display_chip_rom::r#2 + '0' -- vbuz1=vbum2_plus_vbuc1 + // [608] display_chip_rom::$4 = display_chip_rom::r#2 + '0' -- vbuz1=vbum2_plus_vbuc1 lda #'0' clc adc r sta.z display_chip_rom__4 // *(rom+3) = r+'0' - // [954] *(display_chip_rom::rom+3) = display_chip_rom::$4 -- _deref_pbuc1=vbuz1 + // [609] *(display_chip_rom::rom+3) = display_chip_rom::$4 -- _deref_pbuc1=vbuz1 sta rom+3 // display_chip_rom::@3 __b3: // display_rom_led(r, GREY) - // [955] display_rom_led::chip#0 = display_chip_rom::r#2 -- vbum1=vbum2 + // [610] display_rom_led::chip#0 = display_chip_rom::r#2 -- vbum1=vbum2 lda r sta display_rom_led.chip - // [956] call display_rom_led - // [2369] phi from display_chip_rom::@3 to display_rom_led [phi:display_chip_rom::@3->display_rom_led] - // [2369] phi display_rom_led::c#2 = GREY [phi:display_chip_rom::@3->display_rom_led#0] -- vbum1=vbuc1 + // [611] call display_rom_led + // [1422] phi from display_chip_rom::@3 to display_rom_led [phi:display_chip_rom::@3->display_rom_led] + // [1422] phi display_rom_led::c#2 = GREY [phi:display_chip_rom::@3->display_rom_led#0] -- vbum1=vbuc1 lda #GREY sta display_rom_led.c - // [2369] phi display_rom_led::chip#2 = display_rom_led::chip#0 [phi:display_chip_rom::@3->display_rom_led#1] -- register_copy + // [1422] phi display_rom_led::chip#2 = display_rom_led::chip#0 [phi:display_chip_rom::@3->display_rom_led#1] -- register_copy jsr display_rom_led // display_chip_rom::@7 // r*6 - // [957] display_chip_rom::$12 = display_chip_rom::$11 + display_chip_rom::r#2 -- vbuz1=vbuz1_plus_vbum2 + // [612] display_chip_rom::$12 = display_chip_rom::$11 + display_chip_rom::r#2 -- vbuz1=vbuz1_plus_vbum2 lda r clc adc.z display_chip_rom__12 sta.z display_chip_rom__12 - // [958] display_chip_rom::$6 = display_chip_rom::$12 << 1 -- vbuz1=vbuz1_rol_1 + // [613] display_chip_rom::$6 = display_chip_rom::$12 << 1 -- vbuz1=vbuz1_rol_1 asl.z display_chip_rom__6 // display_print_chip(CHIP_ROM_X+r*6, CHIP_ROM_Y+2, CHIP_ROM_W, rom) - // [959] display_print_chip::x#2 = $14 + display_chip_rom::$6 -- vbum1=vbuc1_plus_vbuz2 + // [614] display_print_chip::x#2 = $14 + display_chip_rom::$6 -- vbum1=vbuc1_plus_vbuz2 lda #$14 clc adc.z display_chip_rom__6 sta display_print_chip.x - // [960] call display_print_chip - // [2307] phi from display_chip_rom::@7 to display_print_chip [phi:display_chip_rom::@7->display_print_chip] - // [2307] phi display_print_chip::text#11 = display_chip_rom::rom [phi:display_chip_rom::@7->display_print_chip#0] -- pbuz1=pbuc1 + // [615] call display_print_chip + // [1360] phi from display_chip_rom::@7 to display_print_chip [phi:display_chip_rom::@7->display_print_chip] + // [1360] phi display_print_chip::text#11 = display_chip_rom::rom [phi:display_chip_rom::@7->display_print_chip#0] -- pbuz1=pbuc1 lda #rom sta.z display_print_chip.text_2+1 - // [2307] phi display_print_chip::w#10 = 3 [phi:display_chip_rom::@7->display_print_chip#1] -- vbum1=vbuc1 + // [1360] phi display_print_chip::w#10 = 3 [phi:display_chip_rom::@7->display_print_chip#1] -- vbum1=vbuc1 lda #3 sta display_print_chip.w - // [2307] phi display_print_chip::x#10 = display_print_chip::x#2 [phi:display_chip_rom::@7->display_print_chip#2] -- register_copy + // [1360] phi display_print_chip::x#10 = display_print_chip::x#2 [phi:display_chip_rom::@7->display_print_chip#2] -- register_copy jsr display_print_chip // display_chip_rom::@8 // for (unsigned char r = 0; r < 8; r++) - // [961] display_chip_rom::r#1 = ++ display_chip_rom::r#2 -- vbum1=_inc_vbum1 + // [616] display_chip_rom::r#1 = ++ display_chip_rom::r#2 -- vbum1=_inc_vbum1 inc r - // [944] phi from display_chip_rom::@8 to display_chip_rom::@1 [phi:display_chip_rom::@8->display_chip_rom::@1] - // [944] phi display_chip_rom::r#2 = display_chip_rom::r#1 [phi:display_chip_rom::@8->display_chip_rom::@1#0] -- register_copy + // [599] phi from display_chip_rom::@8 to display_chip_rom::@1 [phi:display_chip_rom::@8->display_chip_rom::@1] + // [599] phi display_chip_rom::r#2 = display_chip_rom::r#1 [phi:display_chip_rom::@8->display_chip_rom::@1#0] -- register_copy jmp __b1 .segment Data rom: .fill $10, 0 @@ -6363,62 +3915,62 @@ display_chip_rom: { * * @remark The smc_booloader is a global variable. */ -// void display_info_smc(__mem() char info_status, __zp($45) char *info_text) +// void display_info_smc(__mem() char info_status, __zp($34) char *info_text) display_info_smc: { - .label display_info_smc__9 = $2b - .label info_text = $45 + .label display_info_smc__9 = $4d + .label info_text = $34 // unsigned char x = wherex() - // [963] call wherex + // [618] call wherex jsr wherex - // [964] wherex::return#10 = wherex::return#0 -- vbum1=vbum2 + // [619] wherex::return#10 = wherex::return#0 -- vbum1=vbum2 lda wherex.return sta wherex.return_2 // display_info_smc::@3 - // [965] display_info_smc::x#0 = wherex::return#10 + // [620] display_info_smc::x#0 = wherex::return#10 // unsigned char y = wherey() - // [966] call wherey + // [621] call wherey jsr wherey - // [967] wherey::return#10 = wherey::return#0 -- vbum1=vbum2 + // [622] wherey::return#10 = wherey::return#0 -- vbum1=vbum2 lda wherey.return sta wherey.return_2 // display_info_smc::@4 - // [968] display_info_smc::y#0 = wherey::return#10 + // [623] display_info_smc::y#0 = wherey::return#10 // status_smc = info_status - // [969] status_smc#0 = display_info_smc::info_status#20 -- vbum1=vbum2 + // [624] status_smc#0 = display_info_smc::info_status#10 -- vbum1=vbum2 lda info_status sta status_smc // display_smc_led(status_color[info_status]) - // [970] display_smc_led::c#1 = status_color[display_info_smc::info_status#20] -- vbum1=pbuc1_derefidx_vbum2 + // [625] display_smc_led::c#1 = status_color[display_info_smc::info_status#10] -- vbum1=pbuc1_derefidx_vbum2 ldy info_status lda status_color,y sta display_smc_led.c - // [971] call display_smc_led - // [2301] phi from display_info_smc::@4 to display_smc_led [phi:display_info_smc::@4->display_smc_led] - // [2301] phi display_smc_led::c#2 = display_smc_led::c#1 [phi:display_info_smc::@4->display_smc_led#0] -- register_copy + // [626] call display_smc_led + // [1354] phi from display_info_smc::@4 to display_smc_led [phi:display_info_smc::@4->display_smc_led] + // [1354] phi display_smc_led::c#2 = display_smc_led::c#1 [phi:display_info_smc::@4->display_smc_led#0] -- register_copy jsr display_smc_led - // [972] phi from display_info_smc::@4 to display_info_smc::@5 [phi:display_info_smc::@4->display_info_smc::@5] + // [627] phi from display_info_smc::@4 to display_info_smc::@5 [phi:display_info_smc::@4->display_info_smc::@5] // display_info_smc::@5 // gotoxy(INFO_X, INFO_Y) - // [973] call gotoxy - // [802] phi from display_info_smc::@5 to gotoxy [phi:display_info_smc::@5->gotoxy] - // [802] phi gotoxy::y#37 = $11 [phi:display_info_smc::@5->gotoxy#0] -- vbum1=vbuc1 + // [628] call gotoxy + // [457] phi from display_info_smc::@5 to gotoxy [phi:display_info_smc::@5->gotoxy] + // [457] phi gotoxy::y#26 = $11 [phi:display_info_smc::@5->gotoxy#0] -- vbum1=vbuc1 lda #$11 sta gotoxy.y - // [802] phi gotoxy::x#37 = 4 [phi:display_info_smc::@5->gotoxy#1] -- vbum1=vbuc1 + // [457] phi gotoxy::x#26 = 4 [phi:display_info_smc::@5->gotoxy#1] -- vbum1=vbuc1 lda #4 sta gotoxy.x jsr gotoxy - // [974] phi from display_info_smc::@5 to display_info_smc::@6 [phi:display_info_smc::@5->display_info_smc::@6] + // [629] phi from display_info_smc::@5 to display_info_smc::@6 [phi:display_info_smc::@5->display_info_smc::@6] // display_info_smc::@6 // printf("SMC %-9s ATTiny %-8s BL:%u ", status_text[info_status], smc_version_text, smc_bootloader) - // [975] call printf_str - // [1210] phi from display_info_smc::@6 to printf_str [phi:display_info_smc::@6->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:display_info_smc::@6->printf_str#0] -- pprz1=pprc1 + // [630] call printf_str + // [785] phi from display_info_smc::@6 to printf_str [phi:display_info_smc::@6->printf_str] + // [785] phi printf_str::putc#53 = &cputc [phi:display_info_smc::@6->printf_str#0] -- pprz1=pprc1 lda #cputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = display_info_smc::s [phi:display_info_smc::@6->printf_str#1] -- pbuz1=pbuc1 + // [785] phi printf_str::s#53 = display_info_smc::s [phi:display_info_smc::@6->printf_str#1] -- pbuz1=pbuc1 lda #s @@ -6426,128 +3978,128 @@ display_info_smc: { jsr printf_str // display_info_smc::@7 // printf("SMC %-9s ATTiny %-8s BL:%u ", status_text[info_status], smc_version_text, smc_bootloader) - // [976] display_info_smc::$9 = display_info_smc::info_status#20 << 1 -- vbuz1=vbum2_rol_1 + // [631] display_info_smc::$9 = display_info_smc::info_status#10 << 1 -- vbuz1=vbum2_rol_1 lda info_status asl sta.z display_info_smc__9 - // [977] printf_string::str#3 = status_text[display_info_smc::$9] -- pbuz1=qbuc1_derefidx_vbuz2 + // [632] printf_string::str#3 = status_text[display_info_smc::$9] -- pbuz1=qbuc1_derefidx_vbuz2 tay lda status_text,y sta.z printf_string.str lda status_text+1,y sta.z printf_string.str+1 - // [978] call printf_string - // [1219] phi from display_info_smc::@7 to printf_string [phi:display_info_smc::@7->printf_string] - // [1219] phi printf_string::putc#26 = &cputc [phi:display_info_smc::@7->printf_string#0] -- pprz1=pprc1 + // [633] call printf_string + // [1308] phi from display_info_smc::@7 to printf_string [phi:display_info_smc::@7->printf_string] + // [1308] phi printf_string::putc#17 = &cputc [phi:display_info_smc::@7->printf_string#0] -- pprz1=pprc1 lda #cputc sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#3 [phi:display_info_smc::@7->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 1 [phi:display_info_smc::@7->printf_string#2] -- vbum1=vbuc1 + // [1308] phi printf_string::str#17 = printf_string::str#3 [phi:display_info_smc::@7->printf_string#1] -- register_copy + // [1308] phi printf_string::format_justify_left#17 = 1 [phi:display_info_smc::@7->printf_string#2] -- vbum1=vbuc1 lda #1 sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = 9 [phi:display_info_smc::@7->printf_string#3] -- vbum1=vbuc1 + // [1308] phi printf_string::format_min_length#17 = 9 [phi:display_info_smc::@7->printf_string#3] -- vbum1=vbuc1 lda #9 sta printf_string.format_min_length jsr printf_string - // [979] phi from display_info_smc::@7 to display_info_smc::@8 [phi:display_info_smc::@7->display_info_smc::@8] + // [634] phi from display_info_smc::@7 to display_info_smc::@8 [phi:display_info_smc::@7->display_info_smc::@8] // display_info_smc::@8 // printf("SMC %-9s ATTiny %-8s BL:%u ", status_text[info_status], smc_version_text, smc_bootloader) - // [980] call printf_str - // [1210] phi from display_info_smc::@8 to printf_str [phi:display_info_smc::@8->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:display_info_smc::@8->printf_str#0] -- pprz1=pprc1 + // [635] call printf_str + // [785] phi from display_info_smc::@8 to printf_str [phi:display_info_smc::@8->printf_str] + // [785] phi printf_str::putc#53 = &cputc [phi:display_info_smc::@8->printf_str#0] -- pprz1=pprc1 lda #cputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = display_info_smc::s1 [phi:display_info_smc::@8->printf_str#1] -- pbuz1=pbuc1 + // [785] phi printf_str::s#53 = display_info_smc::s1 [phi:display_info_smc::@8->printf_str#1] -- pbuz1=pbuc1 lda #s1 sta.z printf_str.s+1 jsr printf_str - // [981] phi from display_info_smc::@8 to display_info_smc::@9 [phi:display_info_smc::@8->display_info_smc::@9] + // [636] phi from display_info_smc::@8 to display_info_smc::@9 [phi:display_info_smc::@8->display_info_smc::@9] // display_info_smc::@9 // printf("SMC %-9s ATTiny %-8s BL:%u ", status_text[info_status], smc_version_text, smc_bootloader) - // [982] call printf_string - // [1219] phi from display_info_smc::@9 to printf_string [phi:display_info_smc::@9->printf_string] - // [1219] phi printf_string::putc#26 = &cputc [phi:display_info_smc::@9->printf_string#0] -- pprz1=pprc1 + // [637] call printf_string + // [1308] phi from display_info_smc::@9 to printf_string [phi:display_info_smc::@9->printf_string] + // [1308] phi printf_string::putc#17 = &cputc [phi:display_info_smc::@9->printf_string#0] -- pprz1=pprc1 lda #cputc sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = smc_version_text [phi:display_info_smc::@9->printf_string#1] -- pbuz1=pbuc1 + // [1308] phi printf_string::str#17 = smc_version_text [phi:display_info_smc::@9->printf_string#1] -- pbuz1=pbuc1 lda #smc_version_text sta.z printf_string.str+1 - // [1219] phi printf_string::format_justify_left#26 = 1 [phi:display_info_smc::@9->printf_string#2] -- vbum1=vbuc1 + // [1308] phi printf_string::format_justify_left#17 = 1 [phi:display_info_smc::@9->printf_string#2] -- vbum1=vbuc1 lda #1 sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = 8 [phi:display_info_smc::@9->printf_string#3] -- vbum1=vbuc1 + // [1308] phi printf_string::format_min_length#17 = 8 [phi:display_info_smc::@9->printf_string#3] -- vbum1=vbuc1 lda #8 sta printf_string.format_min_length jsr printf_string - // [983] phi from display_info_smc::@9 to display_info_smc::@10 [phi:display_info_smc::@9->display_info_smc::@10] + // [638] phi from display_info_smc::@9 to display_info_smc::@10 [phi:display_info_smc::@9->display_info_smc::@10] // display_info_smc::@10 // printf("SMC %-9s ATTiny %-8s BL:%u ", status_text[info_status], smc_version_text, smc_bootloader) - // [984] call printf_str - // [1210] phi from display_info_smc::@10 to printf_str [phi:display_info_smc::@10->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:display_info_smc::@10->printf_str#0] -- pprz1=pprc1 + // [639] call printf_str + // [785] phi from display_info_smc::@10 to printf_str [phi:display_info_smc::@10->printf_str] + // [785] phi printf_str::putc#53 = &cputc [phi:display_info_smc::@10->printf_str#0] -- pprz1=pprc1 lda #cputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = display_info_smc::s2 [phi:display_info_smc::@10->printf_str#1] -- pbuz1=pbuc1 + // [785] phi printf_str::s#53 = display_info_smc::s2 [phi:display_info_smc::@10->printf_str#1] -- pbuz1=pbuc1 lda #s2 sta.z printf_str.s+1 jsr printf_str + // [640] phi from display_info_smc::@10 to display_info_smc::@11 [phi:display_info_smc::@10->display_info_smc::@11] // display_info_smc::@11 // printf("SMC %-9s ATTiny %-8s BL:%u ", status_text[info_status], smc_version_text, smc_bootloader) - // [985] printf_uint::uvalue#1 = smc_bootloader#14 -- vwum1=vwum2 - lda smc_bootloader_1 - sta printf_uint.uvalue - lda smc_bootloader_1+1 - sta printf_uint.uvalue+1 - // [986] call printf_uint - // [2086] phi from display_info_smc::@11 to printf_uint [phi:display_info_smc::@11->printf_uint] - // [2086] phi printf_uint::format_zero_padding#10 = 0 [phi:display_info_smc::@11->printf_uint#0] -- vbum1=vbuc1 + // [641] call printf_uint + // [1433] phi from display_info_smc::@11 to printf_uint [phi:display_info_smc::@11->printf_uint] + // [1433] phi printf_uint::format_zero_padding#4 = 0 [phi:display_info_smc::@11->printf_uint#0] -- vbum1=vbuc1 lda #0 sta printf_uint.format_zero_padding - // [2086] phi printf_uint::format_min_length#10 = 0 [phi:display_info_smc::@11->printf_uint#1] -- vbum1=vbuc1 + // [1433] phi printf_uint::format_min_length#4 = 0 [phi:display_info_smc::@11->printf_uint#1] -- vbum1=vbuc1 sta printf_uint.format_min_length - // [2086] phi printf_uint::putc#10 = &cputc [phi:display_info_smc::@11->printf_uint#2] -- pprz1=pprc1 + // [1433] phi printf_uint::putc#4 = &cputc [phi:display_info_smc::@11->printf_uint#2] -- pprz1=pprc1 lda #cputc sta.z printf_uint.putc+1 - // [2086] phi printf_uint::format_radix#10 = DECIMAL [phi:display_info_smc::@11->printf_uint#3] -- vbum1=vbuc1 + // [1433] phi printf_uint::format_radix#4 = DECIMAL [phi:display_info_smc::@11->printf_uint#3] -- vbum1=vbuc1 lda #DECIMAL sta printf_uint.format_radix - // [2086] phi printf_uint::uvalue#10 = printf_uint::uvalue#1 [phi:display_info_smc::@11->printf_uint#4] -- register_copy + // [1433] phi printf_uint::uvalue#4 = smc_bootloader [phi:display_info_smc::@11->printf_uint#4] -- vwum1=vwuc1 + lda #smc_bootloader + sta printf_uint.uvalue+1 jsr printf_uint - // [987] phi from display_info_smc::@11 to display_info_smc::@12 [phi:display_info_smc::@11->display_info_smc::@12] + // [642] phi from display_info_smc::@11 to display_info_smc::@12 [phi:display_info_smc::@11->display_info_smc::@12] // display_info_smc::@12 // printf("SMC %-9s ATTiny %-8s BL:%u ", status_text[info_status], smc_version_text, smc_bootloader) - // [988] call printf_str - // [1210] phi from display_info_smc::@12 to printf_str [phi:display_info_smc::@12->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:display_info_smc::@12->printf_str#0] -- pprz1=pprc1 + // [643] call printf_str + // [785] phi from display_info_smc::@12 to printf_str [phi:display_info_smc::@12->printf_str] + // [785] phi printf_str::putc#53 = &cputc [phi:display_info_smc::@12->printf_str#0] -- pprz1=pprc1 lda #cputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s4 [phi:display_info_smc::@12->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #<@s sta.z printf_str.s - lda #>s4 + lda #>@s sta.z printf_str.s+1 jsr printf_str // display_info_smc::@13 // if(info_text) - // [989] if((char *)0==display_info_smc::info_text#20) goto display_info_smc::@1 -- pbuc1_eq_pbuz1_then_la1 + // [644] if((char *)0==display_info_smc::info_text#10) goto display_info_smc::@1 -- pbuc1_eq_pbuz1_then_la1 lda.z info_text cmp #<0 bne !+ @@ -6555,57 +4107,57 @@ display_info_smc: { cmp #>0 beq __b1 !: - // [990] phi from display_info_smc::@13 to display_info_smc::@2 [phi:display_info_smc::@13->display_info_smc::@2] + // [645] phi from display_info_smc::@13 to display_info_smc::@2 [phi:display_info_smc::@13->display_info_smc::@2] // display_info_smc::@2 // gotoxy(INFO_X+64-28, INFO_Y) - // [991] call gotoxy - // [802] phi from display_info_smc::@2 to gotoxy [phi:display_info_smc::@2->gotoxy] - // [802] phi gotoxy::y#37 = $11 [phi:display_info_smc::@2->gotoxy#0] -- vbum1=vbuc1 + // [646] call gotoxy + // [457] phi from display_info_smc::@2 to gotoxy [phi:display_info_smc::@2->gotoxy] + // [457] phi gotoxy::y#26 = $11 [phi:display_info_smc::@2->gotoxy#0] -- vbum1=vbuc1 lda #$11 sta gotoxy.y - // [802] phi gotoxy::x#37 = 4+$40-$1c [phi:display_info_smc::@2->gotoxy#1] -- vbum1=vbuc1 + // [457] phi gotoxy::x#26 = 4+$40-$1c [phi:display_info_smc::@2->gotoxy#1] -- vbum1=vbuc1 lda #4+$40-$1c sta gotoxy.x jsr gotoxy // display_info_smc::@14 // printf("%-25s", info_text) - // [992] printf_string::str#5 = display_info_smc::info_text#20 -- pbuz1=pbuz2 + // [647] printf_string::str#5 = display_info_smc::info_text#10 -- pbuz1=pbuz2 lda.z info_text sta.z printf_string.str lda.z info_text+1 sta.z printf_string.str+1 - // [993] call printf_string - // [1219] phi from display_info_smc::@14 to printf_string [phi:display_info_smc::@14->printf_string] - // [1219] phi printf_string::putc#26 = &cputc [phi:display_info_smc::@14->printf_string#0] -- pprz1=pprc1 + // [648] call printf_string + // [1308] phi from display_info_smc::@14 to printf_string [phi:display_info_smc::@14->printf_string] + // [1308] phi printf_string::putc#17 = &cputc [phi:display_info_smc::@14->printf_string#0] -- pprz1=pprc1 lda #cputc sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#5 [phi:display_info_smc::@14->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 1 [phi:display_info_smc::@14->printf_string#2] -- vbum1=vbuc1 + // [1308] phi printf_string::str#17 = printf_string::str#5 [phi:display_info_smc::@14->printf_string#1] -- register_copy + // [1308] phi printf_string::format_justify_left#17 = 1 [phi:display_info_smc::@14->printf_string#2] -- vbum1=vbuc1 lda #1 sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = $19 [phi:display_info_smc::@14->printf_string#3] -- vbum1=vbuc1 + // [1308] phi printf_string::format_min_length#17 = $19 [phi:display_info_smc::@14->printf_string#3] -- vbum1=vbuc1 lda #$19 sta printf_string.format_min_length jsr printf_string // display_info_smc::@1 __b1: // gotoxy(x, y) - // [994] gotoxy::x#18 = display_info_smc::x#0 -- vbum1=vbum2 + // [649] gotoxy::x#18 = display_info_smc::x#0 -- vbum1=vbum2 lda x sta gotoxy.x - // [995] gotoxy::y#18 = display_info_smc::y#0 -- vbum1=vbum2 + // [650] gotoxy::y#18 = display_info_smc::y#0 -- vbum1=vbum2 lda y sta gotoxy.y - // [996] call gotoxy - // [802] phi from display_info_smc::@1 to gotoxy [phi:display_info_smc::@1->gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#18 [phi:display_info_smc::@1->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = gotoxy::x#18 [phi:display_info_smc::@1->gotoxy#1] -- register_copy + // [651] call gotoxy + // [457] phi from display_info_smc::@1 to gotoxy [phi:display_info_smc::@1->gotoxy] + // [457] phi gotoxy::y#26 = gotoxy::y#18 [phi:display_info_smc::@1->gotoxy#0] -- register_copy + // [457] phi gotoxy::x#26 = gotoxy::x#18 [phi:display_info_smc::@1->gotoxy#1] -- register_copy jsr gotoxy // display_info_smc::@return // } - // [997] return + // [652] return rts .segment Data s: .text "SMC " @@ -6625,62 +4177,62 @@ display_info_smc: { * * @param info_status The STATUS_ */ -// void display_info_vera(__mem() char info_status, __zp($5e) char *info_text) +// void display_info_vera(__mem() char info_status, __zp($36) char *info_text) display_info_vera: { - .label display_info_vera__9 = $42 - .label info_text = $5e + .label display_info_vera__9 = $4e + .label info_text = $36 // unsigned char x = wherex() - // [999] call wherex + // [654] call wherex jsr wherex - // [1000] wherex::return#11 = wherex::return#0 -- vbum1=vbum2 + // [655] wherex::return#11 = wherex::return#0 -- vbum1=vbum2 lda wherex.return sta wherex.return_3 // display_info_vera::@3 - // [1001] display_info_vera::x#0 = wherex::return#11 + // [656] display_info_vera::x#0 = wherex::return#11 // unsigned char y = wherey() - // [1002] call wherey + // [657] call wherey jsr wherey - // [1003] wherey::return#11 = wherey::return#0 -- vbum1=vbum2 + // [658] wherey::return#11 = wherey::return#0 -- vbum1=vbum2 lda wherey.return sta wherey.return_3 // display_info_vera::@4 - // [1004] display_info_vera::y#0 = wherey::return#11 + // [659] display_info_vera::y#0 = wherey::return#11 // status_vera = info_status - // [1005] status_vera#127 = display_info_vera::info_status#19 -- vbum1=vbum2 + // [660] status_vera#127 = display_info_vera::info_status#19 -- vbum1=vbum2 lda info_status sta status_vera // display_vera_led(status_color[info_status]) - // [1006] display_vera_led::c#1 = status_color[display_info_vera::info_status#19] -- vbum1=pbuc1_derefidx_vbum2 + // [661] display_vera_led::c#1 = status_color[display_info_vera::info_status#19] -- vbum1=pbuc1_derefidx_vbum2 ldy info_status lda status_color,y sta display_vera_led.c - // [1007] call display_vera_led - // [2351] phi from display_info_vera::@4 to display_vera_led [phi:display_info_vera::@4->display_vera_led] - // [2351] phi display_vera_led::c#2 = display_vera_led::c#1 [phi:display_info_vera::@4->display_vera_led#0] -- register_copy + // [662] call display_vera_led + // [1404] phi from display_info_vera::@4 to display_vera_led [phi:display_info_vera::@4->display_vera_led] + // [1404] phi display_vera_led::c#2 = display_vera_led::c#1 [phi:display_info_vera::@4->display_vera_led#0] -- register_copy jsr display_vera_led - // [1008] phi from display_info_vera::@4 to display_info_vera::@5 [phi:display_info_vera::@4->display_info_vera::@5] + // [663] phi from display_info_vera::@4 to display_info_vera::@5 [phi:display_info_vera::@4->display_info_vera::@5] // display_info_vera::@5 // gotoxy(INFO_X, INFO_Y+1) - // [1009] call gotoxy - // [802] phi from display_info_vera::@5 to gotoxy [phi:display_info_vera::@5->gotoxy] - // [802] phi gotoxy::y#37 = $11+1 [phi:display_info_vera::@5->gotoxy#0] -- vbum1=vbuc1 + // [664] call gotoxy + // [457] phi from display_info_vera::@5 to gotoxy [phi:display_info_vera::@5->gotoxy] + // [457] phi gotoxy::y#26 = $11+1 [phi:display_info_vera::@5->gotoxy#0] -- vbum1=vbuc1 lda #$11+1 sta gotoxy.y - // [802] phi gotoxy::x#37 = 4 [phi:display_info_vera::@5->gotoxy#1] -- vbum1=vbuc1 + // [457] phi gotoxy::x#26 = 4 [phi:display_info_vera::@5->gotoxy#1] -- vbum1=vbuc1 lda #4 sta gotoxy.x jsr gotoxy - // [1010] phi from display_info_vera::@5 to display_info_vera::@6 [phi:display_info_vera::@5->display_info_vera::@6] + // [665] phi from display_info_vera::@5 to display_info_vera::@6 [phi:display_info_vera::@5->display_info_vera::@6] // display_info_vera::@6 // printf("VERA %-9s SPI %0x %0x %0x ", status_text[info_status], spi_manufacturer, spi_memory_type, spi_memory_capacity) - // [1011] call printf_str - // [1210] phi from display_info_vera::@6 to printf_str [phi:display_info_vera::@6->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:display_info_vera::@6->printf_str#0] -- pprz1=pprc1 + // [666] call printf_str + // [785] phi from display_info_vera::@6 to printf_str [phi:display_info_vera::@6->printf_str] + // [785] phi printf_str::putc#53 = &cputc [phi:display_info_vera::@6->printf_str#0] -- pprz1=pprc1 lda #cputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = display_info_vera::s [phi:display_info_vera::@6->printf_str#1] -- pbuz1=pbuc1 + // [785] phi printf_str::s#53 = display_info_vera::s [phi:display_info_vera::@6->printf_str#1] -- pbuz1=pbuc1 lda #s @@ -6688,42 +4240,42 @@ display_info_vera: { jsr printf_str // display_info_vera::@7 // printf("VERA %-9s SPI %0x %0x %0x ", status_text[info_status], spi_manufacturer, spi_memory_type, spi_memory_capacity) - // [1012] display_info_vera::$9 = display_info_vera::info_status#19 << 1 -- vbuz1=vbum2_rol_1 + // [667] display_info_vera::$9 = display_info_vera::info_status#19 << 1 -- vbuz1=vbum2_rol_1 lda info_status asl sta.z display_info_vera__9 - // [1013] printf_string::str#6 = status_text[display_info_vera::$9] -- pbuz1=qbuc1_derefidx_vbuz2 + // [668] printf_string::str#6 = status_text[display_info_vera::$9] -- pbuz1=qbuc1_derefidx_vbuz2 tay lda status_text,y sta.z printf_string.str lda status_text+1,y sta.z printf_string.str+1 - // [1014] call printf_string - // [1219] phi from display_info_vera::@7 to printf_string [phi:display_info_vera::@7->printf_string] - // [1219] phi printf_string::putc#26 = &cputc [phi:display_info_vera::@7->printf_string#0] -- pprz1=pprc1 + // [669] call printf_string + // [1308] phi from display_info_vera::@7 to printf_string [phi:display_info_vera::@7->printf_string] + // [1308] phi printf_string::putc#17 = &cputc [phi:display_info_vera::@7->printf_string#0] -- pprz1=pprc1 lda #cputc sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#6 [phi:display_info_vera::@7->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 1 [phi:display_info_vera::@7->printf_string#2] -- vbum1=vbuc1 + // [1308] phi printf_string::str#17 = printf_string::str#6 [phi:display_info_vera::@7->printf_string#1] -- register_copy + // [1308] phi printf_string::format_justify_left#17 = 1 [phi:display_info_vera::@7->printf_string#2] -- vbum1=vbuc1 lda #1 sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = 9 [phi:display_info_vera::@7->printf_string#3] -- vbum1=vbuc1 + // [1308] phi printf_string::format_min_length#17 = 9 [phi:display_info_vera::@7->printf_string#3] -- vbum1=vbuc1 lda #9 sta printf_string.format_min_length jsr printf_string - // [1015] phi from display_info_vera::@7 to display_info_vera::@8 [phi:display_info_vera::@7->display_info_vera::@8] + // [670] phi from display_info_vera::@7 to display_info_vera::@8 [phi:display_info_vera::@7->display_info_vera::@8] // display_info_vera::@8 // printf("VERA %-9s SPI %0x %0x %0x ", status_text[info_status], spi_manufacturer, spi_memory_type, spi_memory_capacity) - // [1016] call printf_str - // [1210] phi from display_info_vera::@8 to printf_str [phi:display_info_vera::@8->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:display_info_vera::@8->printf_str#0] -- pprz1=pprc1 + // [671] call printf_str + // [785] phi from display_info_vera::@8 to printf_str [phi:display_info_vera::@8->printf_str] + // [785] phi printf_str::putc#53 = &cputc [phi:display_info_vera::@8->printf_str#0] -- pprz1=pprc1 lda #cputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = display_info_vera::s1 [phi:display_info_vera::@8->printf_str#1] -- pbuz1=pbuc1 + // [785] phi printf_str::s#53 = display_info_vera::s1 [phi:display_info_vera::@8->printf_str#1] -- pbuz1=pbuc1 lda #s1 @@ -6731,116 +4283,116 @@ display_info_vera: { jsr printf_str // display_info_vera::@9 // printf("VERA %-9s SPI %0x %0x %0x ", status_text[info_status], spi_manufacturer, spi_memory_type, spi_memory_capacity) - // [1017] printf_uchar::uvalue#1 = spi_manufacturer#108 -- vbum1=vbum2 + // [672] printf_uchar::uvalue#1 = spi_manufacturer#100 -- vbum1=vbum2 lda spi_manufacturer sta printf_uchar.uvalue - // [1018] call printf_uchar - // [1346] phi from display_info_vera::@9 to printf_uchar [phi:display_info_vera::@9->printf_uchar] - // [1346] phi printf_uchar::format_zero_padding#18 = 1 [phi:display_info_vera::@9->printf_uchar#0] -- vbum1=vbuc1 + // [673] call printf_uchar + // [834] phi from display_info_vera::@9 to printf_uchar [phi:display_info_vera::@9->printf_uchar] + // [834] phi printf_uchar::format_zero_padding#10 = 1 [phi:display_info_vera::@9->printf_uchar#0] -- vbum1=vbuc1 lda #1 sta printf_uchar.format_zero_padding - // [1346] phi printf_uchar::format_min_length#18 = 0 [phi:display_info_vera::@9->printf_uchar#1] -- vbum1=vbuc1 + // [834] phi printf_uchar::format_min_length#10 = 0 [phi:display_info_vera::@9->printf_uchar#1] -- vbum1=vbuc1 lda #0 sta printf_uchar.format_min_length - // [1346] phi printf_uchar::putc#18 = &cputc [phi:display_info_vera::@9->printf_uchar#2] -- pprz1=pprc1 + // [834] phi printf_uchar::putc#10 = &cputc [phi:display_info_vera::@9->printf_uchar#2] -- pprz1=pprc1 lda #cputc sta.z printf_uchar.putc+1 - // [1346] phi printf_uchar::format_radix#18 = HEXADECIMAL [phi:display_info_vera::@9->printf_uchar#3] -- vbum1=vbuc1 + // [834] phi printf_uchar::format_radix#10 = HEXADECIMAL [phi:display_info_vera::@9->printf_uchar#3] -- vbum1=vbuc1 lda #HEXADECIMAL sta printf_uchar.format_radix - // [1346] phi printf_uchar::uvalue#18 = printf_uchar::uvalue#1 [phi:display_info_vera::@9->printf_uchar#4] -- register_copy + // [834] phi printf_uchar::uvalue#10 = printf_uchar::uvalue#1 [phi:display_info_vera::@9->printf_uchar#4] -- register_copy jsr printf_uchar - // [1019] phi from display_info_vera::@9 to display_info_vera::@10 [phi:display_info_vera::@9->display_info_vera::@10] + // [674] phi from display_info_vera::@9 to display_info_vera::@10 [phi:display_info_vera::@9->display_info_vera::@10] // display_info_vera::@10 // printf("VERA %-9s SPI %0x %0x %0x ", status_text[info_status], spi_manufacturer, spi_memory_type, spi_memory_capacity) - // [1020] call printf_str - // [1210] phi from display_info_vera::@10 to printf_str [phi:display_info_vera::@10->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:display_info_vera::@10->printf_str#0] -- pprz1=pprc1 + // [675] call printf_str + // [785] phi from display_info_vera::@10 to printf_str [phi:display_info_vera::@10->printf_str] + // [785] phi printf_str::putc#53 = &cputc [phi:display_info_vera::@10->printf_str#0] -- pprz1=pprc1 lda #cputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s4 [phi:display_info_vera::@10->printf_str#1] -- pbuz1=pbuc1 - lda #<@s4 + // [785] phi printf_str::s#53 = s [phi:display_info_vera::@10->printf_str#1] -- pbuz1=pbuc1 + lda #<@s sta.z printf_str.s - lda #>@s4 + lda #>@s sta.z printf_str.s+1 jsr printf_str // display_info_vera::@11 // printf("VERA %-9s SPI %0x %0x %0x ", status_text[info_status], spi_manufacturer, spi_memory_type, spi_memory_capacity) - // [1021] printf_uchar::uvalue#2 = spi_memory_type#107 -- vbum1=vbum2 + // [676] printf_uchar::uvalue#2 = spi_memory_type#111 -- vbum1=vbum2 lda spi_memory_type sta printf_uchar.uvalue - // [1022] call printf_uchar - // [1346] phi from display_info_vera::@11 to printf_uchar [phi:display_info_vera::@11->printf_uchar] - // [1346] phi printf_uchar::format_zero_padding#18 = 1 [phi:display_info_vera::@11->printf_uchar#0] -- vbum1=vbuc1 + // [677] call printf_uchar + // [834] phi from display_info_vera::@11 to printf_uchar [phi:display_info_vera::@11->printf_uchar] + // [834] phi printf_uchar::format_zero_padding#10 = 1 [phi:display_info_vera::@11->printf_uchar#0] -- vbum1=vbuc1 lda #1 sta printf_uchar.format_zero_padding - // [1346] phi printf_uchar::format_min_length#18 = 0 [phi:display_info_vera::@11->printf_uchar#1] -- vbum1=vbuc1 + // [834] phi printf_uchar::format_min_length#10 = 0 [phi:display_info_vera::@11->printf_uchar#1] -- vbum1=vbuc1 lda #0 sta printf_uchar.format_min_length - // [1346] phi printf_uchar::putc#18 = &cputc [phi:display_info_vera::@11->printf_uchar#2] -- pprz1=pprc1 + // [834] phi printf_uchar::putc#10 = &cputc [phi:display_info_vera::@11->printf_uchar#2] -- pprz1=pprc1 lda #cputc sta.z printf_uchar.putc+1 - // [1346] phi printf_uchar::format_radix#18 = HEXADECIMAL [phi:display_info_vera::@11->printf_uchar#3] -- vbum1=vbuc1 + // [834] phi printf_uchar::format_radix#10 = HEXADECIMAL [phi:display_info_vera::@11->printf_uchar#3] -- vbum1=vbuc1 lda #HEXADECIMAL sta printf_uchar.format_radix - // [1346] phi printf_uchar::uvalue#18 = printf_uchar::uvalue#2 [phi:display_info_vera::@11->printf_uchar#4] -- register_copy + // [834] phi printf_uchar::uvalue#10 = printf_uchar::uvalue#2 [phi:display_info_vera::@11->printf_uchar#4] -- register_copy jsr printf_uchar - // [1023] phi from display_info_vera::@11 to display_info_vera::@12 [phi:display_info_vera::@11->display_info_vera::@12] + // [678] phi from display_info_vera::@11 to display_info_vera::@12 [phi:display_info_vera::@11->display_info_vera::@12] // display_info_vera::@12 // printf("VERA %-9s SPI %0x %0x %0x ", status_text[info_status], spi_manufacturer, spi_memory_type, spi_memory_capacity) - // [1024] call printf_str - // [1210] phi from display_info_vera::@12 to printf_str [phi:display_info_vera::@12->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:display_info_vera::@12->printf_str#0] -- pprz1=pprc1 + // [679] call printf_str + // [785] phi from display_info_vera::@12 to printf_str [phi:display_info_vera::@12->printf_str] + // [785] phi printf_str::putc#53 = &cputc [phi:display_info_vera::@12->printf_str#0] -- pprz1=pprc1 lda #cputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s4 [phi:display_info_vera::@12->printf_str#1] -- pbuz1=pbuc1 - lda #<@s4 + // [785] phi printf_str::s#53 = s [phi:display_info_vera::@12->printf_str#1] -- pbuz1=pbuc1 + lda #<@s sta.z printf_str.s - lda #>@s4 + lda #>@s sta.z printf_str.s+1 jsr printf_str // display_info_vera::@13 // printf("VERA %-9s SPI %0x %0x %0x ", status_text[info_status], spi_manufacturer, spi_memory_type, spi_memory_capacity) - // [1025] printf_uchar::uvalue#3 = spi_memory_capacity#106 -- vbum1=vbum2 + // [680] printf_uchar::uvalue#3 = spi_memory_capacity#110 -- vbum1=vbum2 lda spi_memory_capacity sta printf_uchar.uvalue - // [1026] call printf_uchar - // [1346] phi from display_info_vera::@13 to printf_uchar [phi:display_info_vera::@13->printf_uchar] - // [1346] phi printf_uchar::format_zero_padding#18 = 1 [phi:display_info_vera::@13->printf_uchar#0] -- vbum1=vbuc1 + // [681] call printf_uchar + // [834] phi from display_info_vera::@13 to printf_uchar [phi:display_info_vera::@13->printf_uchar] + // [834] phi printf_uchar::format_zero_padding#10 = 1 [phi:display_info_vera::@13->printf_uchar#0] -- vbum1=vbuc1 lda #1 sta printf_uchar.format_zero_padding - // [1346] phi printf_uchar::format_min_length#18 = 0 [phi:display_info_vera::@13->printf_uchar#1] -- vbum1=vbuc1 + // [834] phi printf_uchar::format_min_length#10 = 0 [phi:display_info_vera::@13->printf_uchar#1] -- vbum1=vbuc1 lda #0 sta printf_uchar.format_min_length - // [1346] phi printf_uchar::putc#18 = &cputc [phi:display_info_vera::@13->printf_uchar#2] -- pprz1=pprc1 + // [834] phi printf_uchar::putc#10 = &cputc [phi:display_info_vera::@13->printf_uchar#2] -- pprz1=pprc1 lda #cputc sta.z printf_uchar.putc+1 - // [1346] phi printf_uchar::format_radix#18 = HEXADECIMAL [phi:display_info_vera::@13->printf_uchar#3] -- vbum1=vbuc1 + // [834] phi printf_uchar::format_radix#10 = HEXADECIMAL [phi:display_info_vera::@13->printf_uchar#3] -- vbum1=vbuc1 lda #HEXADECIMAL sta printf_uchar.format_radix - // [1346] phi printf_uchar::uvalue#18 = printf_uchar::uvalue#3 [phi:display_info_vera::@13->printf_uchar#4] -- register_copy + // [834] phi printf_uchar::uvalue#10 = printf_uchar::uvalue#3 [phi:display_info_vera::@13->printf_uchar#4] -- register_copy jsr printf_uchar - // [1027] phi from display_info_vera::@13 to display_info_vera::@14 [phi:display_info_vera::@13->display_info_vera::@14] + // [682] phi from display_info_vera::@13 to display_info_vera::@14 [phi:display_info_vera::@13->display_info_vera::@14] // display_info_vera::@14 // printf("VERA %-9s SPI %0x %0x %0x ", status_text[info_status], spi_manufacturer, spi_memory_type, spi_memory_capacity) - // [1028] call printf_str - // [1210] phi from display_info_vera::@14 to printf_str [phi:display_info_vera::@14->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:display_info_vera::@14->printf_str#0] -- pprz1=pprc1 + // [683] call printf_str + // [785] phi from display_info_vera::@14 to printf_str [phi:display_info_vera::@14->printf_str] + // [785] phi printf_str::putc#53 = &cputc [phi:display_info_vera::@14->printf_str#0] -- pprz1=pprc1 lda #cputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = display_info_vera::s4 [phi:display_info_vera::@14->printf_str#1] -- pbuz1=pbuc1 + // [785] phi printf_str::s#53 = display_info_vera::s4 [phi:display_info_vera::@14->printf_str#1] -- pbuz1=pbuc1 lda #s4 @@ -6848,7 +4400,7 @@ display_info_vera: { jsr printf_str // display_info_vera::@15 // if(info_text) - // [1029] if((char *)0==display_info_vera::info_text#19) goto display_info_vera::@1 -- pbuc1_eq_pbuz1_then_la1 + // [684] if((char *)0==display_info_vera::info_text#19) goto display_info_vera::@1 -- pbuc1_eq_pbuz1_then_la1 lda.z info_text cmp #<0 bne !+ @@ -6856,57 +4408,57 @@ display_info_vera: { cmp #>0 beq __b1 !: - // [1030] phi from display_info_vera::@15 to display_info_vera::@2 [phi:display_info_vera::@15->display_info_vera::@2] + // [685] phi from display_info_vera::@15 to display_info_vera::@2 [phi:display_info_vera::@15->display_info_vera::@2] // display_info_vera::@2 // gotoxy(INFO_X+64-28, INFO_Y+1) - // [1031] call gotoxy - // [802] phi from display_info_vera::@2 to gotoxy [phi:display_info_vera::@2->gotoxy] - // [802] phi gotoxy::y#37 = $11+1 [phi:display_info_vera::@2->gotoxy#0] -- vbum1=vbuc1 + // [686] call gotoxy + // [457] phi from display_info_vera::@2 to gotoxy [phi:display_info_vera::@2->gotoxy] + // [457] phi gotoxy::y#26 = $11+1 [phi:display_info_vera::@2->gotoxy#0] -- vbum1=vbuc1 lda #$11+1 sta gotoxy.y - // [802] phi gotoxy::x#37 = 4+$40-$1c [phi:display_info_vera::@2->gotoxy#1] -- vbum1=vbuc1 + // [457] phi gotoxy::x#26 = 4+$40-$1c [phi:display_info_vera::@2->gotoxy#1] -- vbum1=vbuc1 lda #4+$40-$1c sta gotoxy.x jsr gotoxy // display_info_vera::@16 // printf("%-25s", info_text) - // [1032] printf_string::str#7 = display_info_vera::info_text#19 -- pbuz1=pbuz2 + // [687] printf_string::str#7 = display_info_vera::info_text#19 -- pbuz1=pbuz2 lda.z info_text sta.z printf_string.str lda.z info_text+1 sta.z printf_string.str+1 - // [1033] call printf_string - // [1219] phi from display_info_vera::@16 to printf_string [phi:display_info_vera::@16->printf_string] - // [1219] phi printf_string::putc#26 = &cputc [phi:display_info_vera::@16->printf_string#0] -- pprz1=pprc1 + // [688] call printf_string + // [1308] phi from display_info_vera::@16 to printf_string [phi:display_info_vera::@16->printf_string] + // [1308] phi printf_string::putc#17 = &cputc [phi:display_info_vera::@16->printf_string#0] -- pprz1=pprc1 lda #cputc sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#7 [phi:display_info_vera::@16->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 1 [phi:display_info_vera::@16->printf_string#2] -- vbum1=vbuc1 + // [1308] phi printf_string::str#17 = printf_string::str#7 [phi:display_info_vera::@16->printf_string#1] -- register_copy + // [1308] phi printf_string::format_justify_left#17 = 1 [phi:display_info_vera::@16->printf_string#2] -- vbum1=vbuc1 lda #1 sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = $19 [phi:display_info_vera::@16->printf_string#3] -- vbum1=vbuc1 + // [1308] phi printf_string::format_min_length#17 = $19 [phi:display_info_vera::@16->printf_string#3] -- vbum1=vbuc1 lda #$19 sta printf_string.format_min_length jsr printf_string // display_info_vera::@1 __b1: // gotoxy(x, y) - // [1034] gotoxy::x#21 = display_info_vera::x#0 -- vbum1=vbum2 + // [689] gotoxy::x#21 = display_info_vera::x#0 -- vbum1=vbum2 lda x sta gotoxy.x - // [1035] gotoxy::y#21 = display_info_vera::y#0 -- vbum1=vbum2 + // [690] gotoxy::y#21 = display_info_vera::y#0 -- vbum1=vbum2 lda y sta gotoxy.y - // [1036] call gotoxy - // [802] phi from display_info_vera::@1 to gotoxy [phi:display_info_vera::@1->gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#21 [phi:display_info_vera::@1->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = gotoxy::x#21 [phi:display_info_vera::@1->gotoxy#1] -- register_copy + // [691] call gotoxy + // [457] phi from display_info_vera::@1 to gotoxy [phi:display_info_vera::@1->gotoxy] + // [457] phi gotoxy::y#26 = gotoxy::y#21 [phi:display_info_vera::@1->gotoxy#0] -- register_copy + // [457] phi gotoxy::x#26 = gotoxy::x#21 [phi:display_info_vera::@1->gotoxy#1] -- register_copy jsr gotoxy // display_info_vera::@return // } - // [1037] return + // [692] return rts .segment Data s: .text "VERA " @@ -6922,2030 +4474,761 @@ display_info_vera: { .segment CodeIntro // main_intro main_intro: { - .label intro_status = $c7 + .label intro_status = $7a // display_progress_text(display_into_briefing_text, display_intro_briefing_count) - // [1039] call display_progress_text - // [1331] phi from main_intro to display_progress_text [phi:main_intro->display_progress_text] - // [1331] phi display_progress_text::text#13 = display_into_briefing_text [phi:main_intro->display_progress_text#0] -- qbuz1=qbuc1 + // [694] call display_progress_text + // [815] phi from main_intro to display_progress_text [phi:main_intro->display_progress_text] + // [815] phi display_progress_text::text#11 = display_into_briefing_text [phi:main_intro->display_progress_text#0] -- qbuz1=qbuc1 lda #display_into_briefing_text sta.z display_progress_text.text+1 - // [1331] phi display_progress_text::lines#12 = display_intro_briefing_count [phi:main_intro->display_progress_text#1] -- vbum1=vbuc1 + // [815] phi display_progress_text::lines#10 = display_intro_briefing_count [phi:main_intro->display_progress_text#1] -- vbum1=vbuc1 lda #display_intro_briefing_count sta display_progress_text.lines jsr display_progress_text - // [1040] phi from main_intro to main_intro::@4 [phi:main_intro->main_intro::@4] + // [695] phi from main_intro to main_intro::@4 [phi:main_intro->main_intro::@4] // main_intro::@4 // util_wait_space() - // [1041] call util_wait_space - // [1389] phi from main_intro::@4 to util_wait_space [phi:main_intro::@4->util_wait_space] + // [696] call util_wait_space + // [877] phi from main_intro::@4 to util_wait_space [phi:main_intro::@4->util_wait_space] jsr util_wait_space - // [1042] phi from main_intro::@4 to main_intro::@5 [phi:main_intro::@4->main_intro::@5] + // [697] phi from main_intro::@4 to main_intro::@5 [phi:main_intro::@4->main_intro::@5] // main_intro::@5 // display_progress_text(display_into_colors_text, display_intro_colors_count) - // [1043] call display_progress_text - // [1331] phi from main_intro::@5 to display_progress_text [phi:main_intro::@5->display_progress_text] - // [1331] phi display_progress_text::text#13 = display_into_colors_text [phi:main_intro::@5->display_progress_text#0] -- qbuz1=qbuc1 + // [698] call display_progress_text + // [815] phi from main_intro::@5 to display_progress_text [phi:main_intro::@5->display_progress_text] + // [815] phi display_progress_text::text#11 = display_into_colors_text [phi:main_intro::@5->display_progress_text#0] -- qbuz1=qbuc1 lda #display_into_colors_text sta.z display_progress_text.text+1 - // [1331] phi display_progress_text::lines#12 = display_intro_colors_count [phi:main_intro::@5->display_progress_text#1] -- vbum1=vbuc1 + // [815] phi display_progress_text::lines#10 = display_intro_colors_count [phi:main_intro::@5->display_progress_text#1] -- vbum1=vbuc1 lda #display_intro_colors_count sta display_progress_text.lines jsr display_progress_text - // [1044] phi from main_intro::@5 to main_intro::@1 [phi:main_intro::@5->main_intro::@1] - // [1044] phi main_intro::intro_status#2 = 0 [phi:main_intro::@5->main_intro::@1#0] -- vbuz1=vbuc1 + // [699] phi from main_intro::@5 to main_intro::@1 [phi:main_intro::@5->main_intro::@1] + // [699] phi main_intro::intro_status#2 = 0 [phi:main_intro::@5->main_intro::@1#0] -- vbuz1=vbuc1 lda #0 sta.z intro_status // main_intro::@1 __b1: // for(unsigned char intro_status=0; intro_status<11; intro_status++) - // [1045] if(main_intro::intro_status#2<$b) goto main_intro::@2 -- vbuz1_lt_vbuc1_then_la1 + // [700] if(main_intro::intro_status#2<$b) goto main_intro::@2 -- vbuz1_lt_vbuc1_then_la1 lda.z intro_status cmp #$b bcc __b2 - // [1046] phi from main_intro::@1 to main_intro::@3 [phi:main_intro::@1->main_intro::@3] + // [701] phi from main_intro::@1 to main_intro::@3 [phi:main_intro::@1->main_intro::@3] // main_intro::@3 // util_wait_space() - // [1047] call util_wait_space - // [1389] phi from main_intro::@3 to util_wait_space [phi:main_intro::@3->util_wait_space] + // [702] call util_wait_space + // [877] phi from main_intro::@3 to util_wait_space [phi:main_intro::@3->util_wait_space] jsr util_wait_space - // [1048] phi from main_intro::@3 to main_intro::@7 [phi:main_intro::@3->main_intro::@7] + // [703] phi from main_intro::@3 to main_intro::@7 [phi:main_intro::@3->main_intro::@7] // main_intro::@7 // display_progress_clear() - // [1049] call display_progress_clear - // [918] phi from main_intro::@7 to display_progress_clear [phi:main_intro::@7->display_progress_clear] + // [704] call display_progress_clear + // [573] phi from main_intro::@7 to display_progress_clear [phi:main_intro::@7->display_progress_clear] jsr display_progress_clear // main_intro::@return // } - // [1050] return + // [705] return rts // main_intro::@2 __b2: // display_info_led(PROGRESS_X + 3, PROGRESS_Y + 3 + intro_status, status_color[intro_status], BLUE) - // [1051] display_info_led::y#3 = PROGRESS_Y+3 + main_intro::intro_status#2 -- vbum1=vbuc1_plus_vbuz2 + // [706] display_info_led::y#3 = PROGRESS_Y+3 + main_intro::intro_status#2 -- vbum1=vbuc1_plus_vbuz2 lda #PROGRESS_Y+3 clc adc.z intro_status sta display_info_led.y - // [1052] display_info_led::tc#3 = status_color[main_intro::intro_status#2] -- vbum1=pbuc1_derefidx_vbuz2 + // [707] display_info_led::tc#3 = status_color[main_intro::intro_status#2] -- vbum1=pbuc1_derefidx_vbuz2 ldy.z intro_status lda status_color,y sta display_info_led.tc - // [1053] call display_info_led - // [2380] phi from main_intro::@2 to display_info_led [phi:main_intro::@2->display_info_led] - // [2380] phi display_info_led::y#4 = display_info_led::y#3 [phi:main_intro::@2->display_info_led#0] -- register_copy - // [2380] phi display_info_led::x#4 = PROGRESS_X+3 [phi:main_intro::@2->display_info_led#1] -- vbum1=vbuc1 + // [708] call display_info_led + // [1444] phi from main_intro::@2 to display_info_led [phi:main_intro::@2->display_info_led] + // [1444] phi display_info_led::y#4 = display_info_led::y#3 [phi:main_intro::@2->display_info_led#0] -- register_copy + // [1444] phi display_info_led::x#4 = PROGRESS_X+3 [phi:main_intro::@2->display_info_led#1] -- vbum1=vbuc1 lda #PROGRESS_X+3 sta display_info_led.x - // [2380] phi display_info_led::tc#4 = display_info_led::tc#3 [phi:main_intro::@2->display_info_led#2] -- register_copy + // [1444] phi display_info_led::tc#4 = display_info_led::tc#3 [phi:main_intro::@2->display_info_led#2] -- register_copy jsr display_info_led // main_intro::@6 // for(unsigned char intro_status=0; intro_status<11; intro_status++) - // [1054] main_intro::intro_status#1 = ++ main_intro::intro_status#2 -- vbuz1=_inc_vbuz1 + // [709] main_intro::intro_status#1 = ++ main_intro::intro_status#2 -- vbuz1=_inc_vbuz1 inc.z intro_status - // [1044] phi from main_intro::@6 to main_intro::@1 [phi:main_intro::@6->main_intro::@1] - // [1044] phi main_intro::intro_status#2 = main_intro::intro_status#1 [phi:main_intro::@6->main_intro::@1#0] -- register_copy + // [699] phi from main_intro::@6 to main_intro::@1 [phi:main_intro::@6->main_intro::@1] + // [699] phi main_intro::intro_status#2 = main_intro::intro_status#1 [phi:main_intro::@6->main_intro::@1#0] -- register_copy jmp __b1 } -.segment Code - // smc_detect -/** - * @brief Detect the SMC chip on the CX16 board, and the bootloader version contained in it. - * - * @return unsigned int bootloader version in the SMC chip, if all is OK. - * @return unsigned int 0x0100 if there is no bootloader in the SMC chip. - * @return unsigned int 0x0200 if there is a technical error reading or detecting the SMC chip. - */ -smc_detect: { - .label smc_detect__1 = $2b - // cx16_k_i2c_read_byte(FLASH_I2C_SMC_DEVICE, FLASH_I2C_SMC_OFFSET) - // [1055] cx16_k_i2c_read_byte::device = $42 -- vbum1=vbuc1 - lda #$42 - sta cx16_k_i2c_read_byte.device - // [1056] cx16_k_i2c_read_byte::offset = $8e -- vbum1=vbuc1 - lda #$8e - sta cx16_k_i2c_read_byte.offset - // [1057] call cx16_k_i2c_read_byte - jsr cx16_k_i2c_read_byte - // [1058] cx16_k_i2c_read_byte::return#10 = cx16_k_i2c_read_byte::return#1 - // smc_detect::@3 - // smc_bootloader_version = cx16_k_i2c_read_byte(FLASH_I2C_SMC_DEVICE, FLASH_I2C_SMC_OFFSET) - // [1059] smc_detect::smc_bootloader_version#1 = cx16_k_i2c_read_byte::return#10 - // BYTE1(smc_bootloader_version) - // [1060] smc_detect::$1 = byte1 smc_detect::smc_bootloader_version#1 -- vbuz1=_byte1_vwum2 - lda smc_bootloader_version+1 - sta.z smc_detect__1 - // if(!BYTE1(smc_bootloader_version)) - // [1061] if(0==smc_detect::$1) goto smc_detect::@1 -- 0_eq_vbuz1_then_la1 - beq __b1 - // [1064] phi from smc_detect::@3 to smc_detect::@2 [phi:smc_detect::@3->smc_detect::@2] - // [1064] phi smc_detect::return#0 = $200 [phi:smc_detect::@3->smc_detect::@2#0] -- vwum1=vwuc1 - lda #<$200 - sta return - lda #>$200 - sta return+1 - rts - // smc_detect::@1 - __b1: - // if(smc_bootloader_version == 0xFF) - // [1062] if(smc_detect::smc_bootloader_version#1!=$ff) goto smc_detect::@4 -- vwum1_neq_vbuc1_then_la1 - lda smc_bootloader_version+1 - bne __b2 - lda smc_bootloader_version - cmp #$ff - bne __b2 - // [1064] phi from smc_detect::@1 to smc_detect::@2 [phi:smc_detect::@1->smc_detect::@2] - // [1064] phi smc_detect::return#0 = $100 [phi:smc_detect::@1->smc_detect::@2#0] -- vwum1=vwuc1 - lda #<$100 - sta return - lda #>$100 - sta return+1 - rts - // [1063] phi from smc_detect::@1 to smc_detect::@4 [phi:smc_detect::@1->smc_detect::@4] - // smc_detect::@4 - // [1064] phi from smc_detect::@4 to smc_detect::@2 [phi:smc_detect::@4->smc_detect::@2] - // [1064] phi smc_detect::return#0 = smc_detect::smc_bootloader_version#1 [phi:smc_detect::@4->smc_detect::@2#0] -- register_copy - // smc_detect::@2 - __b2: - // smc_detect::@return - // } - // [1065] return - rts - .segment Data - // When the bootloader is not present, 0xFF is returned. - .label smc_bootloader_version = return - return: .word 0 -} -.segment Code - // strcpy -// Copies the C string pointed by source into the array pointed by destination, including the terminating null character (and stopping at that point). -// char * strcpy(__zp($50) char *destination, char *source) -strcpy: { - .label src = $6c - .label dst = $50 - .label destination = $50 - // [1067] phi from strcpy strcpy::@2 to strcpy::@1 [phi:strcpy/strcpy::@2->strcpy::@1] - // [1067] phi strcpy::dst#2 = strcpy::dst#0 [phi:strcpy/strcpy::@2->strcpy::@1#0] -- register_copy - // [1067] phi strcpy::src#2 = strcpy::src#0 [phi:strcpy/strcpy::@2->strcpy::@1#1] -- register_copy - // strcpy::@1 - __b1: - // while(*src) - // [1068] if(0!=*strcpy::src#2) goto strcpy::@2 -- 0_neq__deref_pbuz1_then_la1 - ldy #0 - lda (src),y - cmp #0 - bne __b2 - // strcpy::@3 - // *dst = 0 - // [1069] *strcpy::dst#2 = 0 -- _deref_pbuz1=vbuc1 - tya - tay - sta (dst),y - // strcpy::@return - // } - // [1070] return - rts - // strcpy::@2 - __b2: - // *dst++ = *src++ - // [1071] *strcpy::dst#2 = *strcpy::src#2 -- _deref_pbuz1=_deref_pbuz2 - ldy #0 - lda (src),y - sta (dst),y - // *dst++ = *src++; - // [1072] strcpy::dst#1 = ++ strcpy::dst#2 -- pbuz1=_inc_pbuz1 - inc.z dst - bne !+ - inc.z dst+1 - !: - // [1073] strcpy::src#1 = ++ strcpy::src#2 -- pbuz1=_inc_pbuz1 - inc.z src - bne !+ - inc.z src+1 - !: - jmp __b1 -} - // cx16_k_i2c_read_byte -/** - * @brief Read a byte at a given offset from a given I2C device. - * Description: The routine i2c_read_byte reads a single byte - * at offset .Y from I2C device .X and returns the result in .A. - * .C is 0 if the read was successful, and 1 if no such device exists. - * @example - * LDX #$6F ; RTC device - * LDY #$20 ; start of NVRAM inside RTC - * JSR i2c_read_byte ; read first byte of NVRAM -*/ -// __mem() unsigned int cx16_k_i2c_read_byte(__mem() volatile char device, __mem() volatile char offset) -cx16_k_i2c_read_byte: { - // unsigned int result - // [1074] cx16_k_i2c_read_byte::result = 0 -- vwum1=vwuc1 +.segment CodeVera + // main_vera_detect +main_vera_detect: { + // vera_detect() + // [711] call vera_detect + // [1455] phi from main_vera_detect to vera_detect [phi:main_vera_detect->vera_detect] + jsr vera_detect + // [712] phi from main_vera_detect to main_vera_detect::@1 [phi:main_vera_detect->main_vera_detect::@1] + // main_vera_detect::@1 + // display_chip_vera() + // [713] call display_chip_vera + // [593] phi from main_vera_detect::@1 to display_chip_vera [phi:main_vera_detect::@1->display_chip_vera] + jsr display_chip_vera + // main_vera_detect::@2 + // [714] spi_manufacturer#410 = spi_read::return#0 -- vbum1=vbum2 + lda spi_read.return + sta spi_manufacturer + // [715] spi_memory_type#411 = spi_read::return#1 -- vbum1=vbum2 + lda spi_read.return_1 + sta spi_memory_type + // [716] spi_memory_capacity#412 = spi_read::return#2 -- vbum1=vbum2 + lda spi_read.return_2 + sta spi_memory_capacity + // display_info_vera(STATUS_DETECTED, NULL) + // [717] call display_info_vera + // [653] phi from main_vera_detect::@2 to display_info_vera [phi:main_vera_detect::@2->display_info_vera] + // [653] phi display_info_vera::info_text#19 = 0 [phi:main_vera_detect::@2->display_info_vera#0] -- pbuz1=vbuc1 lda #<0 - sta result - sta result+1 - // asm - // asm { ldxdevice ldyoffset stzresult+1 jsrCX16_I2C_READ_BYTE staresult rolresult+1 } - ldx device - ldy offset - stz result+1 - jsr CX16_I2C_READ_BYTE - sta result - rol result+1 - // return result; - // [1076] cx16_k_i2c_read_byte::return#0 = cx16_k_i2c_read_byte::result -- vwum1=vwum2 - sta return - lda result+1 - sta return+1 - // cx16_k_i2c_read_byte::@return + sta.z display_info_vera.info_text + sta.z display_info_vera.info_text+1 + // [653] phi spi_memory_capacity#110 = spi_memory_capacity#412 [phi:main_vera_detect::@2->display_info_vera#1] -- register_copy + // [653] phi spi_memory_type#111 = spi_memory_type#411 [phi:main_vera_detect::@2->display_info_vera#2] -- register_copy + // [653] phi spi_manufacturer#100 = spi_manufacturer#410 [phi:main_vera_detect::@2->display_info_vera#3] -- register_copy + // [653] phi display_info_vera::info_status#19 = STATUS_DETECTED [phi:main_vera_detect::@2->display_info_vera#4] -- vbum1=vbuc1 + lda #STATUS_DETECTED + sta display_info_vera.info_status + jsr display_info_vera + // main_vera_detect::@return // } - // [1077] cx16_k_i2c_read_byte::return#1 = cx16_k_i2c_read_byte::return#0 - // [1078] return + // [718] return rts - .segment Data - device: .byte 0 - offset: .byte 0 - result: .word 0 - .label return = smc_detect.return } -.segment Code - // smc_get_version_text -/** - * @brief Detect and write the SMC version number into the info_text. - * - * @param version_string The string containing the SMC version filled upon return. - */ -// unsigned long smc_get_version_text(__zp($45) char *version_string, __mem() char release, __mem() char major, __mem() char minor) -smc_get_version_text: { - .label version_string = $45 - // sprintf(version_string, "%u.%u.%u", release, major, minor) - // [1080] snprintf_init::s#4 = smc_get_version_text::version_string#2 - // [1081] call snprintf_init - // [1205] phi from smc_get_version_text to snprintf_init [phi:smc_get_version_text->snprintf_init] - // [1205] phi snprintf_init::s#31 = snprintf_init::s#4 [phi:smc_get_version_text->snprintf_init#0] -- register_copy + // main_vera_check +main_vera_check: { + .label vera_bytes_read = $ab + // display_action_progress("Checking VERA.BIN ...") + // [720] call display_action_progress + // [559] phi from main_vera_check to display_action_progress [phi:main_vera_check->display_action_progress] + // [559] phi display_action_progress::info_text#19 = main_vera_check::info_text [phi:main_vera_check->display_action_progress#0] -- pbuz1=pbuc1 + lda #info_text + sta.z display_action_progress.info_text+1 + jsr display_action_progress + // [721] phi from main_vera_check to main_vera_check::@4 [phi:main_vera_check->main_vera_check::@4] + // main_vera_check::@4 + // unsigned long vera_bytes_read = vera_read(STATUS_CHECKING) + // [722] call vera_read + // Read the VERA.BIN file. + // [1458] phi from main_vera_check::@4 to vera_read [phi:main_vera_check::@4->vera_read] + // [1458] phi __errno#118 = 0 [phi:main_vera_check::@4->vera_read#0] -- vwsm1=vwsc1 + lda #<0 + sta __errno + sta __errno+1 + // [1458] phi __stdio_filecount#105 = 0 [phi:main_vera_check::@4->vera_read#1] -- vbum1=vbuc1 + sta __stdio_filecount + // [1458] phi vera_read::info_status#12 = STATUS_CHECKING [phi:main_vera_check::@4->vera_read#2] -- vbum1=vbuc1 + lda #STATUS_CHECKING + sta vera_read.info_status + jsr vera_read + // unsigned long vera_bytes_read = vera_read(STATUS_CHECKING) + // [723] vera_read::return#2 = vera_read::return#0 + // main_vera_check::@5 + // [724] main_vera_check::vera_bytes_read#0 = vera_read::return#2 -- vduz1=vdum2 + lda vera_read.return + sta.z vera_bytes_read + lda vera_read.return+1 + sta.z vera_bytes_read+1 + lda vera_read.return+2 + sta.z vera_bytes_read+2 + lda vera_read.return+3 + sta.z vera_bytes_read+3 + // wait_moment(10) + // [725] call wait_moment + // [794] phi from main_vera_check::@5 to wait_moment [phi:main_vera_check::@5->wait_moment] + // [794] phi wait_moment::w#10 = $a [phi:main_vera_check::@5->wait_moment#0] -- vbum1=vbuc1 + lda #$a + sta wait_moment.w + jsr wait_moment + // main_vera_check::@6 + // if (!vera_bytes_read) + // [726] if(0==main_vera_check::vera_bytes_read#0) goto main_vera_check::@1 -- 0_eq_vduz1_then_la1 + // In case no file was found, set the status to none and skip to the next, else, mention the amount of bytes read. + lda.z vera_bytes_read + ora.z vera_bytes_read+1 + ora.z vera_bytes_read+2 + ora.z vera_bytes_read+3 + beq __b1 + // main_vera_check::@3 + // vera_file_size = vera_bytes_read + // [727] vera_file_size#0 = main_vera_check::vera_bytes_read#0 -- vdum1=vduz2 + // VF5 | VERA.BIN all ok | Display the VERA.BIN release version and github commit id (if any) and set VERA to Flash | Flash + // We know the file size, so we indicate it in the status panel. + lda.z vera_bytes_read + sta vera_file_size + lda.z vera_bytes_read+1 + sta vera_file_size+1 + lda.z vera_bytes_read+2 + sta vera_file_size+2 + lda.z vera_bytes_read+3 + sta vera_file_size+3 + // sprintf(info_text, "VERA.BIN:%s", "") + // [728] call snprintf_init jsr snprintf_init - // smc_get_version_text::@1 - // sprintf(version_string, "%u.%u.%u", release, major, minor) - // [1082] printf_uchar::uvalue#7 = smc_get_version_text::release#2 - // [1083] call printf_uchar - // [1346] phi from smc_get_version_text::@1 to printf_uchar [phi:smc_get_version_text::@1->printf_uchar] - // [1346] phi printf_uchar::format_zero_padding#18 = 0 [phi:smc_get_version_text::@1->printf_uchar#0] -- vbum1=vbuc1 - lda #0 - sta printf_uchar.format_zero_padding - // [1346] phi printf_uchar::format_min_length#18 = 0 [phi:smc_get_version_text::@1->printf_uchar#1] -- vbum1=vbuc1 - sta printf_uchar.format_min_length - // [1346] phi printf_uchar::putc#18 = &snputc [phi:smc_get_version_text::@1->printf_uchar#2] -- pprz1=pprc1 - lda #snputc - sta.z printf_uchar.putc+1 - // [1346] phi printf_uchar::format_radix#18 = DECIMAL [phi:smc_get_version_text::@1->printf_uchar#3] -- vbum1=vbuc1 - lda #DECIMAL - sta printf_uchar.format_radix - // [1346] phi printf_uchar::uvalue#18 = printf_uchar::uvalue#7 [phi:smc_get_version_text::@1->printf_uchar#4] -- register_copy - jsr printf_uchar - // [1084] phi from smc_get_version_text::@1 to smc_get_version_text::@2 [phi:smc_get_version_text::@1->smc_get_version_text::@2] - // smc_get_version_text::@2 - // sprintf(version_string, "%u.%u.%u", release, major, minor) - // [1085] call printf_str - // [1210] phi from smc_get_version_text::@2 to printf_str [phi:smc_get_version_text::@2->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:smc_get_version_text::@2->printf_str#0] -- pprz1=pprc1 + // [729] phi from main_vera_check::@3 to main_vera_check::@7 [phi:main_vera_check::@3->main_vera_check::@7] + // main_vera_check::@7 + // sprintf(info_text, "VERA.BIN:%s", "") + // [730] call printf_str + // [785] phi from main_vera_check::@7 to printf_str [phi:main_vera_check::@7->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:main_vera_check::@7->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = smc_get_version_text::s [phi:smc_get_version_text::@2->printf_str#1] -- pbuz1=pbuc1 + // [785] phi printf_str::s#53 = main_vera_check::s [phi:main_vera_check::@7->printf_str#1] -- pbuz1=pbuc1 lda #s sta.z printf_str.s+1 jsr printf_str - // smc_get_version_text::@3 - // sprintf(version_string, "%u.%u.%u", release, major, minor) - // [1086] printf_uchar::uvalue#8 = smc_get_version_text::major#2 -- vbum1=vbum2 - lda major - sta printf_uchar.uvalue - // [1087] call printf_uchar - // [1346] phi from smc_get_version_text::@3 to printf_uchar [phi:smc_get_version_text::@3->printf_uchar] - // [1346] phi printf_uchar::format_zero_padding#18 = 0 [phi:smc_get_version_text::@3->printf_uchar#0] -- vbum1=vbuc1 - lda #0 - sta printf_uchar.format_zero_padding - // [1346] phi printf_uchar::format_min_length#18 = 0 [phi:smc_get_version_text::@3->printf_uchar#1] -- vbum1=vbuc1 - sta printf_uchar.format_min_length - // [1346] phi printf_uchar::putc#18 = &snputc [phi:smc_get_version_text::@3->printf_uchar#2] -- pprz1=pprc1 - lda #snputc - sta.z printf_uchar.putc+1 - // [1346] phi printf_uchar::format_radix#18 = DECIMAL [phi:smc_get_version_text::@3->printf_uchar#3] -- vbum1=vbuc1 - lda #DECIMAL - sta printf_uchar.format_radix - // [1346] phi printf_uchar::uvalue#18 = printf_uchar::uvalue#8 [phi:smc_get_version_text::@3->printf_uchar#4] -- register_copy - jsr printf_uchar - // [1088] phi from smc_get_version_text::@3 to smc_get_version_text::@4 [phi:smc_get_version_text::@3->smc_get_version_text::@4] - // smc_get_version_text::@4 - // sprintf(version_string, "%u.%u.%u", release, major, minor) - // [1089] call printf_str - // [1210] phi from smc_get_version_text::@4 to printf_str [phi:smc_get_version_text::@4->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:smc_get_version_text::@4->printf_str#0] -- pprz1=pprc1 + // [731] phi from main_vera_check::@7 to main_vera_check::@8 [phi:main_vera_check::@7->main_vera_check::@8] + // main_vera_check::@8 + // sprintf(info_text, "VERA.BIN:%s", "") + // [732] call printf_string + // [1308] phi from main_vera_check::@8 to printf_string [phi:main_vera_check::@8->printf_string] + // [1308] phi printf_string::putc#17 = &snputc [phi:main_vera_check::@8->printf_string#0] -- pprz1=pprc1 lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = smc_get_version_text::s [phi:smc_get_version_text::@4->printf_str#1] -- pbuz1=pbuc1 - lda #s - sta.z printf_str.s+1 - jsr printf_str - // smc_get_version_text::@5 - // sprintf(version_string, "%u.%u.%u", release, major, minor) - // [1090] printf_uchar::uvalue#9 = smc_get_version_text::minor#2 -- vbum1=vbum2 - lda minor - sta printf_uchar.uvalue - // [1091] call printf_uchar - // [1346] phi from smc_get_version_text::@5 to printf_uchar [phi:smc_get_version_text::@5->printf_uchar] - // [1346] phi printf_uchar::format_zero_padding#18 = 0 [phi:smc_get_version_text::@5->printf_uchar#0] -- vbum1=vbuc1 + sta.z printf_string.putc+1 + // [1308] phi printf_string::str#17 = str [phi:main_vera_check::@8->printf_string#1] -- pbuz1=pbuc1 + lda #str + sta.z printf_string.str+1 + // [1308] phi printf_string::format_justify_left#17 = 0 [phi:main_vera_check::@8->printf_string#2] -- vbum1=vbuc1 lda #0 - sta printf_uchar.format_zero_padding - // [1346] phi printf_uchar::format_min_length#18 = 0 [phi:smc_get_version_text::@5->printf_uchar#1] -- vbum1=vbuc1 - sta printf_uchar.format_min_length - // [1346] phi printf_uchar::putc#18 = &snputc [phi:smc_get_version_text::@5->printf_uchar#2] -- pprz1=pprc1 - lda #snputc - sta.z printf_uchar.putc+1 - // [1346] phi printf_uchar::format_radix#18 = DECIMAL [phi:smc_get_version_text::@5->printf_uchar#3] -- vbum1=vbuc1 - lda #DECIMAL - sta printf_uchar.format_radix - // [1346] phi printf_uchar::uvalue#18 = printf_uchar::uvalue#9 [phi:smc_get_version_text::@5->printf_uchar#4] -- register_copy - jsr printf_uchar - // smc_get_version_text::@6 - // sprintf(version_string, "%u.%u.%u", release, major, minor) - // [1092] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 + sta printf_string.format_justify_left + // [1308] phi printf_string::format_min_length#17 = 0 [phi:main_vera_check::@8->printf_string#3] -- vbum1=vbuc1 + sta printf_string.format_min_length + jsr printf_string + // main_vera_check::@9 + // sprintf(info_text, "VERA.BIN:%s", "") + // [733] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 lda #0 pha - // [1093] callexecute snputc -- call_vprc1 + // [734] callexecute snputc -- call_vprc1 jsr snputc // sideeffect stackpullpadding(1) -- _stackpullpadding_1 pla - // smc_get_version_text::@return + // [736] spi_manufacturer#409 = spi_read::return#0 -- vbum1=vbum2 + lda spi_read.return + sta spi_manufacturer + // [737] spi_memory_type#410 = spi_read::return#1 -- vbum1=vbum2 + lda spi_read.return_1 + sta spi_memory_type + // [738] spi_memory_capacity#411 = spi_read::return#2 -- vbum1=vbum2 + lda spi_read.return_2 + sta spi_memory_capacity + // display_info_vera(STATUS_FLASH, info_text) + // [739] call display_info_vera + // [653] phi from main_vera_check::@9 to display_info_vera [phi:main_vera_check::@9->display_info_vera] + // [653] phi display_info_vera::info_text#19 = info_text [phi:main_vera_check::@9->display_info_vera#0] -- pbuz1=pbuc1 + lda #<@info_text + sta.z display_info_vera.info_text + lda #>@info_text + sta.z display_info_vera.info_text+1 + // [653] phi spi_memory_capacity#110 = spi_memory_capacity#411 [phi:main_vera_check::@9->display_info_vera#1] -- register_copy + // [653] phi spi_memory_type#111 = spi_memory_type#410 [phi:main_vera_check::@9->display_info_vera#2] -- register_copy + // [653] phi spi_manufacturer#100 = spi_manufacturer#409 [phi:main_vera_check::@9->display_info_vera#3] -- register_copy + // [653] phi display_info_vera::info_status#19 = STATUS_FLASH [phi:main_vera_check::@9->display_info_vera#4] -- vbum1=vbuc1 + lda #STATUS_FLASH + sta display_info_vera.info_status + jsr display_info_vera + // [740] phi from main_vera_check::@9 to main_vera_check::@2 [phi:main_vera_check::@9->main_vera_check::@2] + // [740] phi vera_file_size#1 = vera_file_size#0 [phi:main_vera_check::@9->main_vera_check::@2#0] -- register_copy + // main_vera_check::@2 + // main_vera_check::@return // } - // [1095] return + // [741] return rts - .segment Data - s: .text "." - .byte 0 - release: .byte 0 - major: .byte 0 - minor: .byte 0 -} -.segment CodeVera - // main_vera_detect -main_vera_detect: { - // vera_detect() - // [1097] call vera_detect - // [2391] phi from main_vera_detect to vera_detect [phi:main_vera_detect->vera_detect] - jsr vera_detect - // [1098] phi from main_vera_detect to main_vera_detect::@1 [phi:main_vera_detect->main_vera_detect::@1] - // main_vera_detect::@1 - // display_chip_vera() - // [1099] call display_chip_vera - // [938] phi from main_vera_detect::@1 to display_chip_vera [phi:main_vera_detect::@1->display_chip_vera] - jsr display_chip_vera - // main_vera_detect::@2 - // [1100] spi_manufacturer#584 = spi_read::return#0 -- vbum1=vbum2 + // main_vera_check::@1 + __b1: + // [742] spi_manufacturer#408 = spi_read::return#0 -- vbum1=vbum2 lda spi_read.return sta spi_manufacturer - // [1101] spi_memory_type#585 = spi_read::return#1 -- vbum1=vbum2 + // [743] spi_memory_type#409 = spi_read::return#1 -- vbum1=vbum2 lda spi_read.return_1 sta spi_memory_type - // [1102] spi_memory_capacity#586 = spi_read::return#2 -- vbum1=vbum2 + // [744] spi_memory_capacity#410 = spi_read::return#2 -- vbum1=vbum2 lda spi_read.return_2 sta spi_memory_capacity - // display_info_vera(STATUS_DETECTED, NULL) - // [1103] call display_info_vera - // [998] phi from main_vera_detect::@2 to display_info_vera [phi:main_vera_detect::@2->display_info_vera] - // [998] phi display_info_vera::info_text#19 = 0 [phi:main_vera_detect::@2->display_info_vera#0] -- pbuz1=vbuc1 - lda #<0 + // display_info_vera(STATUS_SKIP, "No VERA.BIN") + // [745] call display_info_vera + // VF1 | no VERA.BIN | Ask the user to place the VERA.BIN file onto the SDcard. Set VERA to Issue. | Issue + // VF2 | VERA.BIN size 0 | Ask the user to place a correct VERA.BIN file onto the SDcard. Set VERA to Issue. | Issue + // TODO: VF4 | ROM.BIN size over 0x20000 | Ask the user to place a correct VERA.BIN file onto the SDcard. Set VERA to Issue. | Issue + // [653] phi from main_vera_check::@1 to display_info_vera [phi:main_vera_check::@1->display_info_vera] + // [653] phi display_info_vera::info_text#19 = main_vera_check::info_text1 [phi:main_vera_check::@1->display_info_vera#0] -- pbuz1=pbuc1 + lda #info_text1 sta.z display_info_vera.info_text+1 - // [998] phi spi_memory_capacity#106 = spi_memory_capacity#586 [phi:main_vera_detect::@2->display_info_vera#1] -- register_copy - // [998] phi spi_memory_type#107 = spi_memory_type#585 [phi:main_vera_detect::@2->display_info_vera#2] -- register_copy - // [998] phi spi_manufacturer#108 = spi_manufacturer#584 [phi:main_vera_detect::@2->display_info_vera#3] -- register_copy - // [998] phi display_info_vera::info_status#19 = STATUS_DETECTED [phi:main_vera_detect::@2->display_info_vera#4] -- vbum1=vbuc1 - lda #STATUS_DETECTED + // [653] phi spi_memory_capacity#110 = spi_memory_capacity#410 [phi:main_vera_check::@1->display_info_vera#1] -- register_copy + // [653] phi spi_memory_type#111 = spi_memory_type#409 [phi:main_vera_check::@1->display_info_vera#2] -- register_copy + // [653] phi spi_manufacturer#100 = spi_manufacturer#408 [phi:main_vera_check::@1->display_info_vera#3] -- register_copy + // [653] phi display_info_vera::info_status#19 = STATUS_SKIP [phi:main_vera_check::@1->display_info_vera#4] -- vbum1=vbuc1 + lda #STATUS_SKIP sta display_info_vera.info_status jsr display_info_vera - // main_vera_detect::@return - // } - // [1104] return + // [740] phi from main_vera_check::@1 to main_vera_check::@2 [phi:main_vera_check::@1->main_vera_check::@2] + // [740] phi vera_file_size#1 = 0 [phi:main_vera_check::@1->main_vera_check::@2#0] -- vdum1=vduc1 + lda #<0 + sta vera_file_size + sta vera_file_size+1 + lda #<0>>$10 + sta vera_file_size+2 + lda #>0>>$10 + sta vera_file_size+3 rts + .segment DataVera + info_text: .text "Checking VERA.BIN ..." + .byte 0 + info_text1: .text "No VERA.BIN" + .byte 0 + s: .text "VERA.BIN:" + .byte 0 } .segment Code - // rom_detect -rom_detect: { - .const bank_set_brom1_bank = 4 - .label rom_detect__3 = $2b - .label rom_detect__5 = $42 - .label rom_detect__9 = $41 - .label rom_detect__14 = $68 - .label rom_detect__15 = $61 - .label rom_detect__18 = $60 - .label rom_detect__21 = $c2 - .label rom_detect__24 = $78 - // [1106] phi from rom_detect to rom_detect::@1 [phi:rom_detect->rom_detect::@1] - // [1106] phi rom_detect::rom_chip#10 = 0 [phi:rom_detect->rom_detect::@1#0] -- vbum1=vbuc1 - lda #0 - sta rom_chip - // [1106] phi rom_detect::rom_detect_address#10 = 0 [phi:rom_detect->rom_detect::@1#1] -- vdum1=vduc1 - sta rom_detect_address - sta rom_detect_address+1 - lda #<0>>$10 - sta rom_detect_address+2 - lda #>0>>$10 - sta rom_detect_address+3 - // Ensure the ROM is set to BASIC. - // bank_set_brom(4); - // rom_detect::@1 + // smc_supported_rom +/** + * @brief Search in the smc file header for supported ROM.BIN releases. + * The first 3 bytes of the smc file header contain the SMC.BIN version, major and minor numbers. + * + * @param rom_release The ROM release to search for. + * @return unsigned char true if found. + */ +// __mem() char smc_supported_rom(__mem() char rom_release) +smc_supported_rom: { + // [747] phi from smc_supported_rom to smc_supported_rom::@1 [phi:smc_supported_rom->smc_supported_rom::@1] + // [747] phi smc_supported_rom::i#2 = $1f [phi:smc_supported_rom->smc_supported_rom::@1#0] -- vbum1=vbuc1 + lda #$1f + sta i + // smc_supported_rom::@1 __b1: - // for (unsigned long rom_detect_address = 0; rom_detect_address < 8 * 0x80000; rom_detect_address += 0x80000) - // [1107] if(rom_detect::rom_detect_address#10<8*$80000) goto rom_detect::@2 -- vdum1_lt_vduc1_then_la1 - lda rom_detect_address+3 - cmp #>8*$80000>>$10 - bcc __b2 - bne !+ - lda rom_detect_address+2 - cmp #<8*$80000>>$10 - bcc __b2 - bne !+ - lda rom_detect_address+1 - cmp #>8*$80000 - bcc __b2 - bne !+ - lda rom_detect_address - cmp #<8*$80000 - bcc __b2 - !: - // rom_detect::@return - // } - // [1108] return + // for(unsigned char i=31; i>3; i--) + // [748] if(smc_supported_rom::i#2>=3+1) goto smc_supported_rom::@2 -- vbum1_ge_vbuc1_then_la1 + lda i + cmp #3+1 + bcs __b2 + // [750] phi from smc_supported_rom::@1 to smc_supported_rom::@return [phi:smc_supported_rom::@1->smc_supported_rom::@return] + // [750] phi smc_supported_rom::return#2 = 0 [phi:smc_supported_rom::@1->smc_supported_rom::@return#0] -- vbum1=vbuc1 + lda #0 + sta return rts - // rom_detect::@2 + // smc_supported_rom::@2 __b2: - // rom_manufacturer_ids[rom_chip] = 0 - // [1109] rom_manufacturer_ids[rom_detect::rom_chip#10] = 0 -- pbuc1_derefidx_vbum1=vbuc2 - lda #0 - ldy rom_chip - sta rom_manufacturer_ids,y - // rom_device_ids[rom_chip] = 0 - // [1110] rom_device_ids[rom_detect::rom_chip#10] = 0 -- pbuc1_derefidx_vbum1=vbuc2 - sta rom_device_ids,y - // rom_unlock(rom_detect_address + 0x05555, 0x90) - // [1111] rom_unlock::address#2 = rom_detect::rom_detect_address#10 + $5555 -- vdum1=vdum2_plus_vwuc1 - clc - lda rom_detect_address - adc #<$5555 - sta rom_unlock.address - lda rom_detect_address+1 - adc #>$5555 - sta rom_unlock.address+1 - lda rom_detect_address+2 - adc #0 - sta rom_unlock.address+2 - lda rom_detect_address+3 - adc #0 - sta rom_unlock.address+3 - // [1112] call rom_unlock - // [2394] phi from rom_detect::@2 to rom_unlock [phi:rom_detect::@2->rom_unlock] - // [2394] phi rom_unlock::unlock_code#5 = $90 [phi:rom_detect::@2->rom_unlock#0] -- vbum1=vbuc1 - lda #$90 - sta rom_unlock.unlock_code - // [2394] phi rom_unlock::address#5 = rom_unlock::address#2 [phi:rom_detect::@2->rom_unlock#1] -- register_copy - jsr rom_unlock - // rom_detect::@12 - // rom_read_byte(rom_detect_address) - // [1113] rom_read_byte::address#0 = rom_detect::rom_detect_address#10 -- vdum1=vdum2 - lda rom_detect_address - sta rom_read_byte.address - lda rom_detect_address+1 - sta rom_read_byte.address+1 - lda rom_detect_address+2 - sta rom_read_byte.address+2 - lda rom_detect_address+3 - sta rom_read_byte.address+3 - // [1114] call rom_read_byte - // [2404] phi from rom_detect::@12 to rom_read_byte [phi:rom_detect::@12->rom_read_byte] - // [2404] phi rom_read_byte::address#2 = rom_read_byte::address#0 [phi:rom_detect::@12->rom_read_byte#0] -- register_copy - jsr rom_read_byte - // rom_read_byte(rom_detect_address) - // [1115] rom_read_byte::return#2 = rom_read_byte::return#0 - // rom_detect::@13 - // [1116] rom_detect::$3 = rom_read_byte::return#2 -- vbuz1=vbum2 - lda rom_read_byte.return - sta.z rom_detect__3 - // rom_manufacturer_ids[rom_chip] = rom_read_byte(rom_detect_address) - // [1117] rom_manufacturer_ids[rom_detect::rom_chip#10] = rom_detect::$3 -- pbuc1_derefidx_vbum1=vbuz2 - ldy rom_chip - sta rom_manufacturer_ids,y - // rom_read_byte(rom_detect_address + 1) - // [1118] rom_read_byte::address#1 = rom_detect::rom_detect_address#10 + 1 -- vdum1=vdum2_plus_1 - lda rom_detect_address - clc - adc #1 - sta rom_read_byte.address - lda rom_detect_address+1 - adc #0 - sta rom_read_byte.address+1 - lda rom_detect_address+2 - adc #0 - sta rom_read_byte.address+2 - lda rom_detect_address+3 - adc #0 - sta rom_read_byte.address+3 - // [1119] call rom_read_byte - // [2404] phi from rom_detect::@13 to rom_read_byte [phi:rom_detect::@13->rom_read_byte] - // [2404] phi rom_read_byte::address#2 = rom_read_byte::address#1 [phi:rom_detect::@13->rom_read_byte#0] -- register_copy - jsr rom_read_byte - // rom_read_byte(rom_detect_address + 1) - // [1120] rom_read_byte::return#3 = rom_read_byte::return#0 - // rom_detect::@14 - // [1121] rom_detect::$5 = rom_read_byte::return#3 -- vbuz1=vbum2 - lda rom_read_byte.return - sta.z rom_detect__5 - // rom_device_ids[rom_chip] = rom_read_byte(rom_detect_address + 1) - // [1122] rom_device_ids[rom_detect::rom_chip#10] = rom_detect::$5 -- pbuc1_derefidx_vbum1=vbuz2 - ldy rom_chip - sta rom_device_ids,y - // rom_unlock(rom_detect_address + 0x05555, 0xF0) - // [1123] rom_unlock::address#3 = rom_detect::rom_detect_address#10 + $5555 -- vdum1=vdum2_plus_vwuc1 - clc - lda rom_detect_address - adc #<$5555 - sta rom_unlock.address - lda rom_detect_address+1 - adc #>$5555 - sta rom_unlock.address+1 - lda rom_detect_address+2 - adc #0 - sta rom_unlock.address+2 - lda rom_detect_address+3 - adc #0 - sta rom_unlock.address+3 - // [1124] call rom_unlock - // [2394] phi from rom_detect::@14 to rom_unlock [phi:rom_detect::@14->rom_unlock] - // [2394] phi rom_unlock::unlock_code#5 = $f0 [phi:rom_detect::@14->rom_unlock#0] -- vbum1=vbuc1 - lda #$f0 - sta rom_unlock.unlock_code - // [2394] phi rom_unlock::address#5 = rom_unlock::address#3 [phi:rom_detect::@14->rom_unlock#1] -- register_copy - jsr rom_unlock - // rom_detect::bank_set_brom1 - // BROM = bank - // [1125] BROM = rom_detect::bank_set_brom1_bank#0 -- vbuz1=vbuc1 - lda #bank_set_brom1_bank - sta.z BROM - // rom_detect::@11 - // rom_chip*3 - // [1126] rom_detect::$14 = rom_detect::rom_chip#10 << 1 -- vbuz1=vbum2_rol_1 - lda rom_chip - asl - sta.z rom_detect__14 - // [1127] rom_detect::$9 = rom_detect::$14 + rom_detect::rom_chip#10 -- vbuz1=vbuz2_plus_vbum3 - lda rom_chip - clc - adc.z rom_detect__14 - sta.z rom_detect__9 - // gotoxy(rom_chip*3+40, 1) - // [1128] gotoxy::x#30 = rom_detect::$9 + $28 -- vbum1=vbuz2_plus_vbuc1 - lda #$28 - clc - adc.z rom_detect__9 - sta gotoxy.x - // [1129] call gotoxy - // [802] phi from rom_detect::@11 to gotoxy [phi:rom_detect::@11->gotoxy] - // [802] phi gotoxy::y#37 = 1 [phi:rom_detect::@11->gotoxy#0] -- vbum1=vbuc1 - lda #1 - sta gotoxy.y - // [802] phi gotoxy::x#37 = gotoxy::x#30 [phi:rom_detect::@11->gotoxy#1] -- register_copy - jsr gotoxy - // rom_detect::@15 - // printf("%02x", rom_device_ids[rom_chip]) - // [1130] printf_uchar::uvalue#14 = rom_device_ids[rom_detect::rom_chip#10] -- vbum1=pbuc1_derefidx_vbum2 - ldy rom_chip - lda rom_device_ids,y - sta printf_uchar.uvalue - // [1131] call printf_uchar - // [1346] phi from rom_detect::@15 to printf_uchar [phi:rom_detect::@15->printf_uchar] - // [1346] phi printf_uchar::format_zero_padding#18 = 1 [phi:rom_detect::@15->printf_uchar#0] -- vbum1=vbuc1 + // if(smc_file_header[i] == rom_release) + // [749] if(smc_file_header[smc_supported_rom::i#2]!=smc_supported_rom::rom_release#0) goto smc_supported_rom::@3 -- pbuc1_derefidx_vbum1_neq_vbum2_then_la1 + lda rom_release + ldy i + cmp smc_file_header,y + bne __b3 + // [750] phi from smc_supported_rom::@2 to smc_supported_rom::@return [phi:smc_supported_rom::@2->smc_supported_rom::@return] + // [750] phi smc_supported_rom::return#2 = 1 [phi:smc_supported_rom::@2->smc_supported_rom::@return#0] -- vbum1=vbuc1 lda #1 - sta printf_uchar.format_zero_padding - // [1346] phi printf_uchar::format_min_length#18 = 2 [phi:rom_detect::@15->printf_uchar#1] -- vbum1=vbuc1 - lda #2 - sta printf_uchar.format_min_length - // [1346] phi printf_uchar::putc#18 = &cputc [phi:rom_detect::@15->printf_uchar#2] -- pprz1=pprc1 - lda #cputc - sta.z printf_uchar.putc+1 - // [1346] phi printf_uchar::format_radix#18 = HEXADECIMAL [phi:rom_detect::@15->printf_uchar#3] -- vbum1=vbuc1 - lda #HEXADECIMAL - sta printf_uchar.format_radix - // [1346] phi printf_uchar::uvalue#18 = printf_uchar::uvalue#14 [phi:rom_detect::@15->printf_uchar#4] -- register_copy - jsr printf_uchar - // rom_detect::@16 - // case SST39SF010A: - // rom_device_names[rom_chip] = "f010a"; - // rom_size_strings[rom_chip] = "128"; - // rom_sizes[rom_chip] = 128 * 1024; - // break; - // [1132] if(rom_device_ids[rom_detect::rom_chip#10]==$b5) goto rom_detect::@3 -- pbuc1_derefidx_vbum1_eq_vbuc2_then_la1 - ldy rom_chip - lda rom_device_ids,y - cmp #$b5 - bne !__b3+ - jmp __b3 - !__b3: - // rom_detect::@9 - // case SST39SF020A: - // rom_device_names[rom_chip] = "f020a"; - // rom_size_strings[rom_chip] = "256"; - // rom_sizes[rom_chip] = 256 * 1024; - // break; - // [1133] if(rom_device_ids[rom_detect::rom_chip#10]==$b6) goto rom_detect::@4 -- pbuc1_derefidx_vbum1_eq_vbuc2_then_la1 - lda rom_device_ids,y - cmp #$b6 - bne !__b4+ - jmp __b4 - !__b4: - // rom_detect::@10 - // case SST39SF040: - // rom_device_names[rom_chip] = "f040"; - // rom_size_strings[rom_chip] = "512"; - // rom_sizes[rom_chip] = 512 * 1024; - // break; - // [1134] if(rom_device_ids[rom_detect::rom_chip#10]==$b7) goto rom_detect::@5 -- pbuc1_derefidx_vbum1_eq_vbuc2_then_la1 - lda rom_device_ids,y - cmp #$b7 - beq __b5 - // rom_detect::@6 - // rom_manufacturer_ids[rom_chip] = 0 - // [1135] rom_manufacturer_ids[rom_detect::rom_chip#10] = 0 -- pbuc1_derefidx_vbum1=vbuc2 + sta return + // smc_supported_rom::@return + // } + // [751] return + rts + // smc_supported_rom::@3 + __b3: + // for(unsigned char i=31; i>3; i--) + // [752] smc_supported_rom::i#1 = -- smc_supported_rom::i#2 -- vbum1=_dec_vbum1 + dec i + // [747] phi from smc_supported_rom::@3 to smc_supported_rom::@1 [phi:smc_supported_rom::@3->smc_supported_rom::@1] + // [747] phi smc_supported_rom::i#2 = smc_supported_rom::i#1 [phi:smc_supported_rom::@3->smc_supported_rom::@1#0] -- register_copy + jmp __b1 + .segment Data + i: .byte 0 + return: .byte 0 + rom_release: .byte 0 +} +.segment Code + // check_status_roms +/** + * @brief Check the status of any of the ROMs. + * + * @param status The status to be checked. + * @return unsigned char true if one chip is equal to the status. + */ +// __mem() char check_status_roms(__mem() char status) +check_status_roms: { + .label check_status_rom1_check_status_roms__0 = $4d + // [754] phi from check_status_roms to check_status_roms::@1 [phi:check_status_roms->check_status_roms::@1] + // [754] phi check_status_roms::rom_chip#2 = 0 [phi:check_status_roms->check_status_roms::@1#0] -- vbum1=vbuc1 lda #0 - sta rom_manufacturer_ids,y - // rom_device_names[rom_chip] = "----" - // [1136] rom_device_names[rom_detect::$14] = rom_detect::$31 -- qbuc1_derefidx_vbuz1=pbuc2 - ldy.z rom_detect__14 - lda #rom_detect__31 - sta rom_device_names+1,y - // rom_size_strings[rom_chip] = "000" - // [1137] rom_size_strings[rom_detect::$14] = rom_detect::$32 -- qbuc1_derefidx_vbuz1=pbuc2 - lda #rom_detect__32 - sta rom_size_strings+1,y - // rom_sizes[rom_chip] = 0 - // [1138] rom_detect::$24 = rom_detect::rom_chip#10 << 2 -- vbuz1=vbum2_rol_2 + sta rom_chip + // check_status_roms::@1 + __b1: + // for(unsigned char rom_chip = 0; rom_chip < 8; rom_chip++) + // [755] if(check_status_roms::rom_chip#2<8) goto check_status_roms::check_status_rom1 -- vbum1_lt_vbuc1_then_la1 lda rom_chip - asl - asl - sta.z rom_detect__24 - // [1139] rom_sizes[rom_detect::$24] = 0 -- pduc1_derefidx_vbuz1=vbuc2 - tay + cmp #8 + bcc check_status_rom1 + // [756] phi from check_status_roms::@1 to check_status_roms::@return [phi:check_status_roms::@1->check_status_roms::@return] + // [756] phi check_status_roms::return#2 = 0 [phi:check_status_roms::@1->check_status_roms::@return#0] -- vbum1=vbuc1 lda #0 - sta rom_sizes,y - sta rom_sizes+1,y - sta rom_sizes+2,y - sta rom_sizes+3,y - // rom_device_ids[rom_chip] = UNKNOWN - // [1140] rom_device_ids[rom_detect::rom_chip#10] = $55 -- pbuc1_derefidx_vbum1=vbuc2 - lda #$55 + sta return + // check_status_roms::@return + // } + // [757] return + rts + // check_status_roms::check_status_rom1 + check_status_rom1: + // status_rom[rom_chip] == status + // [758] check_status_roms::check_status_rom1_$0 = status_rom[check_status_roms::rom_chip#2] == check_status_roms::status#6 -- vboz1=pbuc1_derefidx_vbum2_eq_vbum3 + lda status ldy rom_chip - sta rom_device_ids,y - // rom_detect::@7 - __b7: - // rom_chip++; - // [1141] rom_detect::rom_chip#1 = ++ rom_detect::rom_chip#10 -- vbum1=_inc_vbum1 + eor status_rom,y + beq !+ + lda #1 + !: + eor #1 + sta.z check_status_rom1_check_status_roms__0 + // return (unsigned char)(status_rom[rom_chip] == status); + // [759] check_status_roms::check_status_rom1_return#0 = (char)check_status_roms::check_status_rom1_$0 -- vbum1=vbuz2 + sta check_status_rom1_return + // check_status_roms::@3 + // if(check_status_rom(rom_chip, status)) + // [760] if(0==check_status_roms::check_status_rom1_return#0) goto check_status_roms::@2 -- 0_eq_vbum1_then_la1 + beq __b2 + // [756] phi from check_status_roms::@3 to check_status_roms::@return [phi:check_status_roms::@3->check_status_roms::@return] + // [756] phi check_status_roms::return#2 = 1 [phi:check_status_roms::@3->check_status_roms::@return#0] -- vbum1=vbuc1 + lda #1 + sta return + rts + // check_status_roms::@2 + __b2: + // for(unsigned char rom_chip = 0; rom_chip < 8; rom_chip++) + // [761] check_status_roms::rom_chip#1 = ++ check_status_roms::rom_chip#2 -- vbum1=_inc_vbum1 inc rom_chip - // rom_detect::@8 - // rom_detect_address += 0x80000 - // [1142] rom_detect::rom_detect_address#1 = rom_detect::rom_detect_address#10 + $80000 -- vdum1=vdum1_plus_vduc1 - clc - lda rom_detect_address - adc #<$80000 - sta rom_detect_address - lda rom_detect_address+1 - adc #>$80000 - sta rom_detect_address+1 - lda rom_detect_address+2 - adc #<$80000>>$10 - sta rom_detect_address+2 - lda rom_detect_address+3 - adc #>$80000>>$10 - sta rom_detect_address+3 - // [1106] phi from rom_detect::@8 to rom_detect::@1 [phi:rom_detect::@8->rom_detect::@1] - // [1106] phi rom_detect::rom_chip#10 = rom_detect::rom_chip#1 [phi:rom_detect::@8->rom_detect::@1#0] -- register_copy - // [1106] phi rom_detect::rom_detect_address#10 = rom_detect::rom_detect_address#1 [phi:rom_detect::@8->rom_detect::@1#1] -- register_copy + // [754] phi from check_status_roms::@2 to check_status_roms::@1 [phi:check_status_roms::@2->check_status_roms::@1] + // [754] phi check_status_roms::rom_chip#2 = check_status_roms::rom_chip#1 [phi:check_status_roms::@2->check_status_roms::@1#0] -- register_copy jmp __b1 - // rom_detect::@5 - __b5: - // rom_device_names[rom_chip] = "f040" - // [1143] rom_device_names[rom_detect::$14] = rom_detect::$29 -- qbuc1_derefidx_vbuz1=pbuc2 - ldy.z rom_detect__14 - lda #rom_detect__29 - sta rom_device_names+1,y - // rom_size_strings[rom_chip] = "512" - // [1144] rom_size_strings[rom_detect::$14] = rom_detect::$30 -- qbuc1_derefidx_vbuz1=pbuc2 - lda #rom_detect__30 - sta rom_size_strings+1,y - // rom_sizes[rom_chip] = 512 * 1024 - // [1145] rom_detect::$21 = rom_detect::rom_chip#10 << 2 -- vbuz1=vbum2_rol_2 - lda rom_chip - asl - asl - sta.z rom_detect__21 - // [1146] rom_sizes[rom_detect::$21] = (unsigned long)$200*$400 -- pduc1_derefidx_vbuz1=vduc2 - tay - lda #<$200*$400 - sta rom_sizes,y - lda #>$200*$400 - sta rom_sizes+1,y - lda #<$200*$400>>$10 - sta rom_sizes+2,y - lda #>$200*$400>>$10 - sta rom_sizes+3,y - jmp __b7 - // rom_detect::@4 - __b4: - // rom_device_names[rom_chip] = "f020a" - // [1147] rom_device_names[rom_detect::$14] = rom_detect::$27 -- qbuc1_derefidx_vbuz1=pbuc2 - ldy.z rom_detect__14 - lda #rom_detect__27 - sta rom_device_names+1,y - // rom_size_strings[rom_chip] = "256" - // [1148] rom_size_strings[rom_detect::$14] = rom_detect::$28 -- qbuc1_derefidx_vbuz1=pbuc2 - lda #rom_detect__28 - sta rom_size_strings+1,y - // rom_sizes[rom_chip] = 256 * 1024 - // [1149] rom_detect::$18 = rom_detect::rom_chip#10 << 2 -- vbuz1=vbum2_rol_2 - lda rom_chip - asl - asl - sta.z rom_detect__18 - // [1150] rom_sizes[rom_detect::$18] = (unsigned long)$100*$400 -- pduc1_derefidx_vbuz1=vduc2 - tay - lda #<$100*$400 - sta rom_sizes,y - lda #>$100*$400 - sta rom_sizes+1,y - lda #<$100*$400>>$10 - sta rom_sizes+2,y - lda #>$100*$400>>$10 - sta rom_sizes+3,y - jmp __b7 - // rom_detect::@3 - __b3: - // rom_device_names[rom_chip] = "f010a" - // [1151] rom_device_names[rom_detect::$14] = rom_detect::$25 -- qbuc1_derefidx_vbuz1=pbuc2 - ldy.z rom_detect__14 - lda #rom_detect__25 - sta rom_device_names+1,y - // rom_size_strings[rom_chip] = "128" - // [1152] rom_size_strings[rom_detect::$14] = rom_detect::$26 -- qbuc1_derefidx_vbuz1=pbuc2 - lda #rom_detect__26 - sta rom_size_strings+1,y - // rom_sizes[rom_chip] = 128 * 1024 - // [1153] rom_detect::$15 = rom_detect::rom_chip#10 << 2 -- vbuz1=vbum2_rol_2 - lda rom_chip - asl - asl - sta.z rom_detect__15 - // [1154] rom_sizes[rom_detect::$15] = (unsigned long)$80*$400 -- pduc1_derefidx_vbuz1=vduc2 - tay - lda #<$80*$400 - sta rom_sizes,y - lda #>$80*$400 - sta rom_sizes+1,y - lda #<$80*$400>>$10 - sta rom_sizes+2,y - lda #>$80*$400>>$10 - sta rom_sizes+3,y - jmp __b7 .segment Data - rom_detect__25: .text "f010a" - .byte 0 - rom_detect__26: .text "128" - .byte 0 - rom_detect__27: .text "f020a" - .byte 0 - rom_detect__28: .text "256" - .byte 0 - rom_detect__29: .text "f040" - .byte 0 - rom_detect__30: .text "512" - .byte 0 - rom_detect__31: .text "----" - .byte 0 - rom_detect__32: .text "000" - .byte 0 + check_status_rom1_return: .byte 0 rom_chip: .byte 0 - rom_detect_address: .dword 0 + return: .byte 0 + status: .byte 0 } .segment Code - // smc_read -/** - * @brief Read the SMC.BIN file into RAM_BASE. - * The maximum size of SMC.BIN data that should be in the file is 0x1E00. - * - * @return unsigned int The amount of bytes read from SMC.BIN to be flashed. - */ -// __mem() unsigned int smc_read(__mem() char info_status) -smc_read: { - .const smc_bram_bank = 1 - .label fp = $c3 - .label smc_bram_ptr = $4c - .label smc_action_text = $79 - // if(info_status == STATUS_READING) - // [1156] if(smc_read::info_status#10==STATUS_READING) goto smc_read::@1 -- vbum1_eq_vbuc1_then_la1 - lda #STATUS_READING - cmp info_status - beq __b1 - // [1158] phi from smc_read to smc_read::@2 [phi:smc_read->smc_read::@2] - // [1158] phi smc_read::smc_action_text#12 = smc_action_text#2 [phi:smc_read->smc_read::@2#0] -- pbuz1=pbuc1 - lda #smc_action_text_1 - sta.z smc_action_text+1 - jmp __b2 - // [1157] phi from smc_read to smc_read::@1 [phi:smc_read->smc_read::@1] - // smc_read::@1 + // clrscr +// clears the screen and moves the cursor to the upper left-hand corner of the screen. +clrscr: { + .label clrscr__0 = $4d + .label clrscr__1 = $4e + .label clrscr__2 = $3b + // unsigned int line_text = __conio.mapbase_offset + // [762] clrscr::line_text#0 = *((unsigned int *)&__conio+3) -- vwum1=_deref_pwuc1 + lda __conio+3 + sta line_text + lda __conio+3+1 + sta line_text+1 + // *VERA_CTRL &= ~VERA_ADDRSEL + // [763] *VERA_CTRL = *VERA_CTRL & ~VERA_ADDRSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 + lda #VERA_ADDRSEL^$ff + and VERA_CTRL + sta VERA_CTRL + // __conio.mapbase_bank | VERA_INC_1 + // [764] clrscr::$0 = *((char *)&__conio+5) | VERA_INC_1 -- vbuz1=_deref_pbuc1_bor_vbuc2 + lda #VERA_INC_1 + ora __conio+5 + sta.z clrscr__0 + // *VERA_ADDRX_H = __conio.mapbase_bank | VERA_INC_1 + // [765] *VERA_ADDRX_H = clrscr::$0 -- _deref_pbuc1=vbuz1 + sta VERA_ADDRX_H + // unsigned char l = __conio.mapheight + // [766] clrscr::l#0 = *((char *)&__conio+9) -- vbum1=_deref_pbuc1 + lda __conio+9 + sta l + // [767] phi from clrscr clrscr::@3 to clrscr::@1 [phi:clrscr/clrscr::@3->clrscr::@1] + // [767] phi clrscr::l#4 = clrscr::l#0 [phi:clrscr/clrscr::@3->clrscr::@1#0] -- register_copy + // [767] phi clrscr::ch#0 = clrscr::line_text#0 [phi:clrscr/clrscr::@3->clrscr::@1#1] -- register_copy + // clrscr::@1 __b1: - // [1158] phi from smc_read::@1 to smc_read::@2 [phi:smc_read::@1->smc_read::@2] - // [1158] phi smc_read::smc_action_text#12 = smc_action_text#1 [phi:smc_read::@1->smc_read::@2#0] -- pbuz1=pbuc1 - lda #smc_action_text - sta.z smc_action_text+1 - // smc_read::@2 + // BYTE0(ch) + // [768] clrscr::$1 = byte0 clrscr::ch#0 -- vbuz1=_byte0_vwum2 + lda ch + sta.z clrscr__1 + // *VERA_ADDRX_L = BYTE0(ch) + // [769] *VERA_ADDRX_L = clrscr::$1 -- _deref_pbuc1=vbuz1 + // Set address + sta VERA_ADDRX_L + // BYTE1(ch) + // [770] clrscr::$2 = byte1 clrscr::ch#0 -- vbuz1=_byte1_vwum2 + lda ch+1 + sta.z clrscr__2 + // *VERA_ADDRX_M = BYTE1(ch) + // [771] *VERA_ADDRX_M = clrscr::$2 -- _deref_pbuc1=vbuz1 + sta VERA_ADDRX_M + // unsigned char c = __conio.mapwidth+1 + // [772] clrscr::c#0 = *((char *)&__conio+8) + 1 -- vbum1=_deref_pbuc1_plus_1 + lda __conio+8 + inc + sta c + // [773] phi from clrscr::@1 clrscr::@2 to clrscr::@2 [phi:clrscr::@1/clrscr::@2->clrscr::@2] + // [773] phi clrscr::c#2 = clrscr::c#0 [phi:clrscr::@1/clrscr::@2->clrscr::@2#0] -- register_copy + // clrscr::@2 __b2: - // smc_read::bank_set_bram1 - // BRAM = bank - // [1159] BRAM = smc_read::smc_bram_bank -- vbuz1=vbuc1 - lda #smc_bram_bank - sta.z BRAM - // [1160] phi from smc_read::bank_set_bram1 to smc_read::@16 [phi:smc_read::bank_set_bram1->smc_read::@16] - // smc_read::@16 - // textcolor(WHITE) - // [1161] call textcolor - // [784] phi from smc_read::@16 to textcolor [phi:smc_read::@16->textcolor] - // [784] phi textcolor::color#23 = WHITE [phi:smc_read::@16->textcolor#0] -- vbum1=vbuc1 - lda #WHITE - sta textcolor.color - jsr textcolor - // [1162] phi from smc_read::@16 to smc_read::@17 [phi:smc_read::@16->smc_read::@17] - // smc_read::@17 - // gotoxy(x, y) - // [1163] call gotoxy - // [802] phi from smc_read::@17 to gotoxy [phi:smc_read::@17->gotoxy] - // [802] phi gotoxy::y#37 = PROGRESS_Y [phi:smc_read::@17->gotoxy#0] -- vbum1=vbuc1 - lda #PROGRESS_Y - sta gotoxy.y - // [802] phi gotoxy::x#37 = PROGRESS_X [phi:smc_read::@17->gotoxy#1] -- vbum1=vbuc1 - lda #PROGRESS_X - sta gotoxy.x - jsr gotoxy - // [1164] phi from smc_read::@17 to smc_read::@18 [phi:smc_read::@17->smc_read::@18] - // smc_read::@18 - // FILE *fp = fopen("SMC.BIN", "r") - // [1165] call fopen - // [2416] phi from smc_read::@18 to fopen [phi:smc_read::@18->fopen] - // [2416] phi __errno#473 = __errno#102 [phi:smc_read::@18->fopen#0] -- register_copy - // [2416] phi fopen::pathtoken#0 = smc_read::path [phi:smc_read::@18->fopen#1] -- pbuz1=pbuc1 - lda #path - sta.z fopen.pathtoken+1 - // [2416] phi __stdio_filecount#27 = __stdio_filecount#128 [phi:smc_read::@18->fopen#2] -- register_copy - jsr fopen - // FILE *fp = fopen("SMC.BIN", "r") - // [1166] fopen::return#4 = fopen::return#2 - // smc_read::@19 - // [1167] smc_read::fp#0 = fopen::return#4 -- pssz1=pssz2 - lda.z fopen.return - sta.z fp - lda.z fopen.return+1 - sta.z fp+1 - // if (fp) - // [1168] if((struct $2 *)0==smc_read::fp#0) goto smc_read::@3 -- pssc1_eq_pssz1_then_la1 - lda.z fp - cmp #<0 - bne !+ - lda.z fp+1 - cmp #>0 - bne !__b5+ - jmp __b5 - !__b5: - !: - // smc_read::@4 - // fgets(smc_file_header, 32, fp) - // [1169] fgets::stream#1 = smc_read::fp#0 -- pssz1=pssz2 - lda.z fp - sta.z fgets.stream - lda.z fp+1 - sta.z fgets.stream+1 - // [1170] call fgets - // [2497] phi from smc_read::@4 to fgets [phi:smc_read::@4->fgets] - // [2497] phi fgets::ptr#14 = smc_file_header [phi:smc_read::@4->fgets#0] -- pbuz1=pbuc1 - lda #smc_file_header - sta.z fgets.ptr+1 - // [2497] phi fgets::size#10 = $20 [phi:smc_read::@4->fgets#1] -- vwum1=vbuc1 - lda #<$20 - sta fgets.size - lda #>$20 - sta fgets.size+1 - // [2497] phi fgets::stream#4 = fgets::stream#1 [phi:smc_read::@4->fgets#2] -- register_copy - jsr fgets - // fgets(smc_file_header, 32, fp) - // [1171] fgets::return#11 = fgets::return#1 - // smc_read::@20 - // smc_file_read = fgets(smc_file_header, 32, fp) - // [1172] smc_read::smc_file_read#1 = fgets::return#11 - // if(smc_file_read) - // [1173] if(0==smc_read::smc_file_read#1) goto smc_read::@3 -- 0_eq_vwum1_then_la1 - lda smc_file_read - ora smc_file_read+1 - beq __b5 - // smc_read::@5 - // if(info_status == STATUS_CHECKING) - // [1174] if(smc_read::info_status#10!=STATUS_CHECKING) goto smc_read::@7 -- vbum1_neq_vbuc1_then_la1 - lda #STATUS_CHECKING - cmp info_status - bne __b4 - // [1175] phi from smc_read::@5 to smc_read::@6 [phi:smc_read::@5->smc_read::@6] - // smc_read::@6 - // [1176] phi from smc_read::@6 to smc_read::@7 [phi:smc_read::@6->smc_read::@7] - // [1176] phi smc_read::y#12 = PROGRESS_Y [phi:smc_read::@6->smc_read::@7#0] -- vbum1=vbuc1 - lda #PROGRESS_Y - sta y - // [1176] phi smc_read::progress_row_bytes#10 = 0 [phi:smc_read::@6->smc_read::@7#1] -- vwum1=vwuc1 - lda #<0 - sta progress_row_bytes - sta progress_row_bytes+1 - // [1176] phi smc_read::smc_file_size#10 = 0 [phi:smc_read::@6->smc_read::@7#2] -- vwum1=vwuc1 - sta smc_file_size - sta smc_file_size+1 - // [1176] phi smc_read::smc_bram_ptr#10 = (char *) 1024 [phi:smc_read::@6->smc_read::@7#3] -- pbuz1=pbuc1 - lda #<$400 - sta.z smc_bram_ptr - lda #>$400 - sta.z smc_bram_ptr+1 - jmp __b7 - // We read block_size bytes at a time, and each block_size bytes we plot a dot. - // Every r bytes we move to the next line. - // [1176] phi from smc_read::@5 to smc_read::@7 [phi:smc_read::@5->smc_read::@7] - __b4: - // [1176] phi smc_read::y#12 = PROGRESS_Y [phi:smc_read::@5->smc_read::@7#0] -- vbum1=vbuc1 - lda #PROGRESS_Y - sta y - // [1176] phi smc_read::progress_row_bytes#10 = 0 [phi:smc_read::@5->smc_read::@7#1] -- vwum1=vwuc1 - lda #<0 - sta progress_row_bytes - sta progress_row_bytes+1 - // [1176] phi smc_read::smc_file_size#10 = 0 [phi:smc_read::@5->smc_read::@7#2] -- vwum1=vwuc1 - sta smc_file_size - sta smc_file_size+1 - // [1176] phi smc_read::smc_bram_ptr#10 = (char *)$a000 [phi:smc_read::@5->smc_read::@7#3] -- pbuz1=pbuc1 - lda #<$a000 - sta.z smc_bram_ptr - lda #>$a000 - sta.z smc_bram_ptr+1 - // smc_read::@7 - __b7: - // fgets(smc_bram_ptr, SMC_PROGRESS_CELL, fp) - // [1177] fgets::ptr#4 = smc_read::smc_bram_ptr#10 -- pbuz1=pbuz2 - lda.z smc_bram_ptr - sta.z fgets.ptr - lda.z smc_bram_ptr+1 - sta.z fgets.ptr+1 - // [1178] fgets::stream#2 = smc_read::fp#0 -- pssz1=pssz2 - lda.z fp - sta.z fgets.stream - lda.z fp+1 - sta.z fgets.stream+1 - // [1179] call fgets - // [2497] phi from smc_read::@7 to fgets [phi:smc_read::@7->fgets] - // [2497] phi fgets::ptr#14 = fgets::ptr#4 [phi:smc_read::@7->fgets#0] -- register_copy - // [2497] phi fgets::size#10 = SMC_PROGRESS_CELL [phi:smc_read::@7->fgets#1] -- vwum1=vbuc1 - lda #SMC_PROGRESS_CELL - sta fgets.size+1 - // [2497] phi fgets::stream#4 = fgets::stream#2 [phi:smc_read::@7->fgets#2] -- register_copy - jsr fgets - // fgets(smc_bram_ptr, SMC_PROGRESS_CELL, fp) - // [1180] fgets::return#12 = fgets::return#1 - // smc_read::@21 - // smc_file_read = fgets(smc_bram_ptr, SMC_PROGRESS_CELL, fp) - // [1181] smc_read::smc_file_read#10 = fgets::return#12 - // while (smc_file_read = fgets(smc_bram_ptr, SMC_PROGRESS_CELL, fp)) - // [1182] if(0!=smc_read::smc_file_read#10) goto smc_read::@8 -- 0_neq_vwum1_then_la1 - lda smc_file_read - ora smc_file_read+1 - bne __b8 - // smc_read::@9 - // fclose(fp) - // [1183] fclose::stream#1 = smc_read::fp#0 - // [1184] call fclose - // [2551] phi from smc_read::@9 to fclose [phi:smc_read::@9->fclose] - // [2551] phi fclose::stream#3 = fclose::stream#1 [phi:smc_read::@9->fclose#0] -- register_copy - jsr fclose - // [1185] phi from smc_read::@9 to smc_read::@3 [phi:smc_read::@9->smc_read::@3] - // [1185] phi __stdio_filecount#39 = __stdio_filecount#2 [phi:smc_read::@9->smc_read::@3#0] -- register_copy - // [1185] phi smc_read::return#0 = smc_read::smc_file_size#10 [phi:smc_read::@9->smc_read::@3#1] -- register_copy - rts - // [1185] phi from smc_read::@19 smc_read::@20 to smc_read::@3 [phi:smc_read::@19/smc_read::@20->smc_read::@3] - __b5: - // [1185] phi __stdio_filecount#39 = __stdio_filecount#1 [phi:smc_read::@19/smc_read::@20->smc_read::@3#0] -- register_copy - // [1185] phi smc_read::return#0 = 0 [phi:smc_read::@19/smc_read::@20->smc_read::@3#1] -- vwum1=vwuc1 - lda #<0 - sta return - sta return+1 - // smc_read::@3 - // smc_read::@return + // *VERA_DATA0 = ' ' + // [774] *VERA_DATA0 = ' ' -- _deref_pbuc1=vbuc2 + lda #' ' + sta VERA_DATA0 + // *VERA_DATA0 = __conio.color + // [775] *VERA_DATA0 = *((char *)&__conio+$d) -- _deref_pbuc1=_deref_pbuc2 + lda __conio+$d + sta VERA_DATA0 + // c--; + // [776] clrscr::c#1 = -- clrscr::c#2 -- vbum1=_dec_vbum1 + dec c + // while(c) + // [777] if(0!=clrscr::c#1) goto clrscr::@2 -- 0_neq_vbum1_then_la1 + lda c + bne __b2 + // clrscr::@3 + // line_text += __conio.rowskip + // [778] clrscr::line_text#1 = clrscr::ch#0 + *((unsigned int *)&__conio+$a) -- vwum1=vwum1_plus__deref_pwuc1 + clc + lda line_text + adc __conio+$a + sta line_text + lda line_text+1 + adc __conio+$a+1 + sta line_text+1 + // l--; + // [779] clrscr::l#1 = -- clrscr::l#4 -- vbum1=_dec_vbum1 + dec l + // while(l) + // [780] if(0!=clrscr::l#1) goto clrscr::@1 -- 0_neq_vbum1_then_la1 + lda l + bne __b1 + // clrscr::@4 + // __conio.cursor_x = 0 + // [781] *((char *)&__conio) = 0 -- _deref_pbuc1=vbuc2 + lda #0 + sta __conio + // __conio.cursor_y = 0 + // [782] *((char *)&__conio+1) = 0 -- _deref_pbuc1=vbuc2 + sta __conio+1 + // __conio.offset = __conio.mapbase_offset + // [783] *((unsigned int *)&__conio+$13) = *((unsigned int *)&__conio+3) -- _deref_pwuc1=_deref_pwuc2 + lda __conio+3 + sta __conio+$13 + lda __conio+3+1 + sta __conio+$13+1 + // clrscr::@return // } - // [1186] return + // [784] return rts - // smc_read::@8 - __b8: - // display_action_text_reading(smc_action_text, "SMC.BIN", smc_file_size, SMC_CHIP_SIZE, smc_bram_bank, smc_bram_ptr) - // [1187] display_action_text_reading::action#1 = smc_read::smc_action_text#12 -- pbuz1=pbuz2 - lda.z smc_action_text - sta.z display_action_text_reading.action - lda.z smc_action_text+1 - sta.z display_action_text_reading.action+1 - // [1188] display_action_text_reading::bytes#1 = smc_read::smc_file_size#10 -- vdum1=vwum2 - lda smc_file_size - sta display_action_text_reading.bytes - lda smc_file_size+1 - sta display_action_text_reading.bytes+1 - lda #0 - sta display_action_text_reading.bytes+2 - sta display_action_text_reading.bytes+3 - // [1189] display_action_text_reading::bram_ptr#1 = smc_read::smc_bram_ptr#10 -- pbuz1=pbuz2 - lda.z smc_bram_ptr - sta.z display_action_text_reading.bram_ptr - lda.z smc_bram_ptr+1 - sta.z display_action_text_reading.bram_ptr+1 - // [1190] call display_action_text_reading - // [2580] phi from smc_read::@8 to display_action_text_reading [phi:smc_read::@8->display_action_text_reading] - // [2580] phi display_action_text_reading::bram_ptr#10 = display_action_text_reading::bram_ptr#1 [phi:smc_read::@8->display_action_text_reading#0] -- register_copy - // [2580] phi display_action_text_reading::bram_bank#10 = smc_read::smc_bram_bank [phi:smc_read::@8->display_action_text_reading#1] -- vbum1=vbuc1 - lda #smc_bram_bank - sta display_action_text_reading.bram_bank - // [2580] phi display_action_text_reading::size#10 = SMC_CHIP_SIZE [phi:smc_read::@8->display_action_text_reading#2] -- vdum1=vduc1 - lda #SMC_CHIP_SIZE - sta display_action_text_reading.size+1 - lda #>$10 - sta display_action_text_reading.size+2 - lda #>SMC_CHIP_SIZE>>$10 - sta display_action_text_reading.size+3 - // [2580] phi display_action_text_reading::bytes#3 = display_action_text_reading::bytes#1 [phi:smc_read::@8->display_action_text_reading#3] -- register_copy - // [2580] phi display_action_text_reading::file#3 = smc_read::path [phi:smc_read::@8->display_action_text_reading#4] -- pbuz1=pbuc1 - lda #path - sta.z display_action_text_reading.file+1 - // [2580] phi display_action_text_reading::action#3 = display_action_text_reading::action#1 [phi:smc_read::@8->display_action_text_reading#5] -- register_copy - jsr display_action_text_reading - // smc_read::@22 - // if (progress_row_bytes == SMC_PROGRESS_ROW) - // [1191] if(smc_read::progress_row_bytes#10!=SMC_PROGRESS_ROW) goto smc_read::@10 -- vwum1_neq_vwuc1_then_la1 - lda progress_row_bytes+1 - cmp #>SMC_PROGRESS_ROW - bne __b10 - lda progress_row_bytes - cmp #gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#27 [phi:smc_read::@13->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = PROGRESS_X [phi:smc_read::@13->gotoxy#1] -- vbum1=vbuc1 - lda #PROGRESS_X - sta gotoxy.x - jsr gotoxy - // [1195] phi from smc_read::@13 to smc_read::@10 [phi:smc_read::@13->smc_read::@10] - // [1195] phi smc_read::y#13 = smc_read::y#1 [phi:smc_read::@13->smc_read::@10#0] -- register_copy - // [1195] phi smc_read::progress_row_bytes#11 = 0 [phi:smc_read::@13->smc_read::@10#1] -- vwum1=vbuc1 - lda #<0 - sta progress_row_bytes - sta progress_row_bytes+1 - // [1195] phi from smc_read::@22 to smc_read::@10 [phi:smc_read::@22->smc_read::@10] - // [1195] phi smc_read::y#13 = smc_read::y#12 [phi:smc_read::@22->smc_read::@10#0] -- register_copy - // [1195] phi smc_read::progress_row_bytes#11 = smc_read::progress_row_bytes#10 [phi:smc_read::@22->smc_read::@10#1] -- register_copy - // smc_read::@10 - __b10: - // if(info_status == STATUS_READING) - // [1196] if(smc_read::info_status#10!=STATUS_READING) goto smc_read::@11 -- vbum1_neq_vbuc1_then_la1 - lda #STATUS_READING - cmp info_status - bne __b11 - // smc_read::@14 - // cputc('.') - // [1197] stackpush(char) = '.' -- _stackpushbyte_=vbuc1 - lda #'.' - pha - // [1198] callexecute cputc -- call_vprc1 - jsr cputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // smc_read::@11 - __b11: - // if(info_status == STATUS_CHECKING) - // [1200] if(smc_read::info_status#10==STATUS_CHECKING) goto smc_read::@12 -- vbum1_eq_vbuc1_then_la1 - lda #STATUS_CHECKING - cmp info_status - beq __b6 - // smc_read::@15 - // smc_bram_ptr += smc_file_read - // [1201] smc_read::smc_bram_ptr#3 = smc_read::smc_bram_ptr#10 + smc_read::smc_file_read#10 -- pbuz1=pbuz1_plus_vwum2 - clc - lda.z smc_bram_ptr - adc smc_file_read - sta.z smc_bram_ptr - lda.z smc_bram_ptr+1 - adc smc_file_read+1 - sta.z smc_bram_ptr+1 - // [1202] phi from smc_read::@15 to smc_read::@12 [phi:smc_read::@15->smc_read::@12] - // [1202] phi smc_read::smc_bram_ptr#7 = smc_read::smc_bram_ptr#3 [phi:smc_read::@15->smc_read::@12#0] -- register_copy - jmp __b12 - // [1202] phi from smc_read::@11 to smc_read::@12 [phi:smc_read::@11->smc_read::@12] - __b6: - // [1202] phi smc_read::smc_bram_ptr#7 = (char *) 1024 [phi:smc_read::@11->smc_read::@12#0] -- pbuz1=pbuc1 - lda #<$400 - sta.z smc_bram_ptr - lda #>$400 - sta.z smc_bram_ptr+1 - // smc_read::@12 - __b12: - // smc_file_size += smc_file_read - // [1203] smc_read::smc_file_size#1 = smc_read::smc_file_size#10 + smc_read::smc_file_read#10 -- vwum1=vwum1_plus_vwum2 - clc - lda smc_file_size - adc smc_file_read - sta smc_file_size - lda smc_file_size+1 - adc smc_file_read+1 - sta smc_file_size+1 - // progress_row_bytes += smc_file_read - // [1204] smc_read::progress_row_bytes#2 = smc_read::progress_row_bytes#11 + smc_read::smc_file_read#10 -- vwum1=vwum1_plus_vwum2 - clc - lda progress_row_bytes - adc smc_file_read - sta progress_row_bytes - lda progress_row_bytes+1 - adc smc_file_read+1 - sta progress_row_bytes+1 - // [1176] phi from smc_read::@12 to smc_read::@7 [phi:smc_read::@12->smc_read::@7] - // [1176] phi smc_read::y#12 = smc_read::y#13 [phi:smc_read::@12->smc_read::@7#0] -- register_copy - // [1176] phi smc_read::progress_row_bytes#10 = smc_read::progress_row_bytes#2 [phi:smc_read::@12->smc_read::@7#1] -- register_copy - // [1176] phi smc_read::smc_file_size#10 = smc_read::smc_file_size#1 [phi:smc_read::@12->smc_read::@7#2] -- register_copy - // [1176] phi smc_read::smc_bram_ptr#10 = smc_read::smc_bram_ptr#7 [phi:smc_read::@12->smc_read::@7#3] -- register_copy - jmp __b7 .segment Data - path: .text "SMC.BIN" - .byte 0 - return: .word 0 - .label smc_file_read = fgets.read - y: .byte 0 - .label smc_file_size = return - /// Holds the amount of bytes actually read in the memory to be flashed. - progress_row_bytes: .word 0 - info_status: .byte 0 + .label line_text = ch + l: .byte 0 + ch: .word 0 + c: .byte 0 } .segment Code - // snprintf_init -/// Initialize the snprintf() state -// void snprintf_init(__zp($45) char *s, unsigned int n) -snprintf_init: { - .label s = $45 - // __snprintf_capacity = n - // [1206] __snprintf_capacity = $ffff -- vwum1=vwuc1 - lda #<$ffff - sta __snprintf_capacity - lda #>$ffff - sta __snprintf_capacity+1 - // __snprintf_size = 0 - // [1207] __snprintf_size = 0 -- vwum1=vbuc1 - lda #<0 - sta __snprintf_size - sta __snprintf_size+1 - // __snprintf_buffer = s - // [1208] __snprintf_buffer = snprintf_init::s#31 -- pbuz1=pbuz2 - lda.z s - sta.z __snprintf_buffer - lda.z s+1 - sta.z __snprintf_buffer+1 - // snprintf_init::@return - // } - // [1209] return - rts -} // printf_str /// Print a NUL-terminated string -// void printf_str(__zp($3b) void (*putc)(char), __zp($50) const char *s) +// void printf_str(__zp($49) void (*putc)(char), __zp($42) const char *s) printf_str: { - .label s = $50 - .label putc = $3b - // [1211] phi from printf_str printf_str::@2 to printf_str::@1 [phi:printf_str/printf_str::@2->printf_str::@1] - // [1211] phi printf_str::s#83 = printf_str::s#84 [phi:printf_str/printf_str::@2->printf_str::@1#0] -- register_copy + .label s = $42 + .label putc = $49 + // [786] phi from printf_str printf_str::@2 to printf_str::@1 [phi:printf_str/printf_str::@2->printf_str::@1] + // [786] phi printf_str::s#52 = printf_str::s#53 [phi:printf_str/printf_str::@2->printf_str::@1#0] -- register_copy // printf_str::@1 __b1: // while(c=*s++) - // [1212] printf_str::c#1 = *printf_str::s#83 -- vbum1=_deref_pbuz2 + // [787] printf_str::c#1 = *printf_str::s#52 -- vbum1=_deref_pbuz2 ldy #0 lda (s),y sta c - // [1213] printf_str::s#0 = ++ printf_str::s#83 -- pbuz1=_inc_pbuz1 + // [788] printf_str::s#0 = ++ printf_str::s#52 -- pbuz1=_inc_pbuz1 inc.z s bne !+ inc.z s+1 !: - // [1214] if(0!=printf_str::c#1) goto printf_str::@2 -- 0_neq_vbum1_then_la1 + // [789] if(0!=printf_str::c#1) goto printf_str::@2 -- 0_neq_vbum1_then_la1 lda c bne __b2 // printf_str::@return // } - // [1215] return + // [790] return rts // printf_str::@2 __b2: // putc(c) - // [1216] stackpush(char) = printf_str::c#1 -- _stackpushbyte_=vbum1 + // [791] stackpush(char) = printf_str::c#1 -- _stackpushbyte_=vbum1 lda c pha - // [1217] callexecute *printf_str::putc#84 -- call__deref_pprz1 - jsr icall15 + // [792] callexecute *printf_str::putc#53 -- call__deref_pprz1 + jsr icall5 // sideeffect stackpullpadding(1) -- _stackpullpadding_1 pla jmp __b1 // Outside Flow - icall15: + icall5: jmp (putc) .segment Data c: .byte 0 } .segment Code - // printf_string -// Print a string value using a specific format -// Handles justification and min length -// void printf_string(__zp($4a) void (*putc)(char), __zp($50) char *str, __mem() char format_min_length, __mem() char format_justify_left) -printf_string: { - .label printf_string__9 = $3d - .label str = $50 - .label str_1 = $b0 - .label putc = $4a - // if(format.min_length) - // [1220] if(0==printf_string::format_min_length#26) goto printf_string::@1 -- 0_eq_vbum1_then_la1 - lda format_min_length - beq __b3 - // printf_string::@3 - // strlen(str) - // [1221] strlen::str#3 = printf_string::str#26 -- pbuz1=pbuz2 - lda.z str - sta.z strlen.str - lda.z str+1 - sta.z strlen.str+1 - // [1222] call strlen - // [2611] phi from printf_string::@3 to strlen [phi:printf_string::@3->strlen] - // [2611] phi strlen::str#8 = strlen::str#3 [phi:printf_string::@3->strlen#0] -- register_copy - jsr strlen - // strlen(str) - // [1223] strlen::return#10 = strlen::len#2 - // printf_string::@6 - // [1224] printf_string::$9 = strlen::return#10 -- vwuz1=vwum2 - lda strlen.return - sta.z printf_string__9 - lda strlen.return+1 - sta.z printf_string__9+1 - // signed char len = (signed char)strlen(str) - // [1225] printf_string::len#0 = (signed char)printf_string::$9 -- vbsm1=_sbyte_vwuz2 - lda.z printf_string__9 - sta len - // padding = (signed char)format.min_length - len - // [1226] printf_string::padding#1 = (signed char)printf_string::format_min_length#26 - printf_string::len#0 -- vbsm1=vbsm1_minus_vbsm2 - lda padding - sec - sbc len - sta padding - // if(padding<0) - // [1227] if(printf_string::padding#1>=0) goto printf_string::@10 -- vbsm1_ge_0_then_la1 - cmp #0 - bpl __b1 - // [1229] phi from printf_string printf_string::@6 to printf_string::@1 [phi:printf_string/printf_string::@6->printf_string::@1] - __b3: - // [1229] phi printf_string::padding#3 = 0 [phi:printf_string/printf_string::@6->printf_string::@1#0] -- vbsm1=vbsc1 + // wait_moment +/** + * @brief + * + */ +// void wait_moment(__mem() char w) +wait_moment: { + // [795] phi from wait_moment to wait_moment::@1 [phi:wait_moment->wait_moment::@1] + // [795] phi wait_moment::j#2 = 0 [phi:wait_moment->wait_moment::@1#0] -- vbum1=vbuc1 lda #0 - sta padding - // [1228] phi from printf_string::@6 to printf_string::@10 [phi:printf_string::@6->printf_string::@10] - // printf_string::@10 - // [1229] phi from printf_string::@10 to printf_string::@1 [phi:printf_string::@10->printf_string::@1] - // [1229] phi printf_string::padding#3 = printf_string::padding#1 [phi:printf_string::@10->printf_string::@1#0] -- register_copy - // printf_string::@1 + sta j + // wait_moment::@1 __b1: - // if(!format.justify_left && padding) - // [1230] if(0!=printf_string::format_justify_left#26) goto printf_string::@2 -- 0_neq_vbum1_then_la1 - lda format_justify_left - bne __b2 - // printf_string::@8 - // [1231] if(0!=printf_string::padding#3) goto printf_string::@4 -- 0_neq_vbsm1_then_la1 - lda padding - cmp #0 - bne __b4 - jmp __b2 - // printf_string::@4 - __b4: - // printf_padding(putc, ' ',(char)padding) - // [1232] printf_padding::putc#3 = printf_string::putc#26 -- pprz1=pprz2 - lda.z putc - sta.z printf_padding.putc - lda.z putc+1 - sta.z printf_padding.putc+1 - // [1233] printf_padding::length#3 = (char)printf_string::padding#3 -- vbum1=vbum2 - lda padding - sta printf_padding.length - // [1234] call printf_padding - // [2617] phi from printf_string::@4 to printf_padding [phi:printf_string::@4->printf_padding] - // [2617] phi printf_padding::putc#7 = printf_padding::putc#3 [phi:printf_string::@4->printf_padding#0] -- register_copy - // [2617] phi printf_padding::pad#7 = ' ' [phi:printf_string::@4->printf_padding#1] -- vbum1=vbuc1 - lda #' ' - sta printf_padding.pad - // [2617] phi printf_padding::length#6 = printf_padding::length#3 [phi:printf_string::@4->printf_padding#2] -- register_copy - jsr printf_padding - // printf_string::@2 - __b2: - // printf_str(putc, str) - // [1235] printf_str::putc#1 = printf_string::putc#26 -- pprz1=pprz2 - lda.z putc - sta.z printf_str.putc - lda.z putc+1 - sta.z printf_str.putc+1 - // [1236] printf_str::s#2 = printf_string::str#26 - // [1237] call printf_str - // [1210] phi from printf_string::@2 to printf_str [phi:printf_string::@2->printf_str] - // [1210] phi printf_str::putc#84 = printf_str::putc#1 [phi:printf_string::@2->printf_str#0] -- register_copy - // [1210] phi printf_str::s#84 = printf_str::s#2 [phi:printf_string::@2->printf_str#1] -- register_copy - jsr printf_str - // printf_string::@7 - // if(format.justify_left && padding) - // [1238] if(0==printf_string::format_justify_left#26) goto printf_string::@return -- 0_eq_vbum1_then_la1 - lda format_justify_left - beq __breturn - // printf_string::@9 - // [1239] if(0!=printf_string::padding#3) goto printf_string::@5 -- 0_neq_vbsm1_then_la1 - lda padding - cmp #0 - bne __b5 - rts - // printf_string::@5 - __b5: - // printf_padding(putc, ' ',(char)padding) - // [1240] printf_padding::putc#4 = printf_string::putc#26 -- pprz1=pprz2 - lda.z putc - sta.z printf_padding.putc - lda.z putc+1 - sta.z printf_padding.putc+1 - // [1241] printf_padding::length#4 = (char)printf_string::padding#3 -- vbum1=vbum2 - lda padding - sta printf_padding.length - // [1242] call printf_padding - // [2617] phi from printf_string::@5 to printf_padding [phi:printf_string::@5->printf_padding] - // [2617] phi printf_padding::putc#7 = printf_padding::putc#4 [phi:printf_string::@5->printf_padding#0] -- register_copy - // [2617] phi printf_padding::pad#7 = ' ' [phi:printf_string::@5->printf_padding#1] -- vbum1=vbuc1 - lda #' ' - sta printf_padding.pad - // [2617] phi printf_padding::length#6 = printf_padding::length#4 [phi:printf_string::@5->printf_padding#2] -- register_copy - jsr printf_padding - // printf_string::@return - __breturn: + // for(unsigned char j=0; jwait_moment::@2] + __b4: + // [798] phi wait_moment::i#2 = $ffff [phi:wait_moment::@1->wait_moment::@2#0] -- vwum1=vwuc1 + lda #<$ffff + sta i + lda #>$ffff + sta i+1 + // wait_moment::@2 + __b2: + // for(unsigned int i=65535; i>0; i--) + // [799] if(wait_moment::i#2>0) goto wait_moment::@3 -- vwum1_gt_0_then_la1 + lda i+1 + bne __b3 + lda i + bne __b3 + !: + // wait_moment::@4 + // for(unsigned char j=0; jwait_moment::@1] + // [795] phi wait_moment::j#2 = wait_moment::j#1 [phi:wait_moment::@4->wait_moment::@1#0] -- register_copy + jmp __b1 + // wait_moment::@3 + __b3: + // for(unsigned int i=65535; i>0; i--) + // [801] wait_moment::i#1 = -- wait_moment::i#2 -- vwum1=_dec_vwum1 + lda i + bne !+ + dec i+1 + !: + dec i + // [798] phi from wait_moment::@3 to wait_moment::@2 [phi:wait_moment::@3->wait_moment::@2] + // [798] phi wait_moment::i#2 = wait_moment::i#1 [phi:wait_moment::@3->wait_moment::@2#0] -- register_copy + jmp __b2 .segment Data - len: .byte 0 - .label padding = format_min_length - format_min_length: .byte 0 - format_justify_left: .byte 0 -} -.segment CodeVera - // main_vera_check -main_vera_check: { - .label vera_bytes_read = $d2 - // display_action_progress("Checking VERA.BIN ...") - // [1245] call display_action_progress - // [904] phi from main_vera_check to display_action_progress [phi:main_vera_check->display_action_progress] - // [904] phi display_action_progress::info_text#27 = main_vera_check::info_text [phi:main_vera_check->display_action_progress#0] -- pbuz1=pbuc1 - lda #info_text - sta.z display_action_progress.info_text+1 - jsr display_action_progress - // [1246] phi from main_vera_check to main_vera_check::@4 [phi:main_vera_check->main_vera_check::@4] - // main_vera_check::@4 - // unsigned long vera_bytes_read = vera_read(STATUS_CHECKING) - // [1247] call vera_read - // Read the VERA.BIN file. - // [2625] phi from main_vera_check::@4 to vera_read [phi:main_vera_check::@4->vera_read] - // [2625] phi __errno#100 = __errno#113 [phi:main_vera_check::@4->vera_read#0] -- register_copy - // [2625] phi __stdio_filecount#123 = __stdio_filecount#109 [phi:main_vera_check::@4->vera_read#1] -- register_copy - // [2625] phi vera_read::info_status#12 = STATUS_CHECKING [phi:main_vera_check::@4->vera_read#2] -- vbum1=vbuc1 - lda #STATUS_CHECKING - sta vera_read.info_status - jsr vera_read - // unsigned long vera_bytes_read = vera_read(STATUS_CHECKING) - // [1248] vera_read::return#2 = vera_read::return#0 - // main_vera_check::@5 - // [1249] main_vera_check::vera_bytes_read#0 = vera_read::return#2 -- vduz1=vdum2 - lda vera_read.return - sta.z vera_bytes_read - lda vera_read.return+1 - sta.z vera_bytes_read+1 - lda vera_read.return+2 - sta.z vera_bytes_read+2 - lda vera_read.return+3 - sta.z vera_bytes_read+3 - // wait_moment(10) - // [1250] call wait_moment - // [1310] phi from main_vera_check::@5 to wait_moment [phi:main_vera_check::@5->wait_moment] - // [1310] phi wait_moment::w#13 = $a [phi:main_vera_check::@5->wait_moment#0] -- vbum1=vbuc1 - lda #$a - sta wait_moment.w - jsr wait_moment - // main_vera_check::@6 - // if (!vera_bytes_read) - // [1251] if(0==main_vera_check::vera_bytes_read#0) goto main_vera_check::@1 -- 0_eq_vduz1_then_la1 - // In case no file was found, set the status to none and skip to the next, else, mention the amount of bytes read. - lda.z vera_bytes_read - ora.z vera_bytes_read+1 - ora.z vera_bytes_read+2 - ora.z vera_bytes_read+3 - beq __b1 - // main_vera_check::@3 - // vera_file_size = vera_bytes_read - // [1252] vera_file_size#0 = main_vera_check::vera_bytes_read#0 -- vdum1=vduz2 - // VF5 | VERA.BIN all ok | Display the VERA.BIN release version and github commit id (if any) and set VERA to Flash | Flash - // We know the file size, so we indicate it in the status panel. - lda.z vera_bytes_read - sta vera_file_size - lda.z vera_bytes_read+1 - sta vera_file_size+1 - lda.z vera_bytes_read+2 - sta vera_file_size+2 - lda.z vera_bytes_read+3 - sta vera_file_size+3 - // sprintf(info_text, "VERA.BIN:%s", "") - // [1253] call snprintf_init - // [1205] phi from main_vera_check::@3 to snprintf_init [phi:main_vera_check::@3->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:main_vera_check::@3->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 - jsr snprintf_init - // [1254] phi from main_vera_check::@3 to main_vera_check::@7 [phi:main_vera_check::@3->main_vera_check::@7] - // main_vera_check::@7 - // sprintf(info_text, "VERA.BIN:%s", "") - // [1255] call printf_str - // [1210] phi from main_vera_check::@7 to printf_str [phi:main_vera_check::@7->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main_vera_check::@7->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main_vera_check::s [phi:main_vera_check::@7->printf_str#1] -- pbuz1=pbuc1 - lda #s - sta.z printf_str.s+1 - jsr printf_str - // [1256] phi from main_vera_check::@7 to main_vera_check::@8 [phi:main_vera_check::@7->main_vera_check::@8] - // main_vera_check::@8 - // sprintf(info_text, "VERA.BIN:%s", "") - // [1257] call printf_string - // [1219] phi from main_vera_check::@8 to printf_string [phi:main_vera_check::@8->printf_string] - // [1219] phi printf_string::putc#26 = &snputc [phi:main_vera_check::@8->printf_string#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = str [phi:main_vera_check::@8->printf_string#1] -- pbuz1=pbuc1 - lda #str - sta.z printf_string.str+1 - // [1219] phi printf_string::format_justify_left#26 = 0 [phi:main_vera_check::@8->printf_string#2] -- vbum1=vbuc1 - lda #0 - sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = 0 [phi:main_vera_check::@8->printf_string#3] -- vbum1=vbuc1 - sta printf_string.format_min_length - jsr printf_string - // main_vera_check::@9 - // sprintf(info_text, "VERA.BIN:%s", "") - // [1258] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 - lda #0 - pha - // [1259] callexecute snputc -- call_vprc1 - jsr snputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // [1261] spi_manufacturer#583 = spi_read::return#0 -- vbum1=vbum2 - lda spi_read.return - sta spi_manufacturer - // [1262] spi_memory_type#584 = spi_read::return#1 -- vbum1=vbum2 - lda spi_read.return_1 - sta spi_memory_type - // [1263] spi_memory_capacity#585 = spi_read::return#2 -- vbum1=vbum2 - lda spi_read.return_2 - sta spi_memory_capacity - // display_info_vera(STATUS_FLASH, info_text) - // [1264] call display_info_vera - // [998] phi from main_vera_check::@9 to display_info_vera [phi:main_vera_check::@9->display_info_vera] - // [998] phi display_info_vera::info_text#19 = info_text [phi:main_vera_check::@9->display_info_vera#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z display_info_vera.info_text - lda #>@info_text - sta.z display_info_vera.info_text+1 - // [998] phi spi_memory_capacity#106 = spi_memory_capacity#585 [phi:main_vera_check::@9->display_info_vera#1] -- register_copy - // [998] phi spi_memory_type#107 = spi_memory_type#584 [phi:main_vera_check::@9->display_info_vera#2] -- register_copy - // [998] phi spi_manufacturer#108 = spi_manufacturer#583 [phi:main_vera_check::@9->display_info_vera#3] -- register_copy - // [998] phi display_info_vera::info_status#19 = STATUS_FLASH [phi:main_vera_check::@9->display_info_vera#4] -- vbum1=vbuc1 - lda #STATUS_FLASH - sta display_info_vera.info_status - jsr display_info_vera - // [1265] phi from main_vera_check::@9 to main_vera_check::@2 [phi:main_vera_check::@9->main_vera_check::@2] - // [1265] phi vera_file_size#1 = vera_file_size#0 [phi:main_vera_check::@9->main_vera_check::@2#0] -- register_copy - // main_vera_check::@2 - // main_vera_check::@return - // } - // [1266] return - rts - // main_vera_check::@1 - __b1: - // [1267] spi_manufacturer#582 = spi_read::return#0 -- vbum1=vbum2 - lda spi_read.return - sta spi_manufacturer - // [1268] spi_memory_type#583 = spi_read::return#1 -- vbum1=vbum2 - lda spi_read.return_1 - sta spi_memory_type - // [1269] spi_memory_capacity#584 = spi_read::return#2 -- vbum1=vbum2 - lda spi_read.return_2 - sta spi_memory_capacity - // display_info_vera(STATUS_SKIP, "No VERA.BIN") - // [1270] call display_info_vera - // VF1 | no VERA.BIN | Ask the user to place the VERA.BIN file onto the SDcard. Set VERA to Issue. | Issue - // VF2 | VERA.BIN size 0 | Ask the user to place a correct VERA.BIN file onto the SDcard. Set VERA to Issue. | Issue - // TODO: VF4 | ROM.BIN size over 0x20000 | Ask the user to place a correct VERA.BIN file onto the SDcard. Set VERA to Issue. | Issue - // [998] phi from main_vera_check::@1 to display_info_vera [phi:main_vera_check::@1->display_info_vera] - // [998] phi display_info_vera::info_text#19 = main_vera_check::info_text1 [phi:main_vera_check::@1->display_info_vera#0] -- pbuz1=pbuc1 - lda #info_text1 - sta.z display_info_vera.info_text+1 - // [998] phi spi_memory_capacity#106 = spi_memory_capacity#584 [phi:main_vera_check::@1->display_info_vera#1] -- register_copy - // [998] phi spi_memory_type#107 = spi_memory_type#583 [phi:main_vera_check::@1->display_info_vera#2] -- register_copy - // [998] phi spi_manufacturer#108 = spi_manufacturer#582 [phi:main_vera_check::@1->display_info_vera#3] -- register_copy - // [998] phi display_info_vera::info_status#19 = STATUS_SKIP [phi:main_vera_check::@1->display_info_vera#4] -- vbum1=vbuc1 - lda #STATUS_SKIP - sta display_info_vera.info_status - jsr display_info_vera - // [1265] phi from main_vera_check::@1 to main_vera_check::@2 [phi:main_vera_check::@1->main_vera_check::@2] - // [1265] phi vera_file_size#1 = 0 [phi:main_vera_check::@1->main_vera_check::@2#0] -- vdum1=vduc1 - lda #<0 - sta vera_file_size - sta vera_file_size+1 - lda #<0>>$10 - sta vera_file_size+2 - lda #>0>>$10 - sta vera_file_size+3 - rts - .segment DataVera - info_text: .text "Checking VERA.BIN ..." - .byte 0 - info_text1: .text "No VERA.BIN" - .byte 0 - s: .text "VERA.BIN:" - .byte 0 + i: .word 0 + j: .byte 0 + w: .byte 0 } .segment Code - // smc_supported_rom + // system_reset /** - * @brief Search in the smc file header for supported ROM.BIN releases. - * The first 3 bytes of the smc file header contain the SMC.BIN version, major and minor numbers. + * @brief * - * @param rom_release The ROM release to search for. - * @return unsigned char true if found. */ -// __mem() char smc_supported_rom(__mem() char rom_release) -smc_supported_rom: { - // [1272] phi from smc_supported_rom to smc_supported_rom::@1 [phi:smc_supported_rom->smc_supported_rom::@1] - // [1272] phi smc_supported_rom::i#2 = $1f [phi:smc_supported_rom->smc_supported_rom::@1#0] -- vbum1=vbuc1 - lda #$1f - sta i - // smc_supported_rom::@1 +system_reset: { + .const bank_set_bram1_bank = 0 + .const bank_set_brom1_bank = 0 + // system_reset::bank_set_bram1 + // BRAM = bank + // [803] BRAM = system_reset::bank_set_bram1_bank#0 -- vbuz1=vbuc1 + lda #bank_set_bram1_bank + sta.z BRAM + // system_reset::bank_set_brom1 + // BROM = bank + // [804] BROM = system_reset::bank_set_brom1_bank#0 -- vbuz1=vbuc1 + lda #bank_set_brom1_bank + sta.z BROM + // system_reset::@2 + // asm + // asm { jmp($FFFC) } + jmp ($fffc) + // [806] phi from system_reset::@1 system_reset::@2 to system_reset::@1 [phi:system_reset::@1/system_reset::@2->system_reset::@1] + // system_reset::@1 __b1: - // for(unsigned char i=31; i>3; i--) - // [1273] if(smc_supported_rom::i#2>=3+1) goto smc_supported_rom::@2 -- vbum1_ge_vbuc1_then_la1 - lda i - cmp #3+1 - bcs __b2 - // [1275] phi from smc_supported_rom::@1 to smc_supported_rom::@return [phi:smc_supported_rom::@1->smc_supported_rom::@return] - // [1275] phi smc_supported_rom::return#2 = 0 [phi:smc_supported_rom::@1->smc_supported_rom::@return#0] -- vbum1=vbuc1 - lda #0 - sta return - rts - // smc_supported_rom::@2 - __b2: - // if(smc_file_header[i] == rom_release) - // [1274] if(smc_file_header[smc_supported_rom::i#2]!=smc_supported_rom::rom_release#0) goto smc_supported_rom::@3 -- pbuc1_derefidx_vbum1_neq_vbum2_then_la1 - lda rom_release - ldy i - cmp smc_file_header,y - bne __b3 - // [1275] phi from smc_supported_rom::@2 to smc_supported_rom::@return [phi:smc_supported_rom::@2->smc_supported_rom::@return] - // [1275] phi smc_supported_rom::return#2 = 1 [phi:smc_supported_rom::@2->smc_supported_rom::@return#0] -- vbum1=vbuc1 - lda #1 - sta return - // smc_supported_rom::@return - // } - // [1276] return - rts - // smc_supported_rom::@3 - __b3: - // for(unsigned char i=31; i>3; i--) - // [1277] smc_supported_rom::i#1 = -- smc_supported_rom::i#2 -- vbum1=_dec_vbum1 - dec i - // [1272] phi from smc_supported_rom::@3 to smc_supported_rom::@1 [phi:smc_supported_rom::@3->smc_supported_rom::@1] - // [1272] phi smc_supported_rom::i#2 = smc_supported_rom::i#1 [phi:smc_supported_rom::@3->smc_supported_rom::@1#0] -- register_copy jmp __b1 - .segment Data - i: .byte 0 - return: .byte 0 - rom_release: .byte 0 } -.segment Code - // check_status_roms + // check_status_roms_less /** - * @brief Check the status of any of the ROMs. + * @brief Check the status of all the ROMs. * * @param status The status to be checked. - * @return unsigned char true if one chip is equal to the status. + * @return unsigned char true if all chips are equal to the status. */ -// __mem() char check_status_roms(__mem() char status) -check_status_roms: { - .label check_status_rom1_check_status_roms__0 = $42 - // [1279] phi from check_status_roms to check_status_roms::@1 [phi:check_status_roms->check_status_roms::@1] - // [1279] phi check_status_roms::rom_chip#2 = 0 [phi:check_status_roms->check_status_roms::@1#0] -- vbum1=vbuc1 +// __mem() char check_status_roms_less(char status) +check_status_roms_less: { + .label check_status_roms_less__1 = $4e + // [808] phi from check_status_roms_less to check_status_roms_less::@1 [phi:check_status_roms_less->check_status_roms_less::@1] + // [808] phi check_status_roms_less::rom_chip#2 = 0 [phi:check_status_roms_less->check_status_roms_less::@1#0] -- vbum1=vbuc1 lda #0 sta rom_chip - // check_status_roms::@1 + // check_status_roms_less::@1 __b1: // for(unsigned char rom_chip = 0; rom_chip < 8; rom_chip++) - // [1280] if(check_status_roms::rom_chip#2<8) goto check_status_roms::check_status_rom1 -- vbum1_lt_vbuc1_then_la1 + // [809] if(check_status_roms_less::rom_chip#2<8) goto check_status_roms_less::@2 -- vbum1_lt_vbuc1_then_la1 lda rom_chip cmp #8 - bcc check_status_rom1 - // [1281] phi from check_status_roms::@1 to check_status_roms::@return [phi:check_status_roms::@1->check_status_roms::@return] - // [1281] phi check_status_roms::return#2 = 0 [phi:check_status_roms::@1->check_status_roms::@return#0] -- vbum1=vbuc1 - lda #0 + bcc __b2 + // [812] phi from check_status_roms_less::@1 to check_status_roms_less::@return [phi:check_status_roms_less::@1->check_status_roms_less::@return] + // [812] phi check_status_roms_less::return#2 = 1 [phi:check_status_roms_less::@1->check_status_roms_less::@return#0] -- vbum1=vbuc1 + lda #1 sta return - // check_status_roms::@return - // } - // [1282] return rts - // check_status_roms::check_status_rom1 - check_status_rom1: - // status_rom[rom_chip] == status - // [1283] check_status_roms::check_status_rom1_$0 = status_rom[check_status_roms::rom_chip#2] == check_status_roms::status#6 -- vboz1=pbuc1_derefidx_vbum2_eq_vbum3 - lda status + // check_status_roms_less::@2 + __b2: + // status_rom[rom_chip] > status + // [810] check_status_roms_less::$1 = status_rom[check_status_roms_less::rom_chip#2] > STATUS_SKIP -- vboz1=pbuc1_derefidx_vbum2_gt_vbuc2 ldy rom_chip - eor status_rom,y - beq !+ - lda #1 - !: - eor #1 - sta.z check_status_rom1_check_status_roms__0 - // return (unsigned char)(status_rom[rom_chip] == status); - // [1284] check_status_roms::check_status_rom1_return#0 = (char)check_status_roms::check_status_rom1_$0 -- vbum1=vbuz2 - sta check_status_rom1_return - // check_status_roms::@3 - // if(check_status_rom(rom_chip, status)) - // [1285] if(0==check_status_roms::check_status_rom1_return#0) goto check_status_roms::@2 -- 0_eq_vbum1_then_la1 - beq __b2 - // [1281] phi from check_status_roms::@3 to check_status_roms::@return [phi:check_status_roms::@3->check_status_roms::@return] - // [1281] phi check_status_roms::return#2 = 1 [phi:check_status_roms::@3->check_status_roms::@return#0] -- vbum1=vbuc1 - lda #1 + lda status_rom,y + cmp #STATUS_SKIP + lda #0 + rol + sta.z check_status_roms_less__1 + // if((unsigned char)(status_rom[rom_chip] > status)) + // [811] if(0==(char)check_status_roms_less::$1) goto check_status_roms_less::@3 -- 0_eq_vbuz1_then_la1 + beq __b3 + // [812] phi from check_status_roms_less::@2 to check_status_roms_less::@return [phi:check_status_roms_less::@2->check_status_roms_less::@return] + // [812] phi check_status_roms_less::return#2 = 0 [phi:check_status_roms_less::@2->check_status_roms_less::@return#0] -- vbum1=vbuc1 + lda #0 sta return + // check_status_roms_less::@return + // } + // [813] return rts - // check_status_roms::@2 - __b2: + // check_status_roms_less::@3 + __b3: // for(unsigned char rom_chip = 0; rom_chip < 8; rom_chip++) - // [1286] check_status_roms::rom_chip#1 = ++ check_status_roms::rom_chip#2 -- vbum1=_inc_vbum1 + // [814] check_status_roms_less::rom_chip#1 = ++ check_status_roms_less::rom_chip#2 -- vbum1=_inc_vbum1 inc rom_chip - // [1279] phi from check_status_roms::@2 to check_status_roms::@1 [phi:check_status_roms::@2->check_status_roms::@1] - // [1279] phi check_status_roms::rom_chip#2 = check_status_roms::rom_chip#1 [phi:check_status_roms::@2->check_status_roms::@1#0] -- register_copy - jmp __b1 - .segment Data - check_status_rom1_return: .byte 0 - rom_chip: .byte 0 - return: .byte 0 - status: .byte 0 -} -.segment Code - // clrscr -// clears the screen and moves the cursor to the upper left-hand corner of the screen. -clrscr: { - .label clrscr__0 = $68 - .label clrscr__1 = $41 - .label clrscr__2 = $78 - // unsigned int line_text = __conio.mapbase_offset - // [1287] clrscr::line_text#0 = *((unsigned int *)&__conio+3) -- vwum1=_deref_pwuc1 - lda __conio+3 - sta line_text - lda __conio+3+1 - sta line_text+1 - // *VERA_CTRL &= ~VERA_ADDRSEL - // [1288] *VERA_CTRL = *VERA_CTRL & ~VERA_ADDRSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 - lda #VERA_ADDRSEL^$ff - and VERA_CTRL - sta VERA_CTRL - // __conio.mapbase_bank | VERA_INC_1 - // [1289] clrscr::$0 = *((char *)&__conio+5) | VERA_INC_1 -- vbuz1=_deref_pbuc1_bor_vbuc2 - lda #VERA_INC_1 - ora __conio+5 - sta.z clrscr__0 - // *VERA_ADDRX_H = __conio.mapbase_bank | VERA_INC_1 - // [1290] *VERA_ADDRX_H = clrscr::$0 -- _deref_pbuc1=vbuz1 - sta VERA_ADDRX_H - // unsigned char l = __conio.mapheight - // [1291] clrscr::l#0 = *((char *)&__conio+9) -- vbum1=_deref_pbuc1 - lda __conio+9 - sta l - // [1292] phi from clrscr clrscr::@3 to clrscr::@1 [phi:clrscr/clrscr::@3->clrscr::@1] - // [1292] phi clrscr::l#4 = clrscr::l#0 [phi:clrscr/clrscr::@3->clrscr::@1#0] -- register_copy - // [1292] phi clrscr::ch#0 = clrscr::line_text#0 [phi:clrscr/clrscr::@3->clrscr::@1#1] -- register_copy - // clrscr::@1 - __b1: - // BYTE0(ch) - // [1293] clrscr::$1 = byte0 clrscr::ch#0 -- vbuz1=_byte0_vwum2 - lda ch - sta.z clrscr__1 - // *VERA_ADDRX_L = BYTE0(ch) - // [1294] *VERA_ADDRX_L = clrscr::$1 -- _deref_pbuc1=vbuz1 - // Set address - sta VERA_ADDRX_L - // BYTE1(ch) - // [1295] clrscr::$2 = byte1 clrscr::ch#0 -- vbuz1=_byte1_vwum2 - lda ch+1 - sta.z clrscr__2 - // *VERA_ADDRX_M = BYTE1(ch) - // [1296] *VERA_ADDRX_M = clrscr::$2 -- _deref_pbuc1=vbuz1 - sta VERA_ADDRX_M - // unsigned char c = __conio.mapwidth+1 - // [1297] clrscr::c#0 = *((char *)&__conio+8) + 1 -- vbum1=_deref_pbuc1_plus_1 - lda __conio+8 - inc - sta c - // [1298] phi from clrscr::@1 clrscr::@2 to clrscr::@2 [phi:clrscr::@1/clrscr::@2->clrscr::@2] - // [1298] phi clrscr::c#2 = clrscr::c#0 [phi:clrscr::@1/clrscr::@2->clrscr::@2#0] -- register_copy - // clrscr::@2 - __b2: - // *VERA_DATA0 = ' ' - // [1299] *VERA_DATA0 = ' ' -- _deref_pbuc1=vbuc2 - lda #' ' - sta VERA_DATA0 - // *VERA_DATA0 = __conio.color - // [1300] *VERA_DATA0 = *((char *)&__conio+$d) -- _deref_pbuc1=_deref_pbuc2 - lda __conio+$d - sta VERA_DATA0 - // c--; - // [1301] clrscr::c#1 = -- clrscr::c#2 -- vbum1=_dec_vbum1 - dec c - // while(c) - // [1302] if(0!=clrscr::c#1) goto clrscr::@2 -- 0_neq_vbum1_then_la1 - lda c - bne __b2 - // clrscr::@3 - // line_text += __conio.rowskip - // [1303] clrscr::line_text#1 = clrscr::ch#0 + *((unsigned int *)&__conio+$a) -- vwum1=vwum1_plus__deref_pwuc1 - clc - lda line_text - adc __conio+$a - sta line_text - lda line_text+1 - adc __conio+$a+1 - sta line_text+1 - // l--; - // [1304] clrscr::l#1 = -- clrscr::l#4 -- vbum1=_dec_vbum1 - dec l - // while(l) - // [1305] if(0!=clrscr::l#1) goto clrscr::@1 -- 0_neq_vbum1_then_la1 - lda l - bne __b1 - // clrscr::@4 - // __conio.cursor_x = 0 - // [1306] *((char *)&__conio) = 0 -- _deref_pbuc1=vbuc2 - lda #0 - sta __conio - // __conio.cursor_y = 0 - // [1307] *((char *)&__conio+1) = 0 -- _deref_pbuc1=vbuc2 - sta __conio+1 - // __conio.offset = __conio.mapbase_offset - // [1308] *((unsigned int *)&__conio+$13) = *((unsigned int *)&__conio+3) -- _deref_pwuc1=_deref_pwuc2 - lda __conio+3 - sta __conio+$13 - lda __conio+3+1 - sta __conio+$13+1 - // clrscr::@return - // } - // [1309] return - rts - .segment Data - .label line_text = ch - l: .byte 0 - ch: .word 0 - c: .byte 0 -} -.segment Code - // wait_moment -/** - * @brief - * - */ -// void wait_moment(__mem() char w) -wait_moment: { - // [1311] phi from wait_moment to wait_moment::@1 [phi:wait_moment->wait_moment::@1] - // [1311] phi wait_moment::j#2 = 0 [phi:wait_moment->wait_moment::@1#0] -- vbum1=vbuc1 - lda #0 - sta j - // wait_moment::@1 - __b1: - // for(unsigned char j=0; jwait_moment::@2] - __b4: - // [1314] phi wait_moment::i#2 = $ffff [phi:wait_moment::@1->wait_moment::@2#0] -- vwum1=vwuc1 - lda #<$ffff - sta i - lda #>$ffff - sta i+1 - // wait_moment::@2 - __b2: - // for(unsigned int i=65535; i>0; i--) - // [1315] if(wait_moment::i#2>0) goto wait_moment::@3 -- vwum1_gt_0_then_la1 - lda i+1 - bne __b3 - lda i - bne __b3 - !: - // wait_moment::@4 - // for(unsigned char j=0; jwait_moment::@1] - // [1311] phi wait_moment::j#2 = wait_moment::j#1 [phi:wait_moment::@4->wait_moment::@1#0] -- register_copy - jmp __b1 - // wait_moment::@3 - __b3: - // for(unsigned int i=65535; i>0; i--) - // [1317] wait_moment::i#1 = -- wait_moment::i#2 -- vwum1=_dec_vwum1 - lda i - bne !+ - dec i+1 - !: - dec i - // [1314] phi from wait_moment::@3 to wait_moment::@2 [phi:wait_moment::@3->wait_moment::@2] - // [1314] phi wait_moment::i#2 = wait_moment::i#1 [phi:wait_moment::@3->wait_moment::@2#0] -- register_copy - jmp __b2 - .segment Data - i: .word 0 - j: .byte 0 - w: .byte 0 -} -.segment Code - // system_reset -/** - * @brief - * - */ -system_reset: { - .const bank_set_bram1_bank = 0 - .const bank_set_brom1_bank = 0 - // system_reset::bank_set_bram1 - // BRAM = bank - // [1319] BRAM = system_reset::bank_set_bram1_bank#0 -- vbuz1=vbuc1 - lda #bank_set_bram1_bank - sta.z BRAM - // system_reset::bank_set_brom1 - // BROM = bank - // [1320] BROM = system_reset::bank_set_brom1_bank#0 -- vbuz1=vbuc1 - lda #bank_set_brom1_bank - sta.z BROM - // system_reset::@2 - // asm - // asm { jmp($FFFC) } - jmp ($fffc) - // [1322] phi from system_reset::@1 system_reset::@2 to system_reset::@1 [phi:system_reset::@1/system_reset::@2->system_reset::@1] - // system_reset::@1 - __b1: - jmp __b1 -} - // check_status_roms_less -/** - * @brief Check the status of all the ROMs. - * - * @param status The status to be checked. - * @return unsigned char true if all chips are equal to the status. - */ -// __mem() char check_status_roms_less(char status) -check_status_roms_less: { - .label check_status_roms_less__1 = $c2 - // [1324] phi from check_status_roms_less to check_status_roms_less::@1 [phi:check_status_roms_less->check_status_roms_less::@1] - // [1324] phi check_status_roms_less::rom_chip#2 = 0 [phi:check_status_roms_less->check_status_roms_less::@1#0] -- vbum1=vbuc1 - lda #0 - sta rom_chip - // check_status_roms_less::@1 - __b1: - // for(unsigned char rom_chip = 0; rom_chip < 8; rom_chip++) - // [1325] if(check_status_roms_less::rom_chip#2<8) goto check_status_roms_less::@2 -- vbum1_lt_vbuc1_then_la1 - lda rom_chip - cmp #8 - bcc __b2 - // [1328] phi from check_status_roms_less::@1 to check_status_roms_less::@return [phi:check_status_roms_less::@1->check_status_roms_less::@return] - // [1328] phi check_status_roms_less::return#2 = 1 [phi:check_status_roms_less::@1->check_status_roms_less::@return#0] -- vbum1=vbuc1 - lda #1 - sta return - rts - // check_status_roms_less::@2 - __b2: - // status_rom[rom_chip] > status - // [1326] check_status_roms_less::$1 = status_rom[check_status_roms_less::rom_chip#2] > STATUS_SKIP -- vboz1=pbuc1_derefidx_vbum2_gt_vbuc2 - ldy rom_chip - lda status_rom,y - cmp #STATUS_SKIP - lda #0 - rol - sta.z check_status_roms_less__1 - // if((unsigned char)(status_rom[rom_chip] > status)) - // [1327] if(0==(char)check_status_roms_less::$1) goto check_status_roms_less::@3 -- 0_eq_vbuz1_then_la1 - beq __b3 - // [1328] phi from check_status_roms_less::@2 to check_status_roms_less::@return [phi:check_status_roms_less::@2->check_status_roms_less::@return] - // [1328] phi check_status_roms_less::return#2 = 0 [phi:check_status_roms_less::@2->check_status_roms_less::@return#0] -- vbum1=vbuc1 - lda #0 - sta return - // check_status_roms_less::@return - // } - // [1329] return - rts - // check_status_roms_less::@3 - __b3: - // for(unsigned char rom_chip = 0; rom_chip < 8; rom_chip++) - // [1330] check_status_roms_less::rom_chip#1 = ++ check_status_roms_less::rom_chip#2 -- vbum1=_inc_vbum1 - inc rom_chip - // [1324] phi from check_status_roms_less::@3 to check_status_roms_less::@1 [phi:check_status_roms_less::@3->check_status_roms_less::@1] - // [1324] phi check_status_roms_less::rom_chip#2 = check_status_roms_less::rom_chip#1 [phi:check_status_roms_less::@3->check_status_roms_less::@1#0] -- register_copy + // [808] phi from check_status_roms_less::@3 to check_status_roms_less::@1 [phi:check_status_roms_less::@3->check_status_roms_less::@1] + // [808] phi check_status_roms_less::rom_chip#2 = check_status_roms_less::rom_chip#1 [phi:check_status_roms_less::@3->check_status_roms_less::@1#0] -- register_copy jmp __b1 .segment Data rom_chip: .byte 0 @@ -8959,57 +5242,57 @@ check_status_roms_less: { * @param text A pointer to an array of strings to be displayed (char**). * @param lines The amount of lines to be displayed, starting from the top of the progress frame. */ -// void display_progress_text(__zp($3b) char **text, __mem() char lines) +// void display_progress_text(__zp($3e) char **text, __mem() char lines) display_progress_text: { - .label display_progress_text__3 = $60 - .label text = $3b + .label display_progress_text__3 = $3b + .label text = $3e // display_progress_clear() - // [1332] call display_progress_clear - // [918] phi from display_progress_text to display_progress_clear [phi:display_progress_text->display_progress_clear] + // [816] call display_progress_clear + // [573] phi from display_progress_text to display_progress_clear [phi:display_progress_text->display_progress_clear] jsr display_progress_clear - // [1333] phi from display_progress_text to display_progress_text::@1 [phi:display_progress_text->display_progress_text::@1] - // [1333] phi display_progress_text::l#2 = 0 [phi:display_progress_text->display_progress_text::@1#0] -- vbum1=vbuc1 + // [817] phi from display_progress_text to display_progress_text::@1 [phi:display_progress_text->display_progress_text::@1] + // [817] phi display_progress_text::l#2 = 0 [phi:display_progress_text->display_progress_text::@1#0] -- vbum1=vbuc1 lda #0 sta l // display_progress_text::@1 __b1: // for(unsigned char l=0; ldisplay_progress_line] - // [1341] phi display_progress_line::text#3 = display_progress_line::text#0 [phi:display_progress_text::@2->display_progress_line#0] -- register_copy - // [1341] phi display_progress_line::line#3 = display_progress_line::line#0 [phi:display_progress_text::@2->display_progress_line#1] -- register_copy + // [823] call display_progress_line + // [825] phi from display_progress_text::@2 to display_progress_line [phi:display_progress_text::@2->display_progress_line] + // [825] phi display_progress_line::text#3 = display_progress_line::text#0 [phi:display_progress_text::@2->display_progress_line#0] -- register_copy + // [825] phi display_progress_line::line#3 = display_progress_line::line#0 [phi:display_progress_text::@2->display_progress_line#1] -- register_copy jsr display_progress_line // display_progress_text::@3 // for(unsigned char l=0; ldisplay_progress_text::@1] - // [1333] phi display_progress_text::l#2 = display_progress_text::l#1 [phi:display_progress_text::@3->display_progress_text::@1#0] -- register_copy + // [817] phi from display_progress_text::@3 to display_progress_text::@1 [phi:display_progress_text::@3->display_progress_text::@1] + // [817] phi display_progress_text::l#2 = display_progress_text::l#1 [phi:display_progress_text::@3->display_progress_text::@1#0] -- register_copy jmp __b1 .segment Data l: .byte 0 @@ -9023,71 +5306,97 @@ display_progress_text: { * @param line The start line, counting from 0. * @param text The text to be displayed. */ -// void display_progress_line(__mem() char line, __zp($6c) char *text) +// void display_progress_line(__mem() char line, __zp($49) char *text) display_progress_line: { - .label text = $6c + .label text = $49 // cputsxy(PROGRESS_X, PROGRESS_Y+line, text) - // [1342] cputsxy::y#0 = PROGRESS_Y + display_progress_line::line#3 -- vbum1=vbuc1_plus_vbum1 + // [826] cputsxy::y#0 = PROGRESS_Y + display_progress_line::line#3 -- vbum1=vbuc1_plus_vbum1 lda #PROGRESS_Y clc adc cputsxy.y sta cputsxy.y - // [1343] cputsxy::s#0 = display_progress_line::text#3 - // [1344] call cputsxy - // [897] phi from display_progress_line to cputsxy [phi:display_progress_line->cputsxy] - // [897] phi cputsxy::s#4 = cputsxy::s#0 [phi:display_progress_line->cputsxy#0] -- register_copy - // [897] phi cputsxy::y#4 = cputsxy::y#0 [phi:display_progress_line->cputsxy#1] -- register_copy - // [897] phi cputsxy::x#4 = PROGRESS_X [phi:display_progress_line->cputsxy#2] -- vbum1=vbuc1 + // [827] cputsxy::s#0 = display_progress_line::text#3 + // [828] call cputsxy + // [552] phi from display_progress_line to cputsxy [phi:display_progress_line->cputsxy] + // [552] phi cputsxy::s#3 = cputsxy::s#0 [phi:display_progress_line->cputsxy#0] -- register_copy + // [552] phi cputsxy::y#3 = cputsxy::y#0 [phi:display_progress_line->cputsxy#1] -- register_copy + // [552] phi cputsxy::x#3 = PROGRESS_X [phi:display_progress_line->cputsxy#2] -- vbum1=vbuc1 lda #PROGRESS_X sta cputsxy.x jsr cputsxy // display_progress_line::@return // } - // [1345] return + // [829] return rts .segment Data .label line = cputsxy.y } .segment Code + // snprintf_init +/// Initialize the snprintf() state +// void snprintf_init(char *s, unsigned int n) +snprintf_init: { + // __snprintf_capacity = n + // [830] __snprintf_capacity = $ffff -- vwum1=vwuc1 + lda #<$ffff + sta __snprintf_capacity + lda #>$ffff + sta __snprintf_capacity+1 + // __snprintf_size = 0 + // [831] __snprintf_size = 0 -- vwum1=vbuc1 + lda #<0 + sta __snprintf_size + sta __snprintf_size+1 + // __snprintf_buffer = s + // [832] __snprintf_buffer = info_text -- pbuz1=pbuc1 + lda #info_text + sta.z __snprintf_buffer+1 + // snprintf_init::@return + // } + // [833] return + rts +} // printf_uchar // Print an unsigned char using a specific format -// void printf_uchar(__zp($3b) void (*putc)(char), __mem() char uvalue, __mem() char format_min_length, char format_justify_left, char format_sign_always, __mem() char format_zero_padding, char format_upper_case, __mem() char format_radix) +// void printf_uchar(__zp($49) void (*putc)(char), __mem() char uvalue, __mem() char format_min_length, char format_justify_left, char format_sign_always, __mem() char format_zero_padding, char format_upper_case, __mem() char format_radix) printf_uchar: { - .label putc = $3b + .label putc = $49 // printf_uchar::@1 // printf_buffer.sign = format.sign_always?'+':0 - // [1347] *((char *)&printf_buffer) = 0 -- _deref_pbuc1=vbuc2 + // [835] *((char *)&printf_buffer) = 0 -- _deref_pbuc1=vbuc2 // Handle any sign lda #0 sta printf_buffer // uctoa(uvalue, printf_buffer.digits, format.radix) - // [1348] uctoa::value#1 = printf_uchar::uvalue#18 - // [1349] uctoa::radix#0 = printf_uchar::format_radix#18 - // [1350] call uctoa + // [836] uctoa::value#1 = printf_uchar::uvalue#10 + // [837] uctoa::radix#0 = printf_uchar::format_radix#10 + // [838] call uctoa // Format number into buffer jsr uctoa // printf_uchar::@2 // printf_number_buffer(putc, printf_buffer, format) - // [1351] printf_number_buffer::putc#2 = printf_uchar::putc#18 - // [1352] printf_number_buffer::buffer_sign#2 = *((char *)&printf_buffer) -- vbum1=_deref_pbuc1 + // [839] printf_number_buffer::putc#2 = printf_uchar::putc#10 + // [840] printf_number_buffer::buffer_sign#2 = *((char *)&printf_buffer) -- vbum1=_deref_pbuc1 lda printf_buffer sta printf_number_buffer.buffer_sign - // [1353] printf_number_buffer::format_min_length#2 = printf_uchar::format_min_length#18 - // [1354] printf_number_buffer::format_zero_padding#2 = printf_uchar::format_zero_padding#18 - // [1355] call printf_number_buffer + // [841] printf_number_buffer::format_min_length#2 = printf_uchar::format_min_length#10 + // [842] printf_number_buffer::format_zero_padding#2 = printf_uchar::format_zero_padding#10 + // [843] call printf_number_buffer // Print using format - // [2706] phi from printf_uchar::@2 to printf_number_buffer [phi:printf_uchar::@2->printf_number_buffer] - // [2706] phi printf_number_buffer::putc#10 = printf_number_buffer::putc#2 [phi:printf_uchar::@2->printf_number_buffer#0] -- register_copy - // [2706] phi printf_number_buffer::buffer_sign#10 = printf_number_buffer::buffer_sign#2 [phi:printf_uchar::@2->printf_number_buffer#1] -- register_copy - // [2706] phi printf_number_buffer::format_zero_padding#10 = printf_number_buffer::format_zero_padding#2 [phi:printf_uchar::@2->printf_number_buffer#2] -- register_copy - // [2706] phi printf_number_buffer::format_min_length#3 = printf_number_buffer::format_min_length#2 [phi:printf_uchar::@2->printf_number_buffer#3] -- register_copy + // [1539] phi from printf_uchar::@2 to printf_number_buffer [phi:printf_uchar::@2->printf_number_buffer] + // [1539] phi printf_number_buffer::putc#10 = printf_number_buffer::putc#2 [phi:printf_uchar::@2->printf_number_buffer#0] -- register_copy + // [1539] phi printf_number_buffer::buffer_sign#10 = printf_number_buffer::buffer_sign#2 [phi:printf_uchar::@2->printf_number_buffer#1] -- register_copy + // [1539] phi printf_number_buffer::format_zero_padding#10 = printf_number_buffer::format_zero_padding#2 [phi:printf_uchar::@2->printf_number_buffer#2] -- register_copy + // [1539] phi printf_number_buffer::format_min_length#3 = printf_number_buffer::format_min_length#2 [phi:printf_uchar::@2->printf_number_buffer#3] -- register_copy jsr printf_number_buffer // printf_uchar::@return // } - // [1356] return + // [844] return rts .segment Data - .label uvalue = smc_get_version_text.release + uvalue: .byte 0 format_radix: .byte 0 format_min_length: .byte 0 format_zero_padding: .byte 0 @@ -9099,73 +5408,73 @@ printf_uchar: { * * @param info_text The info text to be displayed. */ -// void display_action_text(__zp($4a) char *info_text) +// void display_action_text(__zp($59) char *info_text) display_action_text: { - .label info_text = $4a + .label info_text = $59 // unsigned char x = wherex() - // [1358] call wherex + // [846] call wherex jsr wherex - // [1359] wherex::return#3 = wherex::return#0 -- vbum1=vbum2 + // [847] wherex::return#3 = wherex::return#0 -- vbum1=vbum2 lda wherex.return sta wherex.return_1 // display_action_text::@1 - // [1360] display_action_text::x#0 = wherex::return#3 + // [848] display_action_text::x#0 = wherex::return#3 // unsigned char y = wherey() - // [1361] call wherey + // [849] call wherey jsr wherey - // [1362] wherey::return#3 = wherey::return#0 -- vbum1=vbum2 + // [850] wherey::return#3 = wherey::return#0 -- vbum1=vbum2 lda wherey.return sta wherey.return_1 // display_action_text::@2 - // [1363] display_action_text::y#0 = wherey::return#3 + // [851] display_action_text::y#0 = wherey::return#3 // gotoxy(2, PROGRESS_Y-3) - // [1364] call gotoxy - // [802] phi from display_action_text::@2 to gotoxy [phi:display_action_text::@2->gotoxy] - // [802] phi gotoxy::y#37 = PROGRESS_Y-3 [phi:display_action_text::@2->gotoxy#0] -- vbum1=vbuc1 + // [852] call gotoxy + // [457] phi from display_action_text::@2 to gotoxy [phi:display_action_text::@2->gotoxy] + // [457] phi gotoxy::y#26 = PROGRESS_Y-3 [phi:display_action_text::@2->gotoxy#0] -- vbum1=vbuc1 lda #PROGRESS_Y-3 sta gotoxy.y - // [802] phi gotoxy::x#37 = 2 [phi:display_action_text::@2->gotoxy#1] -- vbum1=vbuc1 + // [457] phi gotoxy::x#26 = 2 [phi:display_action_text::@2->gotoxy#1] -- vbum1=vbuc1 lda #2 sta gotoxy.x jsr gotoxy // display_action_text::@3 // printf("%-65s", info_text) - // [1365] printf_string::str#2 = display_action_text::info_text#25 -- pbuz1=pbuz2 + // [853] printf_string::str#2 = display_action_text::info_text#17 -- pbuz1=pbuz2 lda.z info_text sta.z printf_string.str lda.z info_text+1 sta.z printf_string.str+1 - // [1366] call printf_string - // [1219] phi from display_action_text::@3 to printf_string [phi:display_action_text::@3->printf_string] - // [1219] phi printf_string::putc#26 = &cputc [phi:display_action_text::@3->printf_string#0] -- pprz1=pprc1 + // [854] call printf_string + // [1308] phi from display_action_text::@3 to printf_string [phi:display_action_text::@3->printf_string] + // [1308] phi printf_string::putc#17 = &cputc [phi:display_action_text::@3->printf_string#0] -- pprz1=pprc1 lda #cputc sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#2 [phi:display_action_text::@3->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 1 [phi:display_action_text::@3->printf_string#2] -- vbum1=vbuc1 + // [1308] phi printf_string::str#17 = printf_string::str#2 [phi:display_action_text::@3->printf_string#1] -- register_copy + // [1308] phi printf_string::format_justify_left#17 = 1 [phi:display_action_text::@3->printf_string#2] -- vbum1=vbuc1 lda #1 sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = $41 [phi:display_action_text::@3->printf_string#3] -- vbum1=vbuc1 + // [1308] phi printf_string::format_min_length#17 = $41 [phi:display_action_text::@3->printf_string#3] -- vbum1=vbuc1 lda #$41 sta printf_string.format_min_length jsr printf_string // display_action_text::@4 // gotoxy(x, y) - // [1367] gotoxy::x#16 = display_action_text::x#0 -- vbum1=vbum2 + // [855] gotoxy::x#16 = display_action_text::x#0 -- vbum1=vbum2 lda x sta gotoxy.x - // [1368] gotoxy::y#16 = display_action_text::y#0 -- vbum1=vbum2 + // [856] gotoxy::y#16 = display_action_text::y#0 -- vbum1=vbum2 lda y sta gotoxy.y - // [1369] call gotoxy - // [802] phi from display_action_text::@4 to gotoxy [phi:display_action_text::@4->gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#16 [phi:display_action_text::@4->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = gotoxy::x#16 [phi:display_action_text::@4->gotoxy#1] -- register_copy + // [857] call gotoxy + // [457] phi from display_action_text::@4 to gotoxy [phi:display_action_text::@4->gotoxy] + // [457] phi gotoxy::y#26 = gotoxy::y#16 [phi:display_action_text::@4->gotoxy#0] -- register_copy + // [457] phi gotoxy::x#26 = gotoxy::x#16 [phi:display_action_text::@4->gotoxy#1] -- register_copy jsr gotoxy // display_action_text::@return // } - // [1370] return + // [858] return rts .segment Data .label x = wherex.return_1 @@ -9185,28 +5494,28 @@ smc_reset: { .const bank_set_brom1_bank = 0 // smc_reset::bank_set_bram1 // BRAM = bank - // [1372] BRAM = smc_reset::bank_set_bram1_bank#0 -- vbuz1=vbuc1 + // [860] BRAM = smc_reset::bank_set_bram1_bank#0 -- vbuz1=vbuc1 lda #bank_set_bram1_bank sta.z BRAM // smc_reset::bank_set_brom1 // BROM = bank - // [1373] BROM = smc_reset::bank_set_brom1_bank#0 -- vbuz1=vbuc1 + // [861] BROM = smc_reset::bank_set_brom1_bank#0 -- vbuz1=vbuc1 lda #bank_set_brom1_bank sta.z BROM // smc_reset::@1 // cx16_k_i2c_write_byte(FLASH_I2C_SMC_DEVICE, FLASH_I2C_SMC_REBOOT, 0) - // [1374] smc_reset::cx16_k_i2c_write_byte1_device = $42 -- vbum1=vbuc1 + // [862] smc_reset::cx16_k_i2c_write_byte1_device = $42 -- vbum1=vbuc1 lda #$42 sta cx16_k_i2c_write_byte1_device - // [1375] smc_reset::cx16_k_i2c_write_byte1_offset = $82 -- vbum1=vbuc1 + // [863] smc_reset::cx16_k_i2c_write_byte1_offset = $82 -- vbum1=vbuc1 lda #$82 sta cx16_k_i2c_write_byte1_offset - // [1376] smc_reset::cx16_k_i2c_write_byte1_value = 0 -- vbum1=vbuc1 + // [864] smc_reset::cx16_k_i2c_write_byte1_value = 0 -- vbum1=vbuc1 lda #0 sta cx16_k_i2c_write_byte1_value // smc_reset::cx16_k_i2c_write_byte1 // unsigned char result - // [1377] smc_reset::cx16_k_i2c_write_byte1_result = 0 -- vbum1=vbuc1 + // [865] smc_reset::cx16_k_i2c_write_byte1_result = 0 -- vbum1=vbuc1 sta cx16_k_i2c_write_byte1_result // asm // asm { ldxdevice ldyoffset ldavalue stzresult jsrCX16_I2C_WRITE_BYTE rolresult } @@ -9218,7 +5527,7 @@ smc_reset: { rol cx16_k_i2c_write_byte1_result // smc_reset::@return // } - // [1379] return + // [867] return rts .segment Data cx16_k_i2c_write_byte1_device: .byte 0 @@ -9236,30 +5545,30 @@ smc_reset: { */ // __mem() char check_status_card_roms(char status) check_status_card_roms: { - .label check_status_rom1_check_status_card_roms__0 = $61 - // [1381] phi from check_status_card_roms to check_status_card_roms::@1 [phi:check_status_card_roms->check_status_card_roms::@1] - // [1381] phi check_status_card_roms::rom_chip#2 = 1 [phi:check_status_card_roms->check_status_card_roms::@1#0] -- vbum1=vbuc1 + .label check_status_rom1_check_status_card_roms__0 = $3b + // [869] phi from check_status_card_roms to check_status_card_roms::@1 [phi:check_status_card_roms->check_status_card_roms::@1] + // [869] phi check_status_card_roms::rom_chip#2 = 1 [phi:check_status_card_roms->check_status_card_roms::@1#0] -- vbum1=vbuc1 lda #1 sta rom_chip // check_status_card_roms::@1 __b1: // for(unsigned char rom_chip = 1; rom_chip < 8; rom_chip++) - // [1382] if(check_status_card_roms::rom_chip#2<8) goto check_status_card_roms::check_status_rom1 -- vbum1_lt_vbuc1_then_la1 + // [870] if(check_status_card_roms::rom_chip#2<8) goto check_status_card_roms::check_status_rom1 -- vbum1_lt_vbuc1_then_la1 lda rom_chip cmp #8 bcc check_status_rom1 - // [1383] phi from check_status_card_roms::@1 to check_status_card_roms::@return [phi:check_status_card_roms::@1->check_status_card_roms::@return] - // [1383] phi check_status_card_roms::return#2 = 0 [phi:check_status_card_roms::@1->check_status_card_roms::@return#0] -- vbum1=vbuc1 + // [871] phi from check_status_card_roms::@1 to check_status_card_roms::@return [phi:check_status_card_roms::@1->check_status_card_roms::@return] + // [871] phi check_status_card_roms::return#2 = 0 [phi:check_status_card_roms::@1->check_status_card_roms::@return#0] -- vbum1=vbuc1 lda #0 sta return // check_status_card_roms::@return // } - // [1384] return + // [872] return rts // check_status_card_roms::check_status_rom1 check_status_rom1: // status_rom[rom_chip] == status - // [1385] check_status_card_roms::check_status_rom1_$0 = status_rom[check_status_card_roms::rom_chip#2] == STATUS_FLASH -- vboz1=pbuc1_derefidx_vbum2_eq_vbuc2 + // [873] check_status_card_roms::check_status_rom1_$0 = status_rom[check_status_card_roms::rom_chip#2] == STATUS_FLASH -- vboz1=pbuc1_derefidx_vbum2_eq_vbuc2 lda #STATUS_FLASH ldy rom_chip eor status_rom,y @@ -9269,24 +5578,24 @@ check_status_card_roms: { eor #1 sta.z check_status_rom1_check_status_card_roms__0 // return (unsigned char)(status_rom[rom_chip] == status); - // [1386] check_status_card_roms::check_status_rom1_return#0 = (char)check_status_card_roms::check_status_rom1_$0 -- vbum1=vbuz2 + // [874] check_status_card_roms::check_status_rom1_return#0 = (char)check_status_card_roms::check_status_rom1_$0 -- vbum1=vbuz2 sta check_status_rom1_return // check_status_card_roms::@3 // if(check_status_rom(rom_chip, status)) - // [1387] if(0==check_status_card_roms::check_status_rom1_return#0) goto check_status_card_roms::@2 -- 0_eq_vbum1_then_la1 + // [875] if(0==check_status_card_roms::check_status_rom1_return#0) goto check_status_card_roms::@2 -- 0_eq_vbum1_then_la1 beq __b2 - // [1383] phi from check_status_card_roms::@3 to check_status_card_roms::@return [phi:check_status_card_roms::@3->check_status_card_roms::@return] - // [1383] phi check_status_card_roms::return#2 = 1 [phi:check_status_card_roms::@3->check_status_card_roms::@return#0] -- vbum1=vbuc1 + // [871] phi from check_status_card_roms::@3 to check_status_card_roms::@return [phi:check_status_card_roms::@3->check_status_card_roms::@return] + // [871] phi check_status_card_roms::return#2 = 1 [phi:check_status_card_roms::@3->check_status_card_roms::@return#0] -- vbum1=vbuc1 lda #1 sta return rts // check_status_card_roms::@2 __b2: // for(unsigned char rom_chip = 1; rom_chip < 8; rom_chip++) - // [1388] check_status_card_roms::rom_chip#1 = ++ check_status_card_roms::rom_chip#2 -- vbum1=_inc_vbum1 + // [876] check_status_card_roms::rom_chip#1 = ++ check_status_card_roms::rom_chip#2 -- vbum1=_inc_vbum1 inc rom_chip - // [1381] phi from check_status_card_roms::@2 to check_status_card_roms::@1 [phi:check_status_card_roms::@2->check_status_card_roms::@1] - // [1381] phi check_status_card_roms::rom_chip#2 = check_status_card_roms::rom_chip#1 [phi:check_status_card_roms::@2->check_status_card_roms::@1#0] -- register_copy + // [869] phi from check_status_card_roms::@2 to check_status_card_roms::@1 [phi:check_status_card_roms::@2->check_status_card_roms::@1] + // [869] phi check_status_card_roms::rom_chip#2 = check_status_card_roms::rom_chip#1 [phi:check_status_card_roms::@2->check_status_card_roms::@1#0] -- register_copy jmp __b1 .segment Data check_status_rom1_return: .byte 0 @@ -9297,14 +5606,14 @@ check_status_card_roms: { // util_wait_space util_wait_space: { // util_wait_key("Press [SPACE] to continue ...", " ") - // [1390] call util_wait_key - // [1999] phi from util_wait_space to util_wait_key [phi:util_wait_space->util_wait_key] - // [1999] phi util_wait_key::filter#13 = s4 [phi:util_wait_space->util_wait_key#0] -- pbuz1=pbuc1 - lda #util_wait_key] + // [1034] phi util_wait_key::filter#13 = s [phi:util_wait_space->util_wait_key#0] -- pbuz1=pbuc1 + lda #s4 + lda #>s sta.z util_wait_key.filter+1 - // [1999] phi util_wait_key::info_text#3 = util_wait_space::info_text [phi:util_wait_space->util_wait_key#1] -- pbuz1=pbuc1 + // [1034] phi util_wait_key::info_text#3 = util_wait_space::info_text [phi:util_wait_space->util_wait_key#1] -- pbuz1=pbuc1 lda #info_text @@ -9312,7 +5621,7 @@ util_wait_space: { jsr util_wait_key // util_wait_space::@return // } - // [1391] return + // [879] return rts .segment Data info_text: .text "Press [SPACE] to continue ..." @@ -9321,36 +5630,32 @@ util_wait_space: { .segment CodeVera // main_vera_flash main_vera_flash: { - .label vera_bytes_read = $d2 - .label spi_ensure_detect = $ca - .label vera_differences1 = $f1 - .label spi_ensure_detect_1 = $cb + .label vera_bytes_read = $ab + .label vera_differences = $b8 + .label spi_ensure_detect = $7d + .label vera_flashed = $bc + .label vera_differences1 = $b4 + .label spi_ensure_detect_1 = $7e // display_progress_clear() - // [1393] call display_progress_clear - // [918] phi from main_vera_flash to display_progress_clear [phi:main_vera_flash->display_progress_clear] + // [881] call display_progress_clear + // [573] phi from main_vera_flash to display_progress_clear [phi:main_vera_flash->display_progress_clear] jsr display_progress_clear - // [1394] phi from main_vera_flash to main_vera_flash::@19 [phi:main_vera_flash->main_vera_flash::@19] + // [882] phi from main_vera_flash to main_vera_flash::@19 [phi:main_vera_flash->main_vera_flash::@19] // main_vera_flash::@19 // sprintf(info_text, "Reading VERA.BIN ... (.) data ( ) empty") - // [1395] call snprintf_init - // [1205] phi from main_vera_flash::@19 to snprintf_init [phi:main_vera_flash::@19->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:main_vera_flash::@19->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 + // [883] call snprintf_init jsr snprintf_init - // [1396] phi from main_vera_flash::@19 to main_vera_flash::@20 [phi:main_vera_flash::@19->main_vera_flash::@20] + // [884] phi from main_vera_flash::@19 to main_vera_flash::@20 [phi:main_vera_flash::@19->main_vera_flash::@20] // main_vera_flash::@20 // sprintf(info_text, "Reading VERA.BIN ... (.) data ( ) empty") - // [1397] call printf_str - // [1210] phi from main_vera_flash::@20 to printf_str [phi:main_vera_flash::@20->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main_vera_flash::@20->printf_str#0] -- pprz1=pprc1 + // [885] call printf_str + // [785] phi from main_vera_flash::@20 to printf_str [phi:main_vera_flash::@20->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:main_vera_flash::@20->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main_vera_flash::s [phi:main_vera_flash::@20->printf_str#1] -- pbuz1=pbuc1 + // [785] phi printf_str::s#53 = main_vera_flash::s [phi:main_vera_flash::@20->printf_str#1] -- pbuz1=pbuc1 lda #s @@ -9358,37 +5663,37 @@ main_vera_flash: { jsr printf_str // main_vera_flash::@21 // sprintf(info_text, "Reading VERA.BIN ... (.) data ( ) empty") - // [1398] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 + // [886] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 lda #0 pha - // [1399] callexecute snputc -- call_vprc1 + // [887] callexecute snputc -- call_vprc1 jsr snputc // sideeffect stackpullpadding(1) -- _stackpullpadding_1 pla // display_action_progress(info_text) - // [1401] call display_action_progress - // [904] phi from main_vera_flash::@21 to display_action_progress [phi:main_vera_flash::@21->display_action_progress] - // [904] phi display_action_progress::info_text#27 = info_text [phi:main_vera_flash::@21->display_action_progress#0] -- pbuz1=pbuc1 + // [889] call display_action_progress + // [559] phi from main_vera_flash::@21 to display_action_progress [phi:main_vera_flash::@21->display_action_progress] + // [559] phi display_action_progress::info_text#19 = info_text [phi:main_vera_flash::@21->display_action_progress#0] -- pbuz1=pbuc1 lda #<@info_text sta.z display_action_progress.info_text lda #>@info_text sta.z display_action_progress.info_text+1 jsr display_action_progress - // [1402] phi from main_vera_flash::@21 to main_vera_flash::@22 [phi:main_vera_flash::@21->main_vera_flash::@22] + // [890] phi from main_vera_flash::@21 to main_vera_flash::@22 [phi:main_vera_flash::@21->main_vera_flash::@22] // main_vera_flash::@22 // unsigned long vera_bytes_read = vera_read(STATUS_READING) - // [1403] call vera_read - // [2625] phi from main_vera_flash::@22 to vera_read [phi:main_vera_flash::@22->vera_read] - // [2625] phi __errno#100 = __errno#115 [phi:main_vera_flash::@22->vera_read#0] -- register_copy - // [2625] phi __stdio_filecount#123 = __stdio_filecount#111 [phi:main_vera_flash::@22->vera_read#1] -- register_copy - // [2625] phi vera_read::info_status#12 = STATUS_READING [phi:main_vera_flash::@22->vera_read#2] -- vbum1=vbuc1 + // [891] call vera_read + // [1458] phi from main_vera_flash::@22 to vera_read [phi:main_vera_flash::@22->vera_read] + // [1458] phi __errno#118 = __errno#18 [phi:main_vera_flash::@22->vera_read#0] -- register_copy + // [1458] phi __stdio_filecount#105 = __stdio_filecount#26 [phi:main_vera_flash::@22->vera_read#1] -- register_copy + // [1458] phi vera_read::info_status#12 = STATUS_READING [phi:main_vera_flash::@22->vera_read#2] -- vbum1=vbuc1 lda #STATUS_READING sta vera_read.info_status jsr vera_read // unsigned long vera_bytes_read = vera_read(STATUS_READING) - // [1404] vera_read::return#3 = vera_read::return#0 + // [892] vera_read::return#3 = vera_read::return#0 // main_vera_flash::@23 - // [1405] main_vera_flash::vera_bytes_read#0 = vera_read::return#3 -- vduz1=vdum2 + // [893] main_vera_flash::vera_bytes_read#0 = vera_read::return#3 -- vduz1=vdum2 lda vera_read.return sta.z vera_bytes_read lda vera_read.return+1 @@ -9398,7 +5703,7 @@ main_vera_flash: { lda vera_read.return+3 sta.z vera_bytes_read+3 // if(vera_bytes_read) - // [1406] if(0==main_vera_flash::vera_bytes_read#0) goto main_vera_flash::@1 -- 0_eq_vduz1_then_la1 + // [894] if(0==main_vera_flash::vera_bytes_read#0) goto main_vera_flash::@1 -- 0_eq_vduz1_then_la1 lda.z vera_bytes_read ora.z vera_bytes_read+1 ora.z vera_bytes_read+2 @@ -9406,401 +5711,380 @@ main_vera_flash: { bne !__b1+ jmp __b1 !__b1: - // [1407] phi from main_vera_flash::@23 to main_vera_flash::@2 [phi:main_vera_flash::@23->main_vera_flash::@2] + // [895] phi from main_vera_flash::@23 to main_vera_flash::@2 [phi:main_vera_flash::@23->main_vera_flash::@2] // main_vera_flash::@2 // display_action_progress("VERA SPI activation ...") - // [1408] call display_action_progress + // [896] call display_action_progress // Now we loop until jumper JP1 has been placed! - // [904] phi from main_vera_flash::@2 to display_action_progress [phi:main_vera_flash::@2->display_action_progress] - // [904] phi display_action_progress::info_text#27 = main_vera_flash::info_text [phi:main_vera_flash::@2->display_action_progress#0] -- pbuz1=pbuc1 + // [559] phi from main_vera_flash::@2 to display_action_progress [phi:main_vera_flash::@2->display_action_progress] + // [559] phi display_action_progress::info_text#19 = main_vera_flash::info_text [phi:main_vera_flash::@2->display_action_progress#0] -- pbuz1=pbuc1 lda #info_text sta.z display_action_progress.info_text+1 jsr display_action_progress - // [1409] phi from main_vera_flash::@2 to main_vera_flash::@24 [phi:main_vera_flash::@2->main_vera_flash::@24] + // [897] phi from main_vera_flash::@2 to main_vera_flash::@24 [phi:main_vera_flash::@2->main_vera_flash::@24] // main_vera_flash::@24 // display_action_text("Please close the jumper JP1 on the VERA board!") - // [1410] call display_action_text - // [1357] phi from main_vera_flash::@24 to display_action_text [phi:main_vera_flash::@24->display_action_text] - // [1357] phi display_action_text::info_text#25 = main_vera_flash::info_text1 [phi:main_vera_flash::@24->display_action_text#0] -- pbuz1=pbuc1 + // [898] call display_action_text + // [845] phi from main_vera_flash::@24 to display_action_text [phi:main_vera_flash::@24->display_action_text] + // [845] phi display_action_text::info_text#17 = main_vera_flash::info_text1 [phi:main_vera_flash::@24->display_action_text#0] -- pbuz1=pbuc1 lda #info_text1 sta.z display_action_text.info_text+1 jsr display_action_text - // [1411] phi from main_vera_flash::@24 to main_vera_flash::@25 [phi:main_vera_flash::@24->main_vera_flash::@25] + // [899] phi from main_vera_flash::@24 to main_vera_flash::@25 [phi:main_vera_flash::@24->main_vera_flash::@25] // main_vera_flash::@25 // vera_detect() - // [1412] call vera_detect - // [2391] phi from main_vera_flash::@25 to vera_detect [phi:main_vera_flash::@25->vera_detect] + // [900] call vera_detect + // [1455] phi from main_vera_flash::@25 to vera_detect [phi:main_vera_flash::@25->vera_detect] jsr vera_detect - // [1413] phi from main_vera_flash::@25 main_vera_flash::@7 to main_vera_flash::@3 [phi:main_vera_flash::@25/main_vera_flash::@7->main_vera_flash::@3] + // [901] phi from main_vera_flash::@25 main_vera_flash::@7 to main_vera_flash::@3 [phi:main_vera_flash::@25/main_vera_flash::@7->main_vera_flash::@3] __b2: - // [1413] phi main_vera_flash::spi_ensure_detect#11 = 0 [phi:main_vera_flash::@25/main_vera_flash::@7->main_vera_flash::@3#0] -- vbuz1=vbuc1 + // [901] phi main_vera_flash::spi_ensure_detect#11 = 0 [phi:main_vera_flash::@25/main_vera_flash::@7->main_vera_flash::@3#0] -- vbuz1=vbuc1 lda #0 sta.z spi_ensure_detect // main_vera_flash::@3 __b3: // while(spi_ensure_detect < 16) - // [1414] if(main_vera_flash::spi_ensure_detect#11<$10) goto main_vera_flash::@4 -- vbuz1_lt_vbuc1_then_la1 + // [902] if(main_vera_flash::spi_ensure_detect#11<$10) goto main_vera_flash::@4 -- vbuz1_lt_vbuc1_then_la1 lda.z spi_ensure_detect cmp #$10 bcs !__b4+ jmp __b4 !__b4: - // [1415] phi from main_vera_flash::@3 to main_vera_flash::@5 [phi:main_vera_flash::@3->main_vera_flash::@5] + // [903] phi from main_vera_flash::@3 to main_vera_flash::@5 [phi:main_vera_flash::@3->main_vera_flash::@5] // main_vera_flash::@5 // display_action_text("The jumper JP1 has been closed on the VERA!") - // [1416] call display_action_text - // [1357] phi from main_vera_flash::@5 to display_action_text [phi:main_vera_flash::@5->display_action_text] - // [1357] phi display_action_text::info_text#25 = main_vera_flash::info_text2 [phi:main_vera_flash::@5->display_action_text#0] -- pbuz1=pbuc1 + // [904] call display_action_text + // [845] phi from main_vera_flash::@5 to display_action_text [phi:main_vera_flash::@5->display_action_text] + // [845] phi display_action_text::info_text#17 = main_vera_flash::info_text2 [phi:main_vera_flash::@5->display_action_text#0] -- pbuz1=pbuc1 lda #info_text2 sta.z display_action_text.info_text+1 jsr display_action_text - // [1417] phi from main_vera_flash::@5 to main_vera_flash::@28 [phi:main_vera_flash::@5->main_vera_flash::@28] + // [905] phi from main_vera_flash::@5 to main_vera_flash::@28 [phi:main_vera_flash::@5->main_vera_flash::@28] // main_vera_flash::@28 // display_action_progress("Comparing VERA ... (.) data, (=) same, (*) different.") - // [1418] call display_action_progress + // [906] call display_action_progress // Now we compare the RAM with the actual VERA contents. - // [904] phi from main_vera_flash::@28 to display_action_progress [phi:main_vera_flash::@28->display_action_progress] - // [904] phi display_action_progress::info_text#27 = main_vera_flash::info_text3 [phi:main_vera_flash::@28->display_action_progress#0] -- pbuz1=pbuc1 + // [559] phi from main_vera_flash::@28 to display_action_progress [phi:main_vera_flash::@28->display_action_progress] + // [559] phi display_action_progress::info_text#19 = main_vera_flash::info_text3 [phi:main_vera_flash::@28->display_action_progress#0] -- pbuz1=pbuc1 lda #info_text3 sta.z display_action_progress.info_text+1 jsr display_action_progress // main_vera_flash::@29 - // [1419] spi_manufacturer#589 = spi_read::return#0 -- vbum1=vbum2 + // [907] spi_manufacturer#415 = spi_read::return#0 -- vbum1=vbum2 lda spi_read.return sta spi_manufacturer - // [1420] spi_memory_type#590 = spi_read::return#1 -- vbum1=vbum2 + // [908] spi_memory_type#416 = spi_read::return#1 -- vbum1=vbum2 lda spi_read.return_1 sta spi_memory_type - // [1421] spi_memory_capacity#591 = spi_read::return#2 -- vbum1=vbum2 + // [909] spi_memory_capacity#417 = spi_read::return#2 -- vbum1=vbum2 lda spi_read.return_2 sta spi_memory_capacity // display_info_vera(STATUS_COMPARING, NULL) - // [1422] call display_info_vera - // [998] phi from main_vera_flash::@29 to display_info_vera [phi:main_vera_flash::@29->display_info_vera] - // [998] phi display_info_vera::info_text#19 = 0 [phi:main_vera_flash::@29->display_info_vera#0] -- pbuz1=vbuc1 + // [910] call display_info_vera + // [653] phi from main_vera_flash::@29 to display_info_vera [phi:main_vera_flash::@29->display_info_vera] + // [653] phi display_info_vera::info_text#19 = 0 [phi:main_vera_flash::@29->display_info_vera#0] -- pbuz1=vbuc1 lda #<0 sta.z display_info_vera.info_text sta.z display_info_vera.info_text+1 - // [998] phi spi_memory_capacity#106 = spi_memory_capacity#591 [phi:main_vera_flash::@29->display_info_vera#1] -- register_copy - // [998] phi spi_memory_type#107 = spi_memory_type#590 [phi:main_vera_flash::@29->display_info_vera#2] -- register_copy - // [998] phi spi_manufacturer#108 = spi_manufacturer#589 [phi:main_vera_flash::@29->display_info_vera#3] -- register_copy - // [998] phi display_info_vera::info_status#19 = STATUS_COMPARING [phi:main_vera_flash::@29->display_info_vera#4] -- vbum1=vbuc1 + // [653] phi spi_memory_capacity#110 = spi_memory_capacity#417 [phi:main_vera_flash::@29->display_info_vera#1] -- register_copy + // [653] phi spi_memory_type#111 = spi_memory_type#416 [phi:main_vera_flash::@29->display_info_vera#2] -- register_copy + // [653] phi spi_manufacturer#100 = spi_manufacturer#415 [phi:main_vera_flash::@29->display_info_vera#3] -- register_copy + // [653] phi display_info_vera::info_status#19 = STATUS_COMPARING [phi:main_vera_flash::@29->display_info_vera#4] -- vbum1=vbuc1 lda #STATUS_COMPARING sta display_info_vera.info_status jsr display_info_vera - // [1423] phi from main_vera_flash::@29 to main_vera_flash::@30 [phi:main_vera_flash::@29->main_vera_flash::@30] + // [911] phi from main_vera_flash::@29 to main_vera_flash::@30 [phi:main_vera_flash::@29->main_vera_flash::@30] // main_vera_flash::@30 // unsigned long vera_differences = vera_verify() - // [1424] call vera_verify + // [912] call vera_verify // Verify VERA ... - // [2737] phi from main_vera_flash::@30 to vera_verify [phi:main_vera_flash::@30->vera_verify] + // [1570] phi from main_vera_flash::@30 to vera_verify [phi:main_vera_flash::@30->vera_verify] jsr vera_verify // unsigned long vera_differences = vera_verify() - // [1425] vera_verify::return#2 = vera_verify::vera_different_bytes#11 + // [913] vera_verify::return#2 = vera_verify::vera_different_bytes#11 // main_vera_flash::@31 - // [1426] main_vera_flash::vera_differences#0 = vera_verify::return#2 -- vdum1=vdum2 + // [914] main_vera_flash::vera_differences#0 = vera_verify::return#2 -- vduz1=vdum2 lda vera_verify.return - sta vera_differences + sta.z vera_differences lda vera_verify.return+1 - sta vera_differences+1 + sta.z vera_differences+1 lda vera_verify.return+2 - sta vera_differences+2 + sta.z vera_differences+2 lda vera_verify.return+3 - sta vera_differences+3 + sta.z vera_differences+3 // if (!vera_differences) - // [1427] if(0==main_vera_flash::vera_differences#0) goto main_vera_flash::@9 -- 0_eq_vdum1_then_la1 - lda vera_differences - ora vera_differences+1 - ora vera_differences+2 - ora vera_differences+3 + // [915] if(0==main_vera_flash::vera_differences#0) goto main_vera_flash::@9 -- 0_eq_vduz1_then_la1 + lda.z vera_differences + ora.z vera_differences+1 + ora.z vera_differences+2 + ora.z vera_differences+3 bne !__b9+ jmp __b9 !__b9: - // [1428] phi from main_vera_flash::@31 to main_vera_flash::@8 [phi:main_vera_flash::@31->main_vera_flash::@8] + // [916] phi from main_vera_flash::@31 to main_vera_flash::@8 [phi:main_vera_flash::@31->main_vera_flash::@8] // main_vera_flash::@8 // sprintf(info_text, "%05x differences!", vera_differences) - // [1429] call snprintf_init - // [1205] phi from main_vera_flash::@8 to snprintf_init [phi:main_vera_flash::@8->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:main_vera_flash::@8->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 + // [917] call snprintf_init jsr snprintf_init // main_vera_flash::@33 - // sprintf(info_text, "%05x differences!", vera_differences) - // [1430] printf_ulong::uvalue#10 = main_vera_flash::vera_differences#0 -- vdum1=vdum2 - lda vera_differences + // [918] printf_ulong::uvalue#7 = main_vera_flash::vera_differences#0 -- vdum1=vduz2 + lda.z vera_differences sta printf_ulong.uvalue - lda vera_differences+1 + lda.z vera_differences+1 sta printf_ulong.uvalue+1 - lda vera_differences+2 + lda.z vera_differences+2 sta printf_ulong.uvalue+2 - lda vera_differences+3 + lda.z vera_differences+3 sta printf_ulong.uvalue+3 - // [1431] call printf_ulong - // [1741] phi from main_vera_flash::@33 to printf_ulong [phi:main_vera_flash::@33->printf_ulong] - // [1741] phi printf_ulong::format_zero_padding#15 = 1 [phi:main_vera_flash::@33->printf_ulong#0] -- vbum1=vbuc1 + // [919] call printf_ulong + // [1633] phi from main_vera_flash::@33 to printf_ulong [phi:main_vera_flash::@33->printf_ulong] + // [1633] phi printf_ulong::format_zero_padding#10 = 1 [phi:main_vera_flash::@33->printf_ulong#0] -- vbum1=vbuc1 lda #1 sta printf_ulong.format_zero_padding - // [1741] phi printf_ulong::format_min_length#15 = 5 [phi:main_vera_flash::@33->printf_ulong#1] -- vbum1=vbuc1 + // [1633] phi printf_ulong::format_min_length#10 = 5 [phi:main_vera_flash::@33->printf_ulong#1] -- vbum1=vbuc1 lda #5 sta printf_ulong.format_min_length - // [1741] phi printf_ulong::format_radix#15 = HEXADECIMAL [phi:main_vera_flash::@33->printf_ulong#2] -- vbum1=vbuc1 + // [1633] phi printf_ulong::format_radix#10 = HEXADECIMAL [phi:main_vera_flash::@33->printf_ulong#2] -- vbum1=vbuc1 lda #HEXADECIMAL sta printf_ulong.format_radix - // [1741] phi printf_ulong::uvalue#15 = printf_ulong::uvalue#10 [phi:main_vera_flash::@33->printf_ulong#3] -- register_copy + // [1633] phi printf_ulong::uvalue#10 = printf_ulong::uvalue#7 [phi:main_vera_flash::@33->printf_ulong#3] -- register_copy jsr printf_ulong - // [1432] phi from main_vera_flash::@33 to main_vera_flash::@34 [phi:main_vera_flash::@33->main_vera_flash::@34] + // [920] phi from main_vera_flash::@33 to main_vera_flash::@34 [phi:main_vera_flash::@33->main_vera_flash::@34] // main_vera_flash::@34 // sprintf(info_text, "%05x differences!", vera_differences) - // [1433] call printf_str - // [1210] phi from main_vera_flash::@34 to printf_str [phi:main_vera_flash::@34->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main_vera_flash::@34->printf_str#0] -- pprz1=pprc1 + // [921] call printf_str + // [785] phi from main_vera_flash::@34 to printf_str [phi:main_vera_flash::@34->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:main_vera_flash::@34->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s13 [phi:main_vera_flash::@34->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #s13 + lda #>s1 sta.z printf_str.s+1 jsr printf_str // main_vera_flash::@35 // sprintf(info_text, "%05x differences!", vera_differences) - // [1434] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 + // [922] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 lda #0 pha - // [1435] callexecute snputc -- call_vprc1 + // [923] callexecute snputc -- call_vprc1 jsr snputc // sideeffect stackpullpadding(1) -- _stackpullpadding_1 pla - // [1437] spi_manufacturer#590 = spi_read::return#0 -- vbum1=vbum2 + // [925] spi_manufacturer#416 = spi_read::return#0 -- vbum1=vbum2 lda spi_read.return sta spi_manufacturer - // [1438] spi_memory_type#591 = spi_read::return#1 -- vbum1=vbum2 + // [926] spi_memory_type#417 = spi_read::return#1 -- vbum1=vbum2 lda spi_read.return_1 sta spi_memory_type - // [1439] spi_memory_capacity#592 = spi_read::return#2 -- vbum1=vbum2 + // [927] spi_memory_capacity#418 = spi_read::return#2 -- vbum1=vbum2 lda spi_read.return_2 sta spi_memory_capacity // display_info_vera(STATUS_FLASH, info_text) - // [1440] call display_info_vera - // [998] phi from main_vera_flash::@35 to display_info_vera [phi:main_vera_flash::@35->display_info_vera] - // [998] phi display_info_vera::info_text#19 = info_text [phi:main_vera_flash::@35->display_info_vera#0] -- pbuz1=pbuc1 + // [928] call display_info_vera + // [653] phi from main_vera_flash::@35 to display_info_vera [phi:main_vera_flash::@35->display_info_vera] + // [653] phi display_info_vera::info_text#19 = info_text [phi:main_vera_flash::@35->display_info_vera#0] -- pbuz1=pbuc1 lda #<@info_text sta.z display_info_vera.info_text lda #>@info_text sta.z display_info_vera.info_text+1 - // [998] phi spi_memory_capacity#106 = spi_memory_capacity#592 [phi:main_vera_flash::@35->display_info_vera#1] -- register_copy - // [998] phi spi_memory_type#107 = spi_memory_type#591 [phi:main_vera_flash::@35->display_info_vera#2] -- register_copy - // [998] phi spi_manufacturer#108 = spi_manufacturer#590 [phi:main_vera_flash::@35->display_info_vera#3] -- register_copy - // [998] phi display_info_vera::info_status#19 = STATUS_FLASH [phi:main_vera_flash::@35->display_info_vera#4] -- vbum1=vbuc1 + // [653] phi spi_memory_capacity#110 = spi_memory_capacity#418 [phi:main_vera_flash::@35->display_info_vera#1] -- register_copy + // [653] phi spi_memory_type#111 = spi_memory_type#417 [phi:main_vera_flash::@35->display_info_vera#2] -- register_copy + // [653] phi spi_manufacturer#100 = spi_manufacturer#416 [phi:main_vera_flash::@35->display_info_vera#3] -- register_copy + // [653] phi display_info_vera::info_status#19 = STATUS_FLASH [phi:main_vera_flash::@35->display_info_vera#4] -- vbum1=vbuc1 lda #STATUS_FLASH sta display_info_vera.info_status jsr display_info_vera - // [1441] phi from main_vera_flash::@35 to main_vera_flash::@36 [phi:main_vera_flash::@35->main_vera_flash::@36] + // [929] phi from main_vera_flash::@35 to main_vera_flash::@36 [phi:main_vera_flash::@35->main_vera_flash::@36] // main_vera_flash::@36 // unsigned char vera_erase_error = vera_erase() - // [1442] call vera_erase + // [930] call vera_erase jsr vera_erase - // [1443] phi from main_vera_flash::@36 to main_vera_flash::@10 [phi:main_vera_flash::@36->main_vera_flash::@10] + // [931] phi from main_vera_flash::@36 to main_vera_flash::@10 [phi:main_vera_flash::@36->main_vera_flash::@10] // main_vera_flash::@10 // unsigned long vera_flashed = vera_flash() - // [1444] call vera_flash - // [2806] phi from main_vera_flash::@10 to vera_flash [phi:main_vera_flash::@10->vera_flash] + // [932] call vera_flash + // [1649] phi from main_vera_flash::@10 to vera_flash [phi:main_vera_flash::@10->vera_flash] jsr vera_flash // unsigned long vera_flashed = vera_flash() - // [1445] vera_flash::return#3 = vera_flash::return#2 + // [933] vera_flash::return#3 = vera_flash::return#2 // main_vera_flash::@37 - // [1446] main_vera_flash::vera_flashed#0 = vera_flash::return#3 -- vdum1=vdum2 + // [934] main_vera_flash::vera_flashed#0 = vera_flash::return#3 -- vduz1=vdum2 lda vera_flash.return - sta vera_flashed + sta.z vera_flashed lda vera_flash.return+1 - sta vera_flashed+1 + sta.z vera_flashed+1 lda vera_flash.return+2 - sta vera_flashed+2 + sta.z vera_flashed+2 lda vera_flash.return+3 - sta vera_flashed+3 + sta.z vera_flashed+3 // if(vera_flashed) - // [1447] if(0!=main_vera_flash::vera_flashed#0) goto main_vera_flash::@11 -- 0_neq_vdum1_then_la1 - lda vera_flashed - ora vera_flashed+1 - ora vera_flashed+2 - ora vera_flashed+3 - beq !__b11+ - jmp __b11 - !__b11: + // [935] if(0!=main_vera_flash::vera_flashed#0) goto main_vera_flash::@11 -- 0_neq_vduz1_then_la1 + lda.z vera_flashed + ora.z vera_flashed+1 + ora.z vera_flashed+2 + ora.z vera_flashed+3 + bne __b11 // main_vera_flash::@12 - // [1448] spi_manufacturer#586 = spi_read::return#0 -- vbum1=vbum2 + // [936] spi_manufacturer#412 = spi_read::return#0 -- vbum1=vbum2 lda spi_read.return sta spi_manufacturer - // [1449] spi_memory_type#587 = spi_read::return#1 -- vbum1=vbum2 + // [937] spi_memory_type#413 = spi_read::return#1 -- vbum1=vbum2 lda spi_read.return_1 sta spi_memory_type - // [1450] spi_memory_capacity#588 = spi_read::return#2 -- vbum1=vbum2 + // [938] spi_memory_capacity#414 = spi_read::return#2 -- vbum1=vbum2 lda spi_read.return_2 sta spi_memory_capacity // display_info_vera(STATUS_ERROR, info_text) - // [1451] call display_info_vera + // [939] call display_info_vera // VFL2 | Flash VERA resulting in errors - // [998] phi from main_vera_flash::@12 to display_info_vera [phi:main_vera_flash::@12->display_info_vera] - // [998] phi display_info_vera::info_text#19 = info_text [phi:main_vera_flash::@12->display_info_vera#0] -- pbuz1=pbuc1 + // [653] phi from main_vera_flash::@12 to display_info_vera [phi:main_vera_flash::@12->display_info_vera] + // [653] phi display_info_vera::info_text#19 = info_text [phi:main_vera_flash::@12->display_info_vera#0] -- pbuz1=pbuc1 lda #<@info_text sta.z display_info_vera.info_text lda #>@info_text sta.z display_info_vera.info_text+1 - // [998] phi spi_memory_capacity#106 = spi_memory_capacity#588 [phi:main_vera_flash::@12->display_info_vera#1] -- register_copy - // [998] phi spi_memory_type#107 = spi_memory_type#587 [phi:main_vera_flash::@12->display_info_vera#2] -- register_copy - // [998] phi spi_manufacturer#108 = spi_manufacturer#586 [phi:main_vera_flash::@12->display_info_vera#3] -- register_copy - // [998] phi display_info_vera::info_status#19 = STATUS_ERROR [phi:main_vera_flash::@12->display_info_vera#4] -- vbum1=vbuc1 + // [653] phi spi_memory_capacity#110 = spi_memory_capacity#414 [phi:main_vera_flash::@12->display_info_vera#1] -- register_copy + // [653] phi spi_memory_type#111 = spi_memory_type#413 [phi:main_vera_flash::@12->display_info_vera#2] -- register_copy + // [653] phi spi_manufacturer#100 = spi_manufacturer#412 [phi:main_vera_flash::@12->display_info_vera#3] -- register_copy + // [653] phi display_info_vera::info_status#19 = STATUS_ERROR [phi:main_vera_flash::@12->display_info_vera#4] -- vbum1=vbuc1 lda #STATUS_ERROR sta display_info_vera.info_status jsr display_info_vera - // [1452] phi from main_vera_flash::@12 to main_vera_flash::@46 [phi:main_vera_flash::@12->main_vera_flash::@46] + // [940] phi from main_vera_flash::@12 to main_vera_flash::@46 [phi:main_vera_flash::@12->main_vera_flash::@46] // main_vera_flash::@46 // display_action_progress("There was an error updating your VERA flash memory!") - // [1453] call display_action_progress - // [904] phi from main_vera_flash::@46 to display_action_progress [phi:main_vera_flash::@46->display_action_progress] - // [904] phi display_action_progress::info_text#27 = main_vera_flash::info_text10 [phi:main_vera_flash::@46->display_action_progress#0] -- pbuz1=pbuc1 + // [941] call display_action_progress + // [559] phi from main_vera_flash::@46 to display_action_progress [phi:main_vera_flash::@46->display_action_progress] + // [559] phi display_action_progress::info_text#19 = main_vera_flash::info_text10 [phi:main_vera_flash::@46->display_action_progress#0] -- pbuz1=pbuc1 lda #info_text10 sta.z display_action_progress.info_text+1 jsr display_action_progress - // [1454] phi from main_vera_flash::@46 to main_vera_flash::@47 [phi:main_vera_flash::@46->main_vera_flash::@47] + // [942] phi from main_vera_flash::@46 to main_vera_flash::@47 [phi:main_vera_flash::@46->main_vera_flash::@47] // main_vera_flash::@47 // display_action_text("DO NOT RESET or REBOOT YOUR CX16 AND WAIT!") - // [1455] call display_action_text - // [1357] phi from main_vera_flash::@47 to display_action_text [phi:main_vera_flash::@47->display_action_text] - // [1357] phi display_action_text::info_text#25 = main_vera_flash::info_text8 [phi:main_vera_flash::@47->display_action_text#0] -- pbuz1=pbuc1 + // [943] call display_action_text + // [845] phi from main_vera_flash::@47 to display_action_text [phi:main_vera_flash::@47->display_action_text] + // [845] phi display_action_text::info_text#17 = main_vera_flash::info_text8 [phi:main_vera_flash::@47->display_action_text#0] -- pbuz1=pbuc1 lda #info_text8 sta.z display_action_text.info_text+1 jsr display_action_text // main_vera_flash::@48 - // [1456] spi_manufacturer#594 = spi_read::return#0 -- vbum1=vbum2 + // [944] spi_manufacturer#420 = spi_read::return#0 -- vbum1=vbum2 lda spi_read.return sta spi_manufacturer - // [1457] spi_memory_type#595 = spi_read::return#1 -- vbum1=vbum2 + // [945] spi_memory_type#421 = spi_read::return#1 -- vbum1=vbum2 lda spi_read.return_1 sta spi_memory_type - // [1458] spi_memory_capacity#596 = spi_read::return#2 -- vbum1=vbum2 + // [946] spi_memory_capacity#422 = spi_read::return#2 -- vbum1=vbum2 lda spi_read.return_2 sta spi_memory_capacity // display_info_vera(STATUS_ERROR, "FLASH ERROR!") - // [1459] call display_info_vera - // [998] phi from main_vera_flash::@48 to display_info_vera [phi:main_vera_flash::@48->display_info_vera] - // [998] phi display_info_vera::info_text#19 = main_vera_flash::info_text12 [phi:main_vera_flash::@48->display_info_vera#0] -- pbuz1=pbuc1 + // [947] call display_info_vera + // [653] phi from main_vera_flash::@48 to display_info_vera [phi:main_vera_flash::@48->display_info_vera] + // [653] phi display_info_vera::info_text#19 = main_vera_flash::info_text12 [phi:main_vera_flash::@48->display_info_vera#0] -- pbuz1=pbuc1 lda #info_text12 sta.z display_info_vera.info_text+1 - // [998] phi spi_memory_capacity#106 = spi_memory_capacity#596 [phi:main_vera_flash::@48->display_info_vera#1] -- register_copy - // [998] phi spi_memory_type#107 = spi_memory_type#595 [phi:main_vera_flash::@48->display_info_vera#2] -- register_copy - // [998] phi spi_manufacturer#108 = spi_manufacturer#594 [phi:main_vera_flash::@48->display_info_vera#3] -- register_copy - // [998] phi display_info_vera::info_status#19 = STATUS_ERROR [phi:main_vera_flash::@48->display_info_vera#4] -- vbum1=vbuc1 + // [653] phi spi_memory_capacity#110 = spi_memory_capacity#422 [phi:main_vera_flash::@48->display_info_vera#1] -- register_copy + // [653] phi spi_memory_type#111 = spi_memory_type#421 [phi:main_vera_flash::@48->display_info_vera#2] -- register_copy + // [653] phi spi_manufacturer#100 = spi_manufacturer#420 [phi:main_vera_flash::@48->display_info_vera#3] -- register_copy + // [653] phi display_info_vera::info_status#19 = STATUS_ERROR [phi:main_vera_flash::@48->display_info_vera#4] -- vbum1=vbuc1 lda #STATUS_ERROR sta display_info_vera.info_status jsr display_info_vera + // [948] phi from main_vera_flash::@48 to main_vera_flash::@49 [phi:main_vera_flash::@48->main_vera_flash::@49] // main_vera_flash::@49 - // [1460] smc_bootloader#517 = smc_bootloader#0 -- vwum1=vwum2 - lda smc_bootloader - sta smc_bootloader_1 - lda smc_bootloader+1 - sta smc_bootloader_1+1 // display_info_smc(STATUS_ERROR, NULL) - // [1461] call display_info_smc - // [962] phi from main_vera_flash::@49 to display_info_smc [phi:main_vera_flash::@49->display_info_smc] - // [962] phi display_info_smc::info_text#20 = 0 [phi:main_vera_flash::@49->display_info_smc#0] -- pbuz1=vbuc1 + // [949] call display_info_smc + // [617] phi from main_vera_flash::@49 to display_info_smc [phi:main_vera_flash::@49->display_info_smc] + // [617] phi display_info_smc::info_text#10 = 0 [phi:main_vera_flash::@49->display_info_smc#0] -- pbuz1=vbuc1 lda #<0 sta.z display_info_smc.info_text sta.z display_info_smc.info_text+1 - // [962] phi smc_bootloader#14 = smc_bootloader#517 [phi:main_vera_flash::@49->display_info_smc#1] -- register_copy - // [962] phi display_info_smc::info_status#20 = STATUS_ERROR [phi:main_vera_flash::@49->display_info_smc#2] -- vbum1=vbuc1 + // [617] phi display_info_smc::info_status#10 = STATUS_ERROR [phi:main_vera_flash::@49->display_info_smc#1] -- vbum1=vbuc1 lda #STATUS_ERROR sta display_info_smc.info_status jsr display_info_smc - // [1462] phi from main_vera_flash::@49 to main_vera_flash::@50 [phi:main_vera_flash::@49->main_vera_flash::@50] + // [950] phi from main_vera_flash::@49 to main_vera_flash::@50 [phi:main_vera_flash::@49->main_vera_flash::@50] // main_vera_flash::@50 // display_info_roms(STATUS_ERROR, NULL) - // [1463] call display_info_roms - // [2856] phi from main_vera_flash::@50 to display_info_roms [phi:main_vera_flash::@50->display_info_roms] + // [951] call display_info_roms + // [1699] phi from main_vera_flash::@50 to display_info_roms [phi:main_vera_flash::@50->display_info_roms] jsr display_info_roms - // [1464] phi from main_vera_flash::@50 to main_vera_flash::@51 [phi:main_vera_flash::@50->main_vera_flash::@51] + // [952] phi from main_vera_flash::@50 to main_vera_flash::@51 [phi:main_vera_flash::@50->main_vera_flash::@51] // main_vera_flash::@51 // wait_moment(32) - // [1465] call wait_moment - // [1310] phi from main_vera_flash::@51 to wait_moment [phi:main_vera_flash::@51->wait_moment] - // [1310] phi wait_moment::w#13 = $20 [phi:main_vera_flash::@51->wait_moment#0] -- vbum1=vbuc1 + // [953] call wait_moment + // [794] phi from main_vera_flash::@51 to wait_moment [phi:main_vera_flash::@51->wait_moment] + // [794] phi wait_moment::w#10 = $20 [phi:main_vera_flash::@51->wait_moment#0] -- vbum1=vbuc1 lda #$20 sta wait_moment.w jsr wait_moment - // [1466] phi from main_vera_flash::@51 to main_vera_flash::@52 [phi:main_vera_flash::@51->main_vera_flash::@52] + // [954] phi from main_vera_flash::@51 to main_vera_flash::@52 [phi:main_vera_flash::@51->main_vera_flash::@52] // main_vera_flash::@52 // spi_deselect() - // [1467] call spi_deselect + // [955] call spi_deselect jsr spi_deselect // main_vera_flash::@return // } - // [1468] return + // [956] return rts - // [1469] phi from main_vera_flash::@37 to main_vera_flash::@11 [phi:main_vera_flash::@37->main_vera_flash::@11] + // [957] phi from main_vera_flash::@37 to main_vera_flash::@11 [phi:main_vera_flash::@37->main_vera_flash::@11] // main_vera_flash::@11 __b11: // sprintf(info_text, "%x bytes flashed!", vera_flashed) - // [1470] call snprintf_init - // [1205] phi from main_vera_flash::@11 to snprintf_init [phi:main_vera_flash::@11->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:main_vera_flash::@11->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 + // [958] call snprintf_init jsr snprintf_init // main_vera_flash::@38 - // sprintf(info_text, "%x bytes flashed!", vera_flashed) - // [1471] printf_ulong::uvalue#11 = main_vera_flash::vera_flashed#0 -- vdum1=vdum2 - lda vera_flashed + // [959] printf_ulong::uvalue#8 = main_vera_flash::vera_flashed#0 -- vdum1=vduz2 + lda.z vera_flashed sta printf_ulong.uvalue - lda vera_flashed+1 + lda.z vera_flashed+1 sta printf_ulong.uvalue+1 - lda vera_flashed+2 + lda.z vera_flashed+2 sta printf_ulong.uvalue+2 - lda vera_flashed+3 + lda.z vera_flashed+3 sta printf_ulong.uvalue+3 - // [1472] call printf_ulong - // [1741] phi from main_vera_flash::@38 to printf_ulong [phi:main_vera_flash::@38->printf_ulong] - // [1741] phi printf_ulong::format_zero_padding#15 = 0 [phi:main_vera_flash::@38->printf_ulong#0] -- vbum1=vbuc1 + // [960] call printf_ulong + // [1633] phi from main_vera_flash::@38 to printf_ulong [phi:main_vera_flash::@38->printf_ulong] + // [1633] phi printf_ulong::format_zero_padding#10 = 0 [phi:main_vera_flash::@38->printf_ulong#0] -- vbum1=vbuc1 lda #0 sta printf_ulong.format_zero_padding - // [1741] phi printf_ulong::format_min_length#15 = 0 [phi:main_vera_flash::@38->printf_ulong#1] -- vbum1=vbuc1 + // [1633] phi printf_ulong::format_min_length#10 = 0 [phi:main_vera_flash::@38->printf_ulong#1] -- vbum1=vbuc1 sta printf_ulong.format_min_length - // [1741] phi printf_ulong::format_radix#15 = HEXADECIMAL [phi:main_vera_flash::@38->printf_ulong#2] -- vbum1=vbuc1 + // [1633] phi printf_ulong::format_radix#10 = HEXADECIMAL [phi:main_vera_flash::@38->printf_ulong#2] -- vbum1=vbuc1 lda #HEXADECIMAL sta printf_ulong.format_radix - // [1741] phi printf_ulong::uvalue#15 = printf_ulong::uvalue#11 [phi:main_vera_flash::@38->printf_ulong#3] -- register_copy + // [1633] phi printf_ulong::uvalue#10 = printf_ulong::uvalue#8 [phi:main_vera_flash::@38->printf_ulong#3] -- register_copy jsr printf_ulong - // [1473] phi from main_vera_flash::@38 to main_vera_flash::@39 [phi:main_vera_flash::@38->main_vera_flash::@39] + // [961] phi from main_vera_flash::@38 to main_vera_flash::@39 [phi:main_vera_flash::@38->main_vera_flash::@39] // main_vera_flash::@39 // sprintf(info_text, "%x bytes flashed!", vera_flashed) - // [1474] call printf_str - // [1210] phi from main_vera_flash::@39 to printf_str [phi:main_vera_flash::@39->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main_vera_flash::@39->printf_str#0] -- pprz1=pprc1 + // [962] call printf_str + // [785] phi from main_vera_flash::@39 to printf_str [phi:main_vera_flash::@39->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:main_vera_flash::@39->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = main_vera_flash::s2 [phi:main_vera_flash::@39->printf_str#1] -- pbuz1=pbuc1 + // [785] phi printf_str::s#53 = main_vera_flash::s2 [phi:main_vera_flash::@39->printf_str#1] -- pbuz1=pbuc1 lda #s2 @@ -9808,47 +6092,47 @@ main_vera_flash: { jsr printf_str // main_vera_flash::@40 // sprintf(info_text, "%x bytes flashed!", vera_flashed) - // [1475] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 + // [963] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 lda #0 pha - // [1476] callexecute snputc -- call_vprc1 + // [964] callexecute snputc -- call_vprc1 jsr snputc // sideeffect stackpullpadding(1) -- _stackpullpadding_1 pla - // [1478] spi_manufacturer#591 = spi_read::return#0 -- vbum1=vbum2 + // [966] spi_manufacturer#417 = spi_read::return#0 -- vbum1=vbum2 lda spi_read.return sta spi_manufacturer - // [1479] spi_memory_type#592 = spi_read::return#1 -- vbum1=vbum2 + // [967] spi_memory_type#418 = spi_read::return#1 -- vbum1=vbum2 lda spi_read.return_1 sta spi_memory_type - // [1480] spi_memory_capacity#593 = spi_read::return#2 -- vbum1=vbum2 + // [968] spi_memory_capacity#419 = spi_read::return#2 -- vbum1=vbum2 lda spi_read.return_2 sta spi_memory_capacity // display_info_vera(STATUS_FLASHED, info_text) - // [1481] call display_info_vera - // [998] phi from main_vera_flash::@40 to display_info_vera [phi:main_vera_flash::@40->display_info_vera] - // [998] phi display_info_vera::info_text#19 = info_text [phi:main_vera_flash::@40->display_info_vera#0] -- pbuz1=pbuc1 + // [969] call display_info_vera + // [653] phi from main_vera_flash::@40 to display_info_vera [phi:main_vera_flash::@40->display_info_vera] + // [653] phi display_info_vera::info_text#19 = info_text [phi:main_vera_flash::@40->display_info_vera#0] -- pbuz1=pbuc1 lda #<@info_text sta.z display_info_vera.info_text lda #>@info_text sta.z display_info_vera.info_text+1 - // [998] phi spi_memory_capacity#106 = spi_memory_capacity#593 [phi:main_vera_flash::@40->display_info_vera#1] -- register_copy - // [998] phi spi_memory_type#107 = spi_memory_type#592 [phi:main_vera_flash::@40->display_info_vera#2] -- register_copy - // [998] phi spi_manufacturer#108 = spi_manufacturer#591 [phi:main_vera_flash::@40->display_info_vera#3] -- register_copy - // [998] phi display_info_vera::info_status#19 = STATUS_FLASHED [phi:main_vera_flash::@40->display_info_vera#4] -- vbum1=vbuc1 + // [653] phi spi_memory_capacity#110 = spi_memory_capacity#419 [phi:main_vera_flash::@40->display_info_vera#1] -- register_copy + // [653] phi spi_memory_type#111 = spi_memory_type#418 [phi:main_vera_flash::@40->display_info_vera#2] -- register_copy + // [653] phi spi_manufacturer#100 = spi_manufacturer#417 [phi:main_vera_flash::@40->display_info_vera#3] -- register_copy + // [653] phi display_info_vera::info_status#19 = STATUS_FLASHED [phi:main_vera_flash::@40->display_info_vera#4] -- vbum1=vbuc1 lda #STATUS_FLASHED sta display_info_vera.info_status jsr display_info_vera - // [1482] phi from main_vera_flash::@40 to main_vera_flash::@41 [phi:main_vera_flash::@40->main_vera_flash::@41] + // [970] phi from main_vera_flash::@40 to main_vera_flash::@41 [phi:main_vera_flash::@40->main_vera_flash::@41] // main_vera_flash::@41 // unsigned long vera_differences = vera_verify() - // [1483] call vera_verify - // [2737] phi from main_vera_flash::@41 to vera_verify [phi:main_vera_flash::@41->vera_verify] + // [971] call vera_verify + // [1570] phi from main_vera_flash::@41 to vera_verify [phi:main_vera_flash::@41->vera_verify] jsr vera_verify // unsigned long vera_differences = vera_verify() - // [1484] vera_verify::return#3 = vera_verify::vera_different_bytes#11 + // [972] vera_verify::return#3 = vera_verify::vera_different_bytes#11 // main_vera_flash::@42 - // [1485] main_vera_flash::vera_differences1#0 = vera_verify::return#3 -- vduz1=vdum2 + // [973] main_vera_flash::vera_differences1#0 = vera_verify::return#3 -- vduz1=vdum2 lda vera_verify.return sta.z vera_differences1 lda vera_verify.return+1 @@ -9858,17 +6142,10 @@ main_vera_flash: { lda vera_verify.return+3 sta.z vera_differences1+3 // sprintf(info_text, "%05x differences!", vera_differences) - // [1486] call snprintf_init - // [1205] phi from main_vera_flash::@42 to snprintf_init [phi:main_vera_flash::@42->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:main_vera_flash::@42->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 + // [974] call snprintf_init jsr snprintf_init // main_vera_flash::@43 - // sprintf(info_text, "%05x differences!", vera_differences) - // [1487] printf_ulong::uvalue#12 = main_vera_flash::vera_differences1#0 -- vdum1=vduz2 + // [975] printf_ulong::uvalue#9 = main_vera_flash::vera_differences1#0 -- vdum1=vduz2 lda.z vera_differences1 sta printf_ulong.uvalue lda.z vera_differences1+1 @@ -9877,337 +6154,337 @@ main_vera_flash: { sta printf_ulong.uvalue+2 lda.z vera_differences1+3 sta printf_ulong.uvalue+3 - // [1488] call printf_ulong - // [1741] phi from main_vera_flash::@43 to printf_ulong [phi:main_vera_flash::@43->printf_ulong] - // [1741] phi printf_ulong::format_zero_padding#15 = 1 [phi:main_vera_flash::@43->printf_ulong#0] -- vbum1=vbuc1 + // [976] call printf_ulong + // [1633] phi from main_vera_flash::@43 to printf_ulong [phi:main_vera_flash::@43->printf_ulong] + // [1633] phi printf_ulong::format_zero_padding#10 = 1 [phi:main_vera_flash::@43->printf_ulong#0] -- vbum1=vbuc1 lda #1 sta printf_ulong.format_zero_padding - // [1741] phi printf_ulong::format_min_length#15 = 5 [phi:main_vera_flash::@43->printf_ulong#1] -- vbum1=vbuc1 + // [1633] phi printf_ulong::format_min_length#10 = 5 [phi:main_vera_flash::@43->printf_ulong#1] -- vbum1=vbuc1 lda #5 sta printf_ulong.format_min_length - // [1741] phi printf_ulong::format_radix#15 = HEXADECIMAL [phi:main_vera_flash::@43->printf_ulong#2] -- vbum1=vbuc1 + // [1633] phi printf_ulong::format_radix#10 = HEXADECIMAL [phi:main_vera_flash::@43->printf_ulong#2] -- vbum1=vbuc1 lda #HEXADECIMAL sta printf_ulong.format_radix - // [1741] phi printf_ulong::uvalue#15 = printf_ulong::uvalue#12 [phi:main_vera_flash::@43->printf_ulong#3] -- register_copy + // [1633] phi printf_ulong::uvalue#10 = printf_ulong::uvalue#9 [phi:main_vera_flash::@43->printf_ulong#3] -- register_copy jsr printf_ulong - // [1489] phi from main_vera_flash::@43 to main_vera_flash::@44 [phi:main_vera_flash::@43->main_vera_flash::@44] + // [977] phi from main_vera_flash::@43 to main_vera_flash::@44 [phi:main_vera_flash::@43->main_vera_flash::@44] // main_vera_flash::@44 // sprintf(info_text, "%05x differences!", vera_differences) - // [1490] call printf_str - // [1210] phi from main_vera_flash::@44 to printf_str [phi:main_vera_flash::@44->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:main_vera_flash::@44->printf_str#0] -- pprz1=pprc1 + // [978] call printf_str + // [785] phi from main_vera_flash::@44 to printf_str [phi:main_vera_flash::@44->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:main_vera_flash::@44->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s13 [phi:main_vera_flash::@44->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #s13 + lda #>s1 sta.z printf_str.s+1 jsr printf_str // main_vera_flash::@45 // sprintf(info_text, "%05x differences!", vera_differences) - // [1491] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 + // [979] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 lda #0 pha - // [1492] callexecute snputc -- call_vprc1 + // [980] callexecute snputc -- call_vprc1 jsr snputc // sideeffect stackpullpadding(1) -- _stackpullpadding_1 pla - // [1494] spi_manufacturer#592 = spi_read::return#0 -- vbum1=vbum2 + // [982] spi_manufacturer#418 = spi_read::return#0 -- vbum1=vbum2 lda spi_read.return sta spi_manufacturer - // [1495] spi_memory_type#593 = spi_read::return#1 -- vbum1=vbum2 + // [983] spi_memory_type#419 = spi_read::return#1 -- vbum1=vbum2 lda spi_read.return_1 sta spi_memory_type - // [1496] spi_memory_capacity#594 = spi_read::return#2 -- vbum1=vbum2 + // [984] spi_memory_capacity#420 = spi_read::return#2 -- vbum1=vbum2 lda spi_read.return_2 sta spi_memory_capacity // display_info_vera(STATUS_FLASHED, info_text) - // [1497] call display_info_vera - // [998] phi from main_vera_flash::@45 to display_info_vera [phi:main_vera_flash::@45->display_info_vera] - // [998] phi display_info_vera::info_text#19 = info_text [phi:main_vera_flash::@45->display_info_vera#0] -- pbuz1=pbuc1 + // [985] call display_info_vera + // [653] phi from main_vera_flash::@45 to display_info_vera [phi:main_vera_flash::@45->display_info_vera] + // [653] phi display_info_vera::info_text#19 = info_text [phi:main_vera_flash::@45->display_info_vera#0] -- pbuz1=pbuc1 lda #<@info_text sta.z display_info_vera.info_text lda #>@info_text sta.z display_info_vera.info_text+1 - // [998] phi spi_memory_capacity#106 = spi_memory_capacity#594 [phi:main_vera_flash::@45->display_info_vera#1] -- register_copy - // [998] phi spi_memory_type#107 = spi_memory_type#593 [phi:main_vera_flash::@45->display_info_vera#2] -- register_copy - // [998] phi spi_manufacturer#108 = spi_manufacturer#592 [phi:main_vera_flash::@45->display_info_vera#3] -- register_copy - // [998] phi display_info_vera::info_status#19 = STATUS_FLASHED [phi:main_vera_flash::@45->display_info_vera#4] -- vbum1=vbuc1 + // [653] phi spi_memory_capacity#110 = spi_memory_capacity#420 [phi:main_vera_flash::@45->display_info_vera#1] -- register_copy + // [653] phi spi_memory_type#111 = spi_memory_type#419 [phi:main_vera_flash::@45->display_info_vera#2] -- register_copy + // [653] phi spi_manufacturer#100 = spi_manufacturer#418 [phi:main_vera_flash::@45->display_info_vera#3] -- register_copy + // [653] phi display_info_vera::info_status#19 = STATUS_FLASHED [phi:main_vera_flash::@45->display_info_vera#4] -- vbum1=vbuc1 lda #STATUS_FLASHED sta display_info_vera.info_status jsr display_info_vera - // [1498] phi from main_vera_flash::@45 main_vera_flash::@9 to main_vera_flash::@13 [phi:main_vera_flash::@45/main_vera_flash::@9->main_vera_flash::@13] + // [986] phi from main_vera_flash::@45 main_vera_flash::@9 to main_vera_flash::@13 [phi:main_vera_flash::@45/main_vera_flash::@9->main_vera_flash::@13] // main_vera_flash::@13 __b13: // display_action_progress("VERA SPI de-activation ...") - // [1499] call display_action_progress + // [987] call display_action_progress // Now we loop until jumper JP1 is open again! - // [904] phi from main_vera_flash::@13 to display_action_progress [phi:main_vera_flash::@13->display_action_progress] - // [904] phi display_action_progress::info_text#27 = main_vera_flash::info_text13 [phi:main_vera_flash::@13->display_action_progress#0] -- pbuz1=pbuc1 + // [559] phi from main_vera_flash::@13 to display_action_progress [phi:main_vera_flash::@13->display_action_progress] + // [559] phi display_action_progress::info_text#19 = main_vera_flash::info_text13 [phi:main_vera_flash::@13->display_action_progress#0] -- pbuz1=pbuc1 lda #info_text13 sta.z display_action_progress.info_text+1 jsr display_action_progress - // [1500] phi from main_vera_flash::@13 to main_vera_flash::@53 [phi:main_vera_flash::@13->main_vera_flash::@53] + // [988] phi from main_vera_flash::@13 to main_vera_flash::@53 [phi:main_vera_flash::@13->main_vera_flash::@53] // main_vera_flash::@53 // display_action_text("Please OPEN the jumper JP1 on the VERA board!") - // [1501] call display_action_text - // [1357] phi from main_vera_flash::@53 to display_action_text [phi:main_vera_flash::@53->display_action_text] - // [1357] phi display_action_text::info_text#25 = main_vera_flash::info_text14 [phi:main_vera_flash::@53->display_action_text#0] -- pbuz1=pbuc1 + // [989] call display_action_text + // [845] phi from main_vera_flash::@53 to display_action_text [phi:main_vera_flash::@53->display_action_text] + // [845] phi display_action_text::info_text#17 = main_vera_flash::info_text14 [phi:main_vera_flash::@53->display_action_text#0] -- pbuz1=pbuc1 lda #info_text14 sta.z display_action_text.info_text+1 jsr display_action_text - // [1502] phi from main_vera_flash::@53 to main_vera_flash::@54 [phi:main_vera_flash::@53->main_vera_flash::@54] + // [990] phi from main_vera_flash::@53 to main_vera_flash::@54 [phi:main_vera_flash::@53->main_vera_flash::@54] // main_vera_flash::@54 // vera_detect() - // [1503] call vera_detect - // [2391] phi from main_vera_flash::@54 to vera_detect [phi:main_vera_flash::@54->vera_detect] + // [991] call vera_detect + // [1455] phi from main_vera_flash::@54 to vera_detect [phi:main_vera_flash::@54->vera_detect] jsr vera_detect - // [1504] phi from main_vera_flash::@18 main_vera_flash::@54 to main_vera_flash::@14 [phi:main_vera_flash::@18/main_vera_flash::@54->main_vera_flash::@14] + // [992] phi from main_vera_flash::@18 main_vera_flash::@54 to main_vera_flash::@14 [phi:main_vera_flash::@18/main_vera_flash::@54->main_vera_flash::@14] __b5: - // [1504] phi main_vera_flash::spi_ensure_detect#12 = 0 [phi:main_vera_flash::@18/main_vera_flash::@54->main_vera_flash::@14#0] -- vbuz1=vbuc1 + // [992] phi main_vera_flash::spi_ensure_detect#12 = 0 [phi:main_vera_flash::@18/main_vera_flash::@54->main_vera_flash::@14#0] -- vbuz1=vbuc1 lda #0 sta.z spi_ensure_detect_1 // main_vera_flash::@14 __b14: // while(spi_ensure_detect < 16) - // [1505] if(main_vera_flash::spi_ensure_detect#12<$10) goto main_vera_flash::@15 -- vbuz1_lt_vbuc1_then_la1 + // [993] if(main_vera_flash::spi_ensure_detect#12<$10) goto main_vera_flash::@15 -- vbuz1_lt_vbuc1_then_la1 lda.z spi_ensure_detect_1 cmp #$10 bcc __b15 - // [1506] phi from main_vera_flash::@14 to main_vera_flash::@16 [phi:main_vera_flash::@14->main_vera_flash::@16] + // [994] phi from main_vera_flash::@14 to main_vera_flash::@16 [phi:main_vera_flash::@14->main_vera_flash::@16] // main_vera_flash::@16 // display_action_text("The jumper JP1 has been opened on the VERA!") - // [1507] call display_action_text - // [1357] phi from main_vera_flash::@16 to display_action_text [phi:main_vera_flash::@16->display_action_text] - // [1357] phi display_action_text::info_text#25 = main_vera_flash::info_text15 [phi:main_vera_flash::@16->display_action_text#0] -- pbuz1=pbuc1 + // [995] call display_action_text + // [845] phi from main_vera_flash::@16 to display_action_text [phi:main_vera_flash::@16->display_action_text] + // [845] phi display_action_text::info_text#17 = main_vera_flash::info_text15 [phi:main_vera_flash::@16->display_action_text#0] -- pbuz1=pbuc1 lda #info_text15 sta.z display_action_text.info_text+1 jsr display_action_text - // [1508] phi from main_vera_flash::@16 main_vera_flash::@23 to main_vera_flash::@1 [phi:main_vera_flash::@16/main_vera_flash::@23->main_vera_flash::@1] + // [996] phi from main_vera_flash::@16 main_vera_flash::@23 to main_vera_flash::@1 [phi:main_vera_flash::@16/main_vera_flash::@23->main_vera_flash::@1] // main_vera_flash::@1 __b1: // spi_deselect() - // [1509] call spi_deselect + // [997] call spi_deselect jsr spi_deselect rts - // [1510] phi from main_vera_flash::@14 to main_vera_flash::@15 [phi:main_vera_flash::@14->main_vera_flash::@15] + // [998] phi from main_vera_flash::@14 to main_vera_flash::@15 [phi:main_vera_flash::@14->main_vera_flash::@15] // main_vera_flash::@15 __b15: // vera_detect() - // [1511] call vera_detect - // [2391] phi from main_vera_flash::@15 to vera_detect [phi:main_vera_flash::@15->vera_detect] + // [999] call vera_detect + // [1455] phi from main_vera_flash::@15 to vera_detect [phi:main_vera_flash::@15->vera_detect] jsr vera_detect - // [1512] phi from main_vera_flash::@15 to main_vera_flash::@55 [phi:main_vera_flash::@15->main_vera_flash::@55] + // [1000] phi from main_vera_flash::@15 to main_vera_flash::@55 [phi:main_vera_flash::@15->main_vera_flash::@55] // main_vera_flash::@55 // wait_moment(1) - // [1513] call wait_moment - // [1310] phi from main_vera_flash::@55 to wait_moment [phi:main_vera_flash::@55->wait_moment] - // [1310] phi wait_moment::w#13 = 1 [phi:main_vera_flash::@55->wait_moment#0] -- vbum1=vbuc1 + // [1001] call wait_moment + // [794] phi from main_vera_flash::@55 to wait_moment [phi:main_vera_flash::@55->wait_moment] + // [794] phi wait_moment::w#10 = 1 [phi:main_vera_flash::@55->wait_moment#0] -- vbum1=vbuc1 lda #1 sta wait_moment.w jsr wait_moment // main_vera_flash::@56 // if(spi_manufacturer != 0xEF && spi_memory_type != 0x40 && spi_memory_capacity != 0x15) - // [1514] if(spi_read::return#0==$ef) goto main_vera_flash::@18 -- vbum1_eq_vbuc1_then_la1 + // [1002] if(spi_read::return#0==$ef) goto main_vera_flash::@18 -- vbum1_eq_vbuc1_then_la1 lda #$ef cmp spi_read.return beq __b18 // main_vera_flash::@61 - // [1515] if(spi_read::return#1==$40) goto main_vera_flash::@18 -- vbum1_eq_vbuc1_then_la1 + // [1003] if(spi_read::return#1==$40) goto main_vera_flash::@18 -- vbum1_eq_vbuc1_then_la1 lda #$40 cmp spi_read.return_1 beq __b18 // main_vera_flash::@60 - // [1516] if(spi_read::return#2!=$15) goto main_vera_flash::@17 -- vbum1_neq_vbuc1_then_la1 + // [1004] if(spi_read::return#2!=$15) goto main_vera_flash::@17 -- vbum1_neq_vbuc1_then_la1 lda #$15 cmp spi_read.return_2 bne __b17 // main_vera_flash::@18 __b18: - // [1517] spi_manufacturer#588 = spi_read::return#0 -- vbum1=vbum2 + // [1005] spi_manufacturer#414 = spi_read::return#0 -- vbum1=vbum2 lda spi_read.return sta spi_manufacturer - // [1518] spi_memory_type#589 = spi_read::return#1 -- vbum1=vbum2 + // [1006] spi_memory_type#415 = spi_read::return#1 -- vbum1=vbum2 lda spi_read.return_1 sta spi_memory_type - // [1519] spi_memory_capacity#590 = spi_read::return#2 -- vbum1=vbum2 + // [1007] spi_memory_capacity#416 = spi_read::return#2 -- vbum1=vbum2 lda spi_read.return_2 sta spi_memory_capacity // display_info_vera(STATUS_WAITING, NULL) - // [1520] call display_info_vera - // [998] phi from main_vera_flash::@18 to display_info_vera [phi:main_vera_flash::@18->display_info_vera] - // [998] phi display_info_vera::info_text#19 = 0 [phi:main_vera_flash::@18->display_info_vera#0] -- pbuz1=vbuc1 + // [1008] call display_info_vera + // [653] phi from main_vera_flash::@18 to display_info_vera [phi:main_vera_flash::@18->display_info_vera] + // [653] phi display_info_vera::info_text#19 = 0 [phi:main_vera_flash::@18->display_info_vera#0] -- pbuz1=vbuc1 lda #<0 sta.z display_info_vera.info_text sta.z display_info_vera.info_text+1 - // [998] phi spi_memory_capacity#106 = spi_memory_capacity#590 [phi:main_vera_flash::@18->display_info_vera#1] -- register_copy - // [998] phi spi_memory_type#107 = spi_memory_type#589 [phi:main_vera_flash::@18->display_info_vera#2] -- register_copy - // [998] phi spi_manufacturer#108 = spi_manufacturer#588 [phi:main_vera_flash::@18->display_info_vera#3] -- register_copy - // [998] phi display_info_vera::info_status#19 = STATUS_WAITING [phi:main_vera_flash::@18->display_info_vera#4] -- vbum1=vbuc1 + // [653] phi spi_memory_capacity#110 = spi_memory_capacity#416 [phi:main_vera_flash::@18->display_info_vera#1] -- register_copy + // [653] phi spi_memory_type#111 = spi_memory_type#415 [phi:main_vera_flash::@18->display_info_vera#2] -- register_copy + // [653] phi spi_manufacturer#100 = spi_manufacturer#414 [phi:main_vera_flash::@18->display_info_vera#3] -- register_copy + // [653] phi display_info_vera::info_status#19 = STATUS_WAITING [phi:main_vera_flash::@18->display_info_vera#4] -- vbum1=vbuc1 lda #STATUS_WAITING sta display_info_vera.info_status jsr display_info_vera jmp __b5 // main_vera_flash::@17 __b17: - // [1521] spi_manufacturer#587 = spi_read::return#0 -- vbum1=vbum2 + // [1009] spi_manufacturer#413 = spi_read::return#0 -- vbum1=vbum2 lda spi_read.return sta spi_manufacturer - // [1522] spi_memory_type#588 = spi_read::return#1 -- vbum1=vbum2 + // [1010] spi_memory_type#414 = spi_read::return#1 -- vbum1=vbum2 lda spi_read.return_1 sta spi_memory_type - // [1523] spi_memory_capacity#589 = spi_read::return#2 -- vbum1=vbum2 + // [1011] spi_memory_capacity#415 = spi_read::return#2 -- vbum1=vbum2 lda spi_read.return_2 sta spi_memory_capacity // display_info_vera(STATUS_DETECTED, NULL) - // [1524] call display_info_vera - // [998] phi from main_vera_flash::@17 to display_info_vera [phi:main_vera_flash::@17->display_info_vera] - // [998] phi display_info_vera::info_text#19 = 0 [phi:main_vera_flash::@17->display_info_vera#0] -- pbuz1=vbuc1 + // [1012] call display_info_vera + // [653] phi from main_vera_flash::@17 to display_info_vera [phi:main_vera_flash::@17->display_info_vera] + // [653] phi display_info_vera::info_text#19 = 0 [phi:main_vera_flash::@17->display_info_vera#0] -- pbuz1=vbuc1 lda #<0 sta.z display_info_vera.info_text sta.z display_info_vera.info_text+1 - // [998] phi spi_memory_capacity#106 = spi_memory_capacity#589 [phi:main_vera_flash::@17->display_info_vera#1] -- register_copy - // [998] phi spi_memory_type#107 = spi_memory_type#588 [phi:main_vera_flash::@17->display_info_vera#2] -- register_copy - // [998] phi spi_manufacturer#108 = spi_manufacturer#587 [phi:main_vera_flash::@17->display_info_vera#3] -- register_copy - // [998] phi display_info_vera::info_status#19 = STATUS_DETECTED [phi:main_vera_flash::@17->display_info_vera#4] -- vbum1=vbuc1 + // [653] phi spi_memory_capacity#110 = spi_memory_capacity#415 [phi:main_vera_flash::@17->display_info_vera#1] -- register_copy + // [653] phi spi_memory_type#111 = spi_memory_type#414 [phi:main_vera_flash::@17->display_info_vera#2] -- register_copy + // [653] phi spi_manufacturer#100 = spi_manufacturer#413 [phi:main_vera_flash::@17->display_info_vera#3] -- register_copy + // [653] phi display_info_vera::info_status#19 = STATUS_DETECTED [phi:main_vera_flash::@17->display_info_vera#4] -- vbum1=vbuc1 lda #STATUS_DETECTED sta display_info_vera.info_status jsr display_info_vera // main_vera_flash::@57 // spi_ensure_detect++; - // [1525] main_vera_flash::spi_ensure_detect#4 = ++ main_vera_flash::spi_ensure_detect#12 -- vbuz1=_inc_vbuz1 + // [1013] main_vera_flash::spi_ensure_detect#4 = ++ main_vera_flash::spi_ensure_detect#12 -- vbuz1=_inc_vbuz1 inc.z spi_ensure_detect_1 - // [1504] phi from main_vera_flash::@57 to main_vera_flash::@14 [phi:main_vera_flash::@57->main_vera_flash::@14] - // [1504] phi main_vera_flash::spi_ensure_detect#12 = main_vera_flash::spi_ensure_detect#4 [phi:main_vera_flash::@57->main_vera_flash::@14#0] -- register_copy + // [992] phi from main_vera_flash::@57 to main_vera_flash::@14 [phi:main_vera_flash::@57->main_vera_flash::@14] + // [992] phi main_vera_flash::spi_ensure_detect#12 = main_vera_flash::spi_ensure_detect#4 [phi:main_vera_flash::@57->main_vera_flash::@14#0] -- register_copy jmp __b14 // main_vera_flash::@9 __b9: - // [1526] spi_manufacturer#585 = spi_read::return#0 -- vbum1=vbum2 + // [1014] spi_manufacturer#411 = spi_read::return#0 -- vbum1=vbum2 lda spi_read.return sta spi_manufacturer - // [1527] spi_memory_type#586 = spi_read::return#1 -- vbum1=vbum2 + // [1015] spi_memory_type#412 = spi_read::return#1 -- vbum1=vbum2 lda spi_read.return_1 sta spi_memory_type - // [1528] spi_memory_capacity#587 = spi_read::return#2 -- vbum1=vbum2 + // [1016] spi_memory_capacity#413 = spi_read::return#2 -- vbum1=vbum2 lda spi_read.return_2 sta spi_memory_capacity // display_info_vera(STATUS_SKIP, "No update required") - // [1529] call display_info_vera + // [1017] call display_info_vera // VFL1 | VERA and VERA.BIN equal | Display that there are no differences between the VERA and VERA.BIN. Set VERA to Flashed. | None - // [998] phi from main_vera_flash::@9 to display_info_vera [phi:main_vera_flash::@9->display_info_vera] - // [998] phi display_info_vera::info_text#19 = info_text6 [phi:main_vera_flash::@9->display_info_vera#0] -- pbuz1=pbuc1 + // [653] phi from main_vera_flash::@9 to display_info_vera [phi:main_vera_flash::@9->display_info_vera] + // [653] phi display_info_vera::info_text#19 = main_vera_flash::info_text6 [phi:main_vera_flash::@9->display_info_vera#0] -- pbuz1=pbuc1 lda #info_text6 sta.z display_info_vera.info_text+1 - // [998] phi spi_memory_capacity#106 = spi_memory_capacity#587 [phi:main_vera_flash::@9->display_info_vera#1] -- register_copy - // [998] phi spi_memory_type#107 = spi_memory_type#586 [phi:main_vera_flash::@9->display_info_vera#2] -- register_copy - // [998] phi spi_manufacturer#108 = spi_manufacturer#585 [phi:main_vera_flash::@9->display_info_vera#3] -- register_copy - // [998] phi display_info_vera::info_status#19 = STATUS_SKIP [phi:main_vera_flash::@9->display_info_vera#4] -- vbum1=vbuc1 + // [653] phi spi_memory_capacity#110 = spi_memory_capacity#413 [phi:main_vera_flash::@9->display_info_vera#1] -- register_copy + // [653] phi spi_memory_type#111 = spi_memory_type#412 [phi:main_vera_flash::@9->display_info_vera#2] -- register_copy + // [653] phi spi_manufacturer#100 = spi_manufacturer#411 [phi:main_vera_flash::@9->display_info_vera#3] -- register_copy + // [653] phi display_info_vera::info_status#19 = STATUS_SKIP [phi:main_vera_flash::@9->display_info_vera#4] -- vbum1=vbuc1 lda #STATUS_SKIP sta display_info_vera.info_status jsr display_info_vera jmp __b13 - // [1530] phi from main_vera_flash::@3 to main_vera_flash::@4 [phi:main_vera_flash::@3->main_vera_flash::@4] + // [1018] phi from main_vera_flash::@3 to main_vera_flash::@4 [phi:main_vera_flash::@3->main_vera_flash::@4] // main_vera_flash::@4 __b4: // vera_detect() - // [1531] call vera_detect - // [2391] phi from main_vera_flash::@4 to vera_detect [phi:main_vera_flash::@4->vera_detect] + // [1019] call vera_detect + // [1455] phi from main_vera_flash::@4 to vera_detect [phi:main_vera_flash::@4->vera_detect] jsr vera_detect - // [1532] phi from main_vera_flash::@4 to main_vera_flash::@26 [phi:main_vera_flash::@4->main_vera_flash::@26] + // [1020] phi from main_vera_flash::@4 to main_vera_flash::@26 [phi:main_vera_flash::@4->main_vera_flash::@26] // main_vera_flash::@26 // wait_moment(1) - // [1533] call wait_moment - // [1310] phi from main_vera_flash::@26 to wait_moment [phi:main_vera_flash::@26->wait_moment] - // [1310] phi wait_moment::w#13 = 1 [phi:main_vera_flash::@26->wait_moment#0] -- vbum1=vbuc1 + // [1021] call wait_moment + // [794] phi from main_vera_flash::@26 to wait_moment [phi:main_vera_flash::@26->wait_moment] + // [794] phi wait_moment::w#10 = 1 [phi:main_vera_flash::@26->wait_moment#0] -- vbum1=vbuc1 lda #1 sta wait_moment.w jsr wait_moment // main_vera_flash::@27 // if(spi_manufacturer == 0xEF && spi_memory_type == 0x40 && spi_memory_capacity == 0x15) - // [1534] if(spi_read::return#0!=$ef) goto main_vera_flash::@7 -- vbum1_neq_vbuc1_then_la1 + // [1022] if(spi_read::return#0!=$ef) goto main_vera_flash::@7 -- vbum1_neq_vbuc1_then_la1 lda #$ef cmp spi_read.return bne __b7 // main_vera_flash::@59 - // [1535] if(spi_read::return#1!=$40) goto main_vera_flash::@7 -- vbum1_neq_vbuc1_then_la1 + // [1023] if(spi_read::return#1!=$40) goto main_vera_flash::@7 -- vbum1_neq_vbuc1_then_la1 lda #$40 cmp spi_read.return_1 bne __b7 // main_vera_flash::@58 - // [1536] if(spi_read::return#2==$15) goto main_vera_flash::@6 -- vbum1_eq_vbuc1_then_la1 + // [1024] if(spi_read::return#2==$15) goto main_vera_flash::@6 -- vbum1_eq_vbuc1_then_la1 lda #$15 cmp spi_read.return_2 beq __b6 // main_vera_flash::@7 __b7: - // [1537] spi_manufacturer#595 = spi_read::return#0 -- vbum1=vbum2 + // [1025] spi_manufacturer#421 = spi_read::return#0 -- vbum1=vbum2 lda spi_read.return sta spi_manufacturer - // [1538] spi_memory_type#596 = spi_read::return#1 -- vbum1=vbum2 + // [1026] spi_memory_type#422 = spi_read::return#1 -- vbum1=vbum2 lda spi_read.return_1 sta spi_memory_type - // [1539] spi_memory_capacity#597 = spi_read::return#2 -- vbum1=vbum2 + // [1027] spi_memory_capacity#423 = spi_read::return#2 -- vbum1=vbum2 lda spi_read.return_2 sta spi_memory_capacity // display_info_vera(STATUS_WAITING, "Close JP1 jumper pins!") - // [1540] call display_info_vera - // [998] phi from main_vera_flash::@7 to display_info_vera [phi:main_vera_flash::@7->display_info_vera] - // [998] phi display_info_vera::info_text#19 = main_vera_flash::info_text5 [phi:main_vera_flash::@7->display_info_vera#0] -- pbuz1=pbuc1 + // [1028] call display_info_vera + // [653] phi from main_vera_flash::@7 to display_info_vera [phi:main_vera_flash::@7->display_info_vera] + // [653] phi display_info_vera::info_text#19 = main_vera_flash::info_text5 [phi:main_vera_flash::@7->display_info_vera#0] -- pbuz1=pbuc1 lda #info_text5 sta.z display_info_vera.info_text+1 - // [998] phi spi_memory_capacity#106 = spi_memory_capacity#597 [phi:main_vera_flash::@7->display_info_vera#1] -- register_copy - // [998] phi spi_memory_type#107 = spi_memory_type#596 [phi:main_vera_flash::@7->display_info_vera#2] -- register_copy - // [998] phi spi_manufacturer#108 = spi_manufacturer#595 [phi:main_vera_flash::@7->display_info_vera#3] -- register_copy - // [998] phi display_info_vera::info_status#19 = STATUS_WAITING [phi:main_vera_flash::@7->display_info_vera#4] -- vbum1=vbuc1 + // [653] phi spi_memory_capacity#110 = spi_memory_capacity#423 [phi:main_vera_flash::@7->display_info_vera#1] -- register_copy + // [653] phi spi_memory_type#111 = spi_memory_type#422 [phi:main_vera_flash::@7->display_info_vera#2] -- register_copy + // [653] phi spi_manufacturer#100 = spi_manufacturer#421 [phi:main_vera_flash::@7->display_info_vera#3] -- register_copy + // [653] phi display_info_vera::info_status#19 = STATUS_WAITING [phi:main_vera_flash::@7->display_info_vera#4] -- vbum1=vbuc1 lda #STATUS_WAITING sta display_info_vera.info_status jsr display_info_vera jmp __b2 // main_vera_flash::@6 __b6: - // [1541] spi_manufacturer#593 = spi_read::return#0 -- vbum1=vbum2 + // [1029] spi_manufacturer#419 = spi_read::return#0 -- vbum1=vbum2 lda spi_read.return sta spi_manufacturer - // [1542] spi_memory_type#594 = spi_read::return#1 -- vbum1=vbum2 + // [1030] spi_memory_type#420 = spi_read::return#1 -- vbum1=vbum2 lda spi_read.return_1 sta spi_memory_type - // [1543] spi_memory_capacity#595 = spi_read::return#2 -- vbum1=vbum2 + // [1031] spi_memory_capacity#421 = spi_read::return#2 -- vbum1=vbum2 lda spi_read.return_2 sta spi_memory_capacity // display_info_vera(STATUS_DETECTED, "JP1 jumper pins closed!") - // [1544] call display_info_vera - // [998] phi from main_vera_flash::@6 to display_info_vera [phi:main_vera_flash::@6->display_info_vera] - // [998] phi display_info_vera::info_text#19 = main_vera_flash::info_text4 [phi:main_vera_flash::@6->display_info_vera#0] -- pbuz1=pbuc1 + // [1032] call display_info_vera + // [653] phi from main_vera_flash::@6 to display_info_vera [phi:main_vera_flash::@6->display_info_vera] + // [653] phi display_info_vera::info_text#19 = main_vera_flash::info_text4 [phi:main_vera_flash::@6->display_info_vera#0] -- pbuz1=pbuc1 lda #info_text4 sta.z display_info_vera.info_text+1 - // [998] phi spi_memory_capacity#106 = spi_memory_capacity#595 [phi:main_vera_flash::@6->display_info_vera#1] -- register_copy - // [998] phi spi_memory_type#107 = spi_memory_type#594 [phi:main_vera_flash::@6->display_info_vera#2] -- register_copy - // [998] phi spi_manufacturer#108 = spi_manufacturer#593 [phi:main_vera_flash::@6->display_info_vera#3] -- register_copy - // [998] phi display_info_vera::info_status#19 = STATUS_DETECTED [phi:main_vera_flash::@6->display_info_vera#4] -- vbum1=vbuc1 + // [653] phi spi_memory_capacity#110 = spi_memory_capacity#421 [phi:main_vera_flash::@6->display_info_vera#1] -- register_copy + // [653] phi spi_memory_type#111 = spi_memory_type#420 [phi:main_vera_flash::@6->display_info_vera#2] -- register_copy + // [653] phi spi_manufacturer#100 = spi_manufacturer#419 [phi:main_vera_flash::@6->display_info_vera#3] -- register_copy + // [653] phi display_info_vera::info_status#19 = STATUS_DETECTED [phi:main_vera_flash::@6->display_info_vera#4] -- vbum1=vbuc1 lda #STATUS_DETECTED sta display_info_vera.info_status jsr display_info_vera // main_vera_flash::@32 // spi_ensure_detect++; - // [1545] main_vera_flash::spi_ensure_detect#1 = ++ main_vera_flash::spi_ensure_detect#11 -- vbuz1=_inc_vbuz1 + // [1033] main_vera_flash::spi_ensure_detect#1 = ++ main_vera_flash::spi_ensure_detect#11 -- vbuz1=_inc_vbuz1 inc.z spi_ensure_detect - // [1413] phi from main_vera_flash::@32 to main_vera_flash::@3 [phi:main_vera_flash::@32->main_vera_flash::@3] - // [1413] phi main_vera_flash::spi_ensure_detect#11 = main_vera_flash::spi_ensure_detect#1 [phi:main_vera_flash::@32->main_vera_flash::@3#0] -- register_copy + // [901] phi from main_vera_flash::@32 to main_vera_flash::@3 [phi:main_vera_flash::@32->main_vera_flash::@3] + // [901] phi main_vera_flash::spi_ensure_detect#11 = main_vera_flash::spi_ensure_detect#1 [phi:main_vera_flash::@32->main_vera_flash::@3#0] -- register_copy jmp __b3 .segment DataVera s: .text "Reading VERA.BIN ... (.) data ( ) empty" @@ -10224,6 +6501,10 @@ main_vera_flash: { .byte 0 info_text5: .text "Close JP1 jumper pins!" .byte 0 + info_text6: .text "No update required" + .byte 0 + s1: .text " differences!" + .byte 0 info_text8: .text "DO NOT RESET or REBOOT YOUR CX16 AND WAIT!" .byte 0 s2: .text " bytes flashed!" @@ -10238,278 +6519,458 @@ main_vera_flash: { .byte 0 info_text15: .text "The jumper JP1 has been opened on the VERA!" .byte 0 - vera_differences: .dword 0 - vera_flashed: .dword 0 } .segment Code - // display_info_rom + // util_wait_key /** - * @brief Display the ROM status of a specific rom chip. + * @brief * - * @param rom_chip The ROM chip, 0 is the main CX16 ROM chip, maximum 7 ROMs. - * @param info_status The status. - * @param info_text The status text. - */ -// void display_info_rom(__mem() char rom_chip, __mem() char info_status, __zp($3f) char *info_text) + * @param info_text + * @param filter + * @return unsigned char + */ +// __mem() char util_wait_key(__zp($59) char *info_text, __zp($5f) char *filter) +util_wait_key: { + .const bank_set_bram1_bank = 0 + .const bank_set_brom1_bank = 4 + .label util_wait_key__9 = $42 + .label info_text = $59 + .label filter = $5f + // display_action_text(info_text) + // [1035] display_action_text::info_text#5 = util_wait_key::info_text#3 + // [1036] call display_action_text + // [845] phi from util_wait_key to display_action_text [phi:util_wait_key->display_action_text] + // [845] phi display_action_text::info_text#17 = display_action_text::info_text#5 [phi:util_wait_key->display_action_text#0] -- register_copy + jsr display_action_text + // util_wait_key::bank_get_bram1 + // return BRAM; + // [1037] util_wait_key::bram#0 = BRAM -- vbum1=vbuz2 + lda.z BRAM + sta bram + // util_wait_key::bank_get_brom1 + // return BROM; + // [1038] util_wait_key::bank_get_brom1_return#0 = BROM -- vbum1=vbuz2 + lda.z BROM + sta bank_get_brom1_return + // util_wait_key::bank_set_bram1 + // BRAM = bank + // [1039] BRAM = util_wait_key::bank_set_bram1_bank#0 -- vbuz1=vbuc1 + lda #bank_set_bram1_bank + sta.z BRAM + // util_wait_key::bank_set_brom1 + // BROM = bank + // [1040] BROM = util_wait_key::bank_set_brom1_bank#0 -- vbuz1=vbuc1 + lda #bank_set_brom1_bank + sta.z BROM + // [1041] phi from util_wait_key::@2 util_wait_key::@5 util_wait_key::bank_set_brom1 to util_wait_key::kbhit1 [phi:util_wait_key::@2/util_wait_key::@5/util_wait_key::bank_set_brom1->util_wait_key::kbhit1] + // util_wait_key::kbhit1 + kbhit1: + // util_wait_key::kbhit1_cbm_k_clrchn1 + // asm + // asm { jsrCBM_CLRCHN } + jsr CBM_CLRCHN + // [1043] phi from util_wait_key::kbhit1_cbm_k_clrchn1 to util_wait_key::kbhit1_@2 [phi:util_wait_key::kbhit1_cbm_k_clrchn1->util_wait_key::kbhit1_@2] + // util_wait_key::kbhit1_@2 + // cbm_k_getin() + // [1044] call cbm_k_getin + jsr cbm_k_getin + // [1045] cbm_k_getin::return#2 = cbm_k_getin::return#1 + // util_wait_key::@4 + // [1046] util_wait_key::ch#4 = cbm_k_getin::return#2 -- vwum1=vbum2 + lda cbm_k_getin.return + sta ch + lda #0 + sta ch+1 + // util_wait_key::@3 + // if (filter) + // [1047] if((char *)0!=util_wait_key::filter#13) goto util_wait_key::@1 -- pbuc1_neq_pbuz1_then_la1 + // if there is a filter, check the filter, otherwise return ch. + lda.z filter+1 + cmp #>0 + bne __b1 + lda.z filter + cmp #<0 + bne __b1 + // util_wait_key::@2 + // if(ch) + // [1048] if(0!=util_wait_key::ch#4) goto util_wait_key::bank_set_bram2 -- 0_neq_vwum1_then_la1 + lda ch + ora ch+1 + bne bank_set_bram2 + jmp kbhit1 + // util_wait_key::bank_set_bram2 + bank_set_bram2: + // BRAM = bank + // [1049] BRAM = util_wait_key::bram#0 -- vbuz1=vbum2 + lda bram + sta.z BRAM + // util_wait_key::bank_set_brom2 + // BROM = bank + // [1050] BROM = util_wait_key::bank_get_brom1_return#0 -- vbuz1=vbum2 + lda bank_get_brom1_return + sta.z BROM + // util_wait_key::@return + // } + // [1051] return + rts + // util_wait_key::@1 + __b1: + // strchr(filter, ch) + // [1052] strchr::str#0 = (const void *)util_wait_key::filter#13 -- pvoz1=pvoz2 + lda.z filter + sta.z strchr.str + lda.z filter+1 + sta.z strchr.str+1 + // [1053] strchr::c#0 = util_wait_key::ch#4 -- vbum1=vwum2 + lda ch + sta strchr.c + // [1054] call strchr + // [1058] phi from util_wait_key::@1 to strchr [phi:util_wait_key::@1->strchr] + // [1058] phi strchr::c#4 = strchr::c#0 [phi:util_wait_key::@1->strchr#0] -- register_copy + // [1058] phi strchr::str#2 = strchr::str#0 [phi:util_wait_key::@1->strchr#1] -- register_copy + jsr strchr + // strchr(filter, ch) + // [1055] strchr::return#3 = strchr::return#2 + // util_wait_key::@5 + // [1056] util_wait_key::$9 = strchr::return#3 + // if(strchr(filter, ch) != NULL) + // [1057] if(util_wait_key::$9!=0) goto util_wait_key::bank_set_bram2 -- pvoz1_neq_0_then_la1 + lda.z util_wait_key__9 + ora.z util_wait_key__9+1 + bne bank_set_bram2 + jmp kbhit1 + .segment Data + bram: .byte 0 + bank_get_brom1_return: .byte 0 + return: .byte 0 + return_1: .byte 0 + ch: .word 0 +} +.segment Code + // strchr +// Searches for the first occurrence of the character c (an unsigned char) in the string pointed to, by the argument str. +// - str: The memory to search +// - c: A character to search for +// Return: A pointer to the matching byte or NULL if the character does not occur in the given memory area. +// __zp($42) void * strchr(__zp($42) const void *str, __mem() char c) +strchr: { + .label ptr = $42 + .label return = $42 + .label str = $42 + // [1059] strchr::ptr#6 = (char *)strchr::str#2 + // [1060] phi from strchr strchr::@3 to strchr::@1 [phi:strchr/strchr::@3->strchr::@1] + // [1060] phi strchr::ptr#2 = strchr::ptr#6 [phi:strchr/strchr::@3->strchr::@1#0] -- register_copy + // strchr::@1 + __b1: + // while(*ptr) + // [1061] if(0!=*strchr::ptr#2) goto strchr::@2 -- 0_neq__deref_pbuz1_then_la1 + ldy #0 + lda (ptr),y + cmp #0 + bne __b2 + // [1062] phi from strchr::@1 to strchr::@return [phi:strchr::@1->strchr::@return] + // [1062] phi strchr::return#2 = (void *) 0 [phi:strchr::@1->strchr::@return#0] -- pvoz1=pvoc1 + tya + sta.z return + sta.z return+1 + // strchr::@return + // } + // [1063] return + rts + // strchr::@2 + __b2: + // if(*ptr==c) + // [1064] if(*strchr::ptr#2!=strchr::c#4) goto strchr::@3 -- _deref_pbuz1_neq_vbum2_then_la1 + ldy #0 + lda (ptr),y + cmp c + bne __b3 + // strchr::@4 + // [1065] strchr::return#8 = (void *)strchr::ptr#2 + // [1062] phi from strchr::@4 to strchr::@return [phi:strchr::@4->strchr::@return] + // [1062] phi strchr::return#2 = strchr::return#8 [phi:strchr::@4->strchr::@return#0] -- register_copy + rts + // strchr::@3 + __b3: + // ptr++; + // [1066] strchr::ptr#1 = ++ strchr::ptr#2 -- pbuz1=_inc_pbuz1 + inc.z ptr + bne !+ + inc.z ptr+1 + !: + jmp __b1 + .segment Data + c: .byte 0 +} +.segment Code + // display_info_rom +/** + * @brief Display the ROM status of a specific rom chip. + * + * @param rom_chip The ROM chip, 0 is the main CX16 ROM chip, maximum 7 ROMs. + * @param info_status The status. + * @param info_text The status text. + */ +// void display_info_rom(__mem() char rom_chip, __mem() char info_status, __zp($3c) char *info_text) display_info_rom: { - .label display_info_rom__6 = $68 - .label display_info_rom__15 = $78 - .label display_info_rom__16 = $41 - .label info_text = $3f - .label display_info_rom__19 = $68 - .label display_info_rom__20 = $68 + .label display_info_rom__6 = $38 + .label display_info_rom__15 = $4e + .label display_info_rom__16 = $3b + .label info_text = $3c + .label display_info_rom__19 = $38 + .label display_info_rom__20 = $38 // unsigned char x = wherex() - // [1547] call wherex + // [1068] call wherex jsr wherex - // [1548] wherex::return#12 = wherex::return#0 -- vbum1=vbum2 + // [1069] wherex::return#12 = wherex::return#0 -- vbum1=vbum2 lda wherex.return sta wherex.return_4 // display_info_rom::@3 - // [1549] display_info_rom::x#0 = wherex::return#12 + // [1070] display_info_rom::x#0 = wherex::return#12 // unsigned char y = wherey() - // [1550] call wherey + // [1071] call wherey jsr wherey - // [1551] wherey::return#12 = wherey::return#0 -- vbum1=vbum2 + // [1072] wherey::return#12 = wherey::return#0 -- vbum1=vbum2 lda wherey.return sta wherey.return_4 // display_info_rom::@4 - // [1552] display_info_rom::y#0 = wherey::return#12 + // [1073] display_info_rom::y#0 = wherey::return#12 // status_rom[rom_chip] = info_status - // [1553] status_rom[display_info_rom::rom_chip#17] = display_info_rom::info_status#17 -- pbuc1_derefidx_vbum1=vbum2 + // [1074] status_rom[display_info_rom::rom_chip#10] = display_info_rom::info_status#10 -- pbuc1_derefidx_vbum1=vbum2 lda info_status ldy rom_chip sta status_rom,y // display_rom_led(rom_chip, status_color[info_status]) - // [1554] display_rom_led::chip#1 = display_info_rom::rom_chip#17 -- vbum1=vbum2 + // [1075] display_rom_led::chip#1 = display_info_rom::rom_chip#10 -- vbum1=vbum2 tya sta display_rom_led.chip - // [1555] display_rom_led::c#1 = status_color[display_info_rom::info_status#17] -- vbum1=pbuc1_derefidx_vbum2 + // [1076] display_rom_led::c#1 = status_color[display_info_rom::info_status#10] -- vbum1=pbuc1_derefidx_vbum2 ldy info_status lda status_color,y sta display_rom_led.c - // [1556] call display_rom_led - // [2369] phi from display_info_rom::@4 to display_rom_led [phi:display_info_rom::@4->display_rom_led] - // [2369] phi display_rom_led::c#2 = display_rom_led::c#1 [phi:display_info_rom::@4->display_rom_led#0] -- register_copy - // [2369] phi display_rom_led::chip#2 = display_rom_led::chip#1 [phi:display_info_rom::@4->display_rom_led#1] -- register_copy + // [1077] call display_rom_led + // [1422] phi from display_info_rom::@4 to display_rom_led [phi:display_info_rom::@4->display_rom_led] + // [1422] phi display_rom_led::c#2 = display_rom_led::c#1 [phi:display_info_rom::@4->display_rom_led#0] -- register_copy + // [1422] phi display_rom_led::chip#2 = display_rom_led::chip#1 [phi:display_info_rom::@4->display_rom_led#1] -- register_copy jsr display_rom_led // display_info_rom::@5 // gotoxy(INFO_X, INFO_Y+rom_chip+2) - // [1557] gotoxy::y#23 = display_info_rom::rom_chip#17 + $11+2 -- vbum1=vbum2_plus_vbuc1 + // [1078] gotoxy::y#23 = display_info_rom::rom_chip#10 + $11+2 -- vbum1=vbum2_plus_vbuc1 lda #$11+2 clc adc rom_chip sta gotoxy.y - // [1558] call gotoxy - // [802] phi from display_info_rom::@5 to gotoxy [phi:display_info_rom::@5->gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#23 [phi:display_info_rom::@5->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = 4 [phi:display_info_rom::@5->gotoxy#1] -- vbum1=vbuc1 + // [1079] call gotoxy + // [457] phi from display_info_rom::@5 to gotoxy [phi:display_info_rom::@5->gotoxy] + // [457] phi gotoxy::y#26 = gotoxy::y#23 [phi:display_info_rom::@5->gotoxy#0] -- register_copy + // [457] phi gotoxy::x#26 = 4 [phi:display_info_rom::@5->gotoxy#1] -- vbum1=vbuc1 lda #4 sta gotoxy.x jsr gotoxy // display_info_rom::@6 // printf("ROM%u %-9s %-6s %-13s ", rom_chip, status_text[info_status], rom_device_names[rom_chip], &rom_release_text[rom_chip*13]) - // [1559] display_info_rom::$16 = display_info_rom::rom_chip#17 << 1 -- vbuz1=vbum2_rol_1 + // [1080] display_info_rom::$16 = display_info_rom::rom_chip#10 << 1 -- vbuz1=vbum2_rol_1 lda rom_chip asl sta.z display_info_rom__16 // rom_chip*13 - // [1560] display_info_rom::$19 = display_info_rom::$16 + display_info_rom::rom_chip#17 -- vbuz1=vbuz2_plus_vbum3 + // [1081] display_info_rom::$19 = display_info_rom::$16 + display_info_rom::rom_chip#10 -- vbuz1=vbuz2_plus_vbum3 lda rom_chip clc adc.z display_info_rom__16 sta.z display_info_rom__19 - // [1561] display_info_rom::$20 = display_info_rom::$19 << 2 -- vbuz1=vbuz1_rol_2 + // [1082] display_info_rom::$20 = display_info_rom::$19 << 2 -- vbuz1=vbuz1_rol_2 lda.z display_info_rom__20 asl asl sta.z display_info_rom__20 - // [1562] display_info_rom::$6 = display_info_rom::$20 + display_info_rom::rom_chip#17 -- vbuz1=vbuz1_plus_vbum2 + // [1083] display_info_rom::$6 = display_info_rom::$20 + display_info_rom::rom_chip#10 -- vbuz1=vbuz1_plus_vbum2 lda rom_chip clc adc.z display_info_rom__6 sta.z display_info_rom__6 // printf("ROM%u %-9s %-6s %-13s ", rom_chip, status_text[info_status], rom_device_names[rom_chip], &rom_release_text[rom_chip*13]) - // [1563] printf_string::str#10 = rom_release_text + display_info_rom::$6 -- pbuz1=pbuc1_plus_vbuz2 + // [1084] printf_string::str#10 = rom_release_text + display_info_rom::$6 -- pbuz1=pbuc1_plus_vbuz2 clc adc #rom_release_text adc #0 sta.z printf_string.str_1+1 - // [1564] call printf_str - // [1210] phi from display_info_rom::@6 to printf_str [phi:display_info_rom::@6->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:display_info_rom::@6->printf_str#0] -- pprz1=pprc1 + // [1085] call printf_str + // [785] phi from display_info_rom::@6 to printf_str [phi:display_info_rom::@6->printf_str] + // [785] phi printf_str::putc#53 = &cputc [phi:display_info_rom::@6->printf_str#0] -- pprz1=pprc1 lda #cputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = chip [phi:display_info_rom::@6->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #chip + lda #>s sta.z printf_str.s+1 jsr printf_str // display_info_rom::@7 // printf("ROM%u %-9s %-6s %-13s ", rom_chip, status_text[info_status], rom_device_names[rom_chip], &rom_release_text[rom_chip*13]) - // [1565] printf_uchar::uvalue#4 = display_info_rom::rom_chip#17 -- vbum1=vbum2 + // [1086] printf_uchar::uvalue#4 = display_info_rom::rom_chip#10 -- vbum1=vbum2 lda rom_chip sta printf_uchar.uvalue - // [1566] call printf_uchar - // [1346] phi from display_info_rom::@7 to printf_uchar [phi:display_info_rom::@7->printf_uchar] - // [1346] phi printf_uchar::format_zero_padding#18 = 0 [phi:display_info_rom::@7->printf_uchar#0] -- vbum1=vbuc1 + // [1087] call printf_uchar + // [834] phi from display_info_rom::@7 to printf_uchar [phi:display_info_rom::@7->printf_uchar] + // [834] phi printf_uchar::format_zero_padding#10 = 0 [phi:display_info_rom::@7->printf_uchar#0] -- vbum1=vbuc1 lda #0 sta printf_uchar.format_zero_padding - // [1346] phi printf_uchar::format_min_length#18 = 0 [phi:display_info_rom::@7->printf_uchar#1] -- vbum1=vbuc1 + // [834] phi printf_uchar::format_min_length#10 = 0 [phi:display_info_rom::@7->printf_uchar#1] -- vbum1=vbuc1 sta printf_uchar.format_min_length - // [1346] phi printf_uchar::putc#18 = &cputc [phi:display_info_rom::@7->printf_uchar#2] -- pprz1=pprc1 + // [834] phi printf_uchar::putc#10 = &cputc [phi:display_info_rom::@7->printf_uchar#2] -- pprz1=pprc1 lda #cputc sta.z printf_uchar.putc+1 - // [1346] phi printf_uchar::format_radix#18 = DECIMAL [phi:display_info_rom::@7->printf_uchar#3] -- vbum1=vbuc1 + // [834] phi printf_uchar::format_radix#10 = DECIMAL [phi:display_info_rom::@7->printf_uchar#3] -- vbum1=vbuc1 lda #DECIMAL sta printf_uchar.format_radix - // [1346] phi printf_uchar::uvalue#18 = printf_uchar::uvalue#4 [phi:display_info_rom::@7->printf_uchar#4] -- register_copy + // [834] phi printf_uchar::uvalue#10 = printf_uchar::uvalue#4 [phi:display_info_rom::@7->printf_uchar#4] -- register_copy jsr printf_uchar - // [1567] phi from display_info_rom::@7 to display_info_rom::@8 [phi:display_info_rom::@7->display_info_rom::@8] + // [1088] phi from display_info_rom::@7 to display_info_rom::@8 [phi:display_info_rom::@7->display_info_rom::@8] // display_info_rom::@8 // printf("ROM%u %-9s %-6s %-13s ", rom_chip, status_text[info_status], rom_device_names[rom_chip], &rom_release_text[rom_chip*13]) - // [1568] call printf_str - // [1210] phi from display_info_rom::@8 to printf_str [phi:display_info_rom::@8->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:display_info_rom::@8->printf_str#0] -- pprz1=pprc1 + // [1089] call printf_str + // [785] phi from display_info_rom::@8 to printf_str [phi:display_info_rom::@8->printf_str] + // [785] phi printf_str::putc#53 = &cputc [phi:display_info_rom::@8->printf_str#0] -- pprz1=pprc1 lda #cputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s4 [phi:display_info_rom::@8->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #<@s sta.z printf_str.s - lda #>s4 + lda #>@s sta.z printf_str.s+1 jsr printf_str // display_info_rom::@9 // printf("ROM%u %-9s %-6s %-13s ", rom_chip, status_text[info_status], rom_device_names[rom_chip], &rom_release_text[rom_chip*13]) - // [1569] display_info_rom::$15 = display_info_rom::info_status#17 << 1 -- vbuz1=vbum2_rol_1 + // [1090] display_info_rom::$15 = display_info_rom::info_status#10 << 1 -- vbuz1=vbum2_rol_1 lda info_status asl sta.z display_info_rom__15 - // [1570] printf_string::str#8 = status_text[display_info_rom::$15] -- pbuz1=qbuc1_derefidx_vbuz2 + // [1091] printf_string::str#8 = status_text[display_info_rom::$15] -- pbuz1=qbuc1_derefidx_vbuz2 tay lda status_text,y sta.z printf_string.str lda status_text+1,y sta.z printf_string.str+1 - // [1571] call printf_string - // [1219] phi from display_info_rom::@9 to printf_string [phi:display_info_rom::@9->printf_string] - // [1219] phi printf_string::putc#26 = &cputc [phi:display_info_rom::@9->printf_string#0] -- pprz1=pprc1 + // [1092] call printf_string + // [1308] phi from display_info_rom::@9 to printf_string [phi:display_info_rom::@9->printf_string] + // [1308] phi printf_string::putc#17 = &cputc [phi:display_info_rom::@9->printf_string#0] -- pprz1=pprc1 lda #cputc sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#8 [phi:display_info_rom::@9->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 1 [phi:display_info_rom::@9->printf_string#2] -- vbum1=vbuc1 + // [1308] phi printf_string::str#17 = printf_string::str#8 [phi:display_info_rom::@9->printf_string#1] -- register_copy + // [1308] phi printf_string::format_justify_left#17 = 1 [phi:display_info_rom::@9->printf_string#2] -- vbum1=vbuc1 lda #1 sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = 9 [phi:display_info_rom::@9->printf_string#3] -- vbum1=vbuc1 + // [1308] phi printf_string::format_min_length#17 = 9 [phi:display_info_rom::@9->printf_string#3] -- vbum1=vbuc1 lda #9 sta printf_string.format_min_length jsr printf_string - // [1572] phi from display_info_rom::@9 to display_info_rom::@10 [phi:display_info_rom::@9->display_info_rom::@10] + // [1093] phi from display_info_rom::@9 to display_info_rom::@10 [phi:display_info_rom::@9->display_info_rom::@10] // display_info_rom::@10 // printf("ROM%u %-9s %-6s %-13s ", rom_chip, status_text[info_status], rom_device_names[rom_chip], &rom_release_text[rom_chip*13]) - // [1573] call printf_str - // [1210] phi from display_info_rom::@10 to printf_str [phi:display_info_rom::@10->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:display_info_rom::@10->printf_str#0] -- pprz1=pprc1 + // [1094] call printf_str + // [785] phi from display_info_rom::@10 to printf_str [phi:display_info_rom::@10->printf_str] + // [785] phi printf_str::putc#53 = &cputc [phi:display_info_rom::@10->printf_str#0] -- pprz1=pprc1 lda #cputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s4 [phi:display_info_rom::@10->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #<@s sta.z printf_str.s - lda #>s4 + lda #>@s sta.z printf_str.s+1 jsr printf_str // display_info_rom::@11 // printf("ROM%u %-9s %-6s %-13s ", rom_chip, status_text[info_status], rom_device_names[rom_chip], &rom_release_text[rom_chip*13]) - // [1574] printf_string::str#9 = rom_device_names[display_info_rom::$16] -- pbuz1=qbuc1_derefidx_vbuz2 + // [1095] printf_string::str#9 = rom_device_names[display_info_rom::$16] -- pbuz1=qbuc1_derefidx_vbuz2 ldy.z display_info_rom__16 lda rom_device_names,y sta.z printf_string.str lda rom_device_names+1,y sta.z printf_string.str+1 - // [1575] call printf_string - // [1219] phi from display_info_rom::@11 to printf_string [phi:display_info_rom::@11->printf_string] - // [1219] phi printf_string::putc#26 = &cputc [phi:display_info_rom::@11->printf_string#0] -- pprz1=pprc1 + // [1096] call printf_string + // [1308] phi from display_info_rom::@11 to printf_string [phi:display_info_rom::@11->printf_string] + // [1308] phi printf_string::putc#17 = &cputc [phi:display_info_rom::@11->printf_string#0] -- pprz1=pprc1 lda #cputc sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#9 [phi:display_info_rom::@11->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 1 [phi:display_info_rom::@11->printf_string#2] -- vbum1=vbuc1 + // [1308] phi printf_string::str#17 = printf_string::str#9 [phi:display_info_rom::@11->printf_string#1] -- register_copy + // [1308] phi printf_string::format_justify_left#17 = 1 [phi:display_info_rom::@11->printf_string#2] -- vbum1=vbuc1 lda #1 sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = 6 [phi:display_info_rom::@11->printf_string#3] -- vbum1=vbuc1 + // [1308] phi printf_string::format_min_length#17 = 6 [phi:display_info_rom::@11->printf_string#3] -- vbum1=vbuc1 lda #6 sta printf_string.format_min_length jsr printf_string - // [1576] phi from display_info_rom::@11 to display_info_rom::@12 [phi:display_info_rom::@11->display_info_rom::@12] + // [1097] phi from display_info_rom::@11 to display_info_rom::@12 [phi:display_info_rom::@11->display_info_rom::@12] // display_info_rom::@12 // printf("ROM%u %-9s %-6s %-13s ", rom_chip, status_text[info_status], rom_device_names[rom_chip], &rom_release_text[rom_chip*13]) - // [1577] call printf_str - // [1210] phi from display_info_rom::@12 to printf_str [phi:display_info_rom::@12->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:display_info_rom::@12->printf_str#0] -- pprz1=pprc1 + // [1098] call printf_str + // [785] phi from display_info_rom::@12 to printf_str [phi:display_info_rom::@12->printf_str] + // [785] phi printf_str::putc#53 = &cputc [phi:display_info_rom::@12->printf_str#0] -- pprz1=pprc1 lda #cputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s4 [phi:display_info_rom::@12->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #<@s sta.z printf_str.s - lda #>s4 + lda #>@s sta.z printf_str.s+1 jsr printf_str // display_info_rom::@13 - // [1578] printf_string::str#41 = printf_string::str#10 -- pbuz1=pbuz2 + // [1099] printf_string::str#29 = printf_string::str#10 -- pbuz1=pbuz2 lda.z printf_string.str_1 sta.z printf_string.str lda.z printf_string.str_1+1 sta.z printf_string.str+1 // printf("ROM%u %-9s %-6s %-13s ", rom_chip, status_text[info_status], rom_device_names[rom_chip], &rom_release_text[rom_chip*13]) - // [1579] call printf_string - // [1219] phi from display_info_rom::@13 to printf_string [phi:display_info_rom::@13->printf_string] - // [1219] phi printf_string::putc#26 = &cputc [phi:display_info_rom::@13->printf_string#0] -- pprz1=pprc1 + // [1100] call printf_string + // [1308] phi from display_info_rom::@13 to printf_string [phi:display_info_rom::@13->printf_string] + // [1308] phi printf_string::putc#17 = &cputc [phi:display_info_rom::@13->printf_string#0] -- pprz1=pprc1 lda #cputc sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#41 [phi:display_info_rom::@13->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 1 [phi:display_info_rom::@13->printf_string#2] -- vbum1=vbuc1 + // [1308] phi printf_string::str#17 = printf_string::str#29 [phi:display_info_rom::@13->printf_string#1] -- register_copy + // [1308] phi printf_string::format_justify_left#17 = 1 [phi:display_info_rom::@13->printf_string#2] -- vbum1=vbuc1 lda #1 sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = $d [phi:display_info_rom::@13->printf_string#3] -- vbum1=vbuc1 + // [1308] phi printf_string::format_min_length#17 = $d [phi:display_info_rom::@13->printf_string#3] -- vbum1=vbuc1 lda #$d sta printf_string.format_min_length jsr printf_string - // [1580] phi from display_info_rom::@13 to display_info_rom::@14 [phi:display_info_rom::@13->display_info_rom::@14] + // [1101] phi from display_info_rom::@13 to display_info_rom::@14 [phi:display_info_rom::@13->display_info_rom::@14] // display_info_rom::@14 // printf("ROM%u %-9s %-6s %-13s ", rom_chip, status_text[info_status], rom_device_names[rom_chip], &rom_release_text[rom_chip*13]) - // [1581] call printf_str - // [1210] phi from display_info_rom::@14 to printf_str [phi:display_info_rom::@14->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:display_info_rom::@14->printf_str#0] -- pprz1=pprc1 + // [1102] call printf_str + // [785] phi from display_info_rom::@14 to printf_str [phi:display_info_rom::@14->printf_str] + // [785] phi printf_str::putc#53 = &cputc [phi:display_info_rom::@14->printf_str#0] -- pprz1=pprc1 lda #cputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s4 [phi:display_info_rom::@14->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #<@s sta.z printf_str.s - lda #>s4 + lda #>@s sta.z printf_str.s+1 jsr printf_str // display_info_rom::@15 // if(info_text) - // [1582] if((char *)0==display_info_rom::info_text#17) goto display_info_rom::@1 -- pbuc1_eq_pbuz1_then_la1 + // [1103] if((char *)0==display_info_rom::info_text#10) goto display_info_rom::@1 -- pbuc1_eq_pbuz1_then_la1 lda.z info_text cmp #<0 bne !+ @@ -10519,6642 +6980,4371 @@ display_info_rom: { !: // display_info_rom::@2 // gotoxy(INFO_X+64-28, INFO_Y+rom_chip+2) - // [1583] gotoxy::y#25 = display_info_rom::rom_chip#17 + $11+2 -- vbum1=vbum2_plus_vbuc1 + // [1104] gotoxy::y#25 = display_info_rom::rom_chip#10 + $11+2 -- vbum1=vbum2_plus_vbuc1 lda #$11+2 clc adc rom_chip sta gotoxy.y - // [1584] call gotoxy - // [802] phi from display_info_rom::@2 to gotoxy [phi:display_info_rom::@2->gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#25 [phi:display_info_rom::@2->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = 4+$40-$1c [phi:display_info_rom::@2->gotoxy#1] -- vbum1=vbuc1 + // [1105] call gotoxy + // [457] phi from display_info_rom::@2 to gotoxy [phi:display_info_rom::@2->gotoxy] + // [457] phi gotoxy::y#26 = gotoxy::y#25 [phi:display_info_rom::@2->gotoxy#0] -- register_copy + // [457] phi gotoxy::x#26 = 4+$40-$1c [phi:display_info_rom::@2->gotoxy#1] -- vbum1=vbuc1 lda #4+$40-$1c sta gotoxy.x jsr gotoxy // display_info_rom::@16 // printf("%-25s", info_text) - // [1585] printf_string::str#11 = display_info_rom::info_text#17 -- pbuz1=pbuz2 + // [1106] printf_string::str#11 = display_info_rom::info_text#10 -- pbuz1=pbuz2 lda.z info_text sta.z printf_string.str lda.z info_text+1 sta.z printf_string.str+1 - // [1586] call printf_string - // [1219] phi from display_info_rom::@16 to printf_string [phi:display_info_rom::@16->printf_string] - // [1219] phi printf_string::putc#26 = &cputc [phi:display_info_rom::@16->printf_string#0] -- pprz1=pprc1 + // [1107] call printf_string + // [1308] phi from display_info_rom::@16 to printf_string [phi:display_info_rom::@16->printf_string] + // [1308] phi printf_string::putc#17 = &cputc [phi:display_info_rom::@16->printf_string#0] -- pprz1=pprc1 lda #cputc sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#11 [phi:display_info_rom::@16->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 1 [phi:display_info_rom::@16->printf_string#2] -- vbum1=vbuc1 + // [1308] phi printf_string::str#17 = printf_string::str#11 [phi:display_info_rom::@16->printf_string#1] -- register_copy + // [1308] phi printf_string::format_justify_left#17 = 1 [phi:display_info_rom::@16->printf_string#2] -- vbum1=vbuc1 lda #1 sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = $19 [phi:display_info_rom::@16->printf_string#3] -- vbum1=vbuc1 + // [1308] phi printf_string::format_min_length#17 = $19 [phi:display_info_rom::@16->printf_string#3] -- vbum1=vbuc1 lda #$19 sta printf_string.format_min_length jsr printf_string // display_info_rom::@1 __b1: // gotoxy(x,y) - // [1587] gotoxy::x#24 = display_info_rom::x#0 -- vbum1=vbum2 + // [1108] gotoxy::x#24 = display_info_rom::x#0 -- vbum1=vbum2 lda x sta gotoxy.x - // [1588] gotoxy::y#24 = display_info_rom::y#0 -- vbum1=vbum2 + // [1109] gotoxy::y#24 = display_info_rom::y#0 -- vbum1=vbum2 lda y sta gotoxy.y - // [1589] call gotoxy - // [802] phi from display_info_rom::@1 to gotoxy [phi:display_info_rom::@1->gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#24 [phi:display_info_rom::@1->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = gotoxy::x#24 [phi:display_info_rom::@1->gotoxy#1] -- register_copy + // [1110] call gotoxy + // [457] phi from display_info_rom::@1 to gotoxy [phi:display_info_rom::@1->gotoxy] + // [457] phi gotoxy::y#26 = gotoxy::y#24 [phi:display_info_rom::@1->gotoxy#0] -- register_copy + // [457] phi gotoxy::x#26 = gotoxy::x#24 [phi:display_info_rom::@1->gotoxy#1] -- register_copy jsr gotoxy // display_info_rom::@return // } - // [1590] return + // [1111] return rts .segment Data + s: .text "ROM" + .byte 0 .label x = wherex.return_4 .label y = wherey.return_4 info_status: .byte 0 rom_chip: .byte 0 } .segment Code - // rom_file -// __zp($cf) char * rom_file(__mem() char rom_chip) -rom_file: { - .label rom_file__0 = $41 - .label return = $cf - // if(rom_chip) - // [1592] if(0!=rom_file::rom_chip#2) goto rom_file::@1 -- 0_neq_vbum1_then_la1 - lda rom_chip - bne __b1 - // [1595] phi from rom_file to rom_file::@return [phi:rom_file->rom_file::@return] - // [1595] phi rom_file::return#2 = rom_file::file_rom_cx16 [phi:rom_file->rom_file::@return#0] -- pbuz1=pbuc1 - lda #file_rom_cx16 - sta.z return+1 - rts - // rom_file::@1 - __b1: - // '0'+rom_chip - // [1593] rom_file::$0 = '0' + rom_file::rom_chip#2 -- vbuz1=vbuc1_plus_vbum2 - lda #'0' - clc - adc rom_chip - sta.z rom_file__0 - // file_rom_card[3] = '0'+rom_chip - // [1594] *(rom_file::file_rom_card+3) = rom_file::$0 -- _deref_pbuc1=vbuz1 - sta file_rom_card+3 - // [1595] phi from rom_file::@1 to rom_file::@return [phi:rom_file::@1->rom_file::@return] - // [1595] phi rom_file::return#2 = rom_file::file_rom_card [phi:rom_file::@1->rom_file::@return#0] -- pbuz1=pbuc1 - lda #file_rom_card - sta.z return+1 - // rom_file::@return + // display_info_cx16_rom +/** + * @brief Display the ROM status of the main CX16 ROM chip. + * + * @param info_status The status. + * @param info_text The status text. + */ +// void display_info_cx16_rom(__mem() char info_status, __zp($3c) char *info_text) +display_info_cx16_rom: { + .label info_text = $3c + // display_info_rom(0, info_status, info_text) + // [1113] display_info_rom::info_status#0 = display_info_cx16_rom::info_status#4 + // [1114] display_info_rom::info_text#0 = display_info_cx16_rom::info_text#4 + // [1115] call display_info_rom + // [1067] phi from display_info_cx16_rom to display_info_rom [phi:display_info_cx16_rom->display_info_rom] + // [1067] phi display_info_rom::info_text#10 = display_info_rom::info_text#0 [phi:display_info_cx16_rom->display_info_rom#0] -- register_copy + // [1067] phi display_info_rom::rom_chip#10 = 0 [phi:display_info_cx16_rom->display_info_rom#1] -- vbum1=vbuc1 + lda #0 + sta display_info_rom.rom_chip + // [1067] phi display_info_rom::info_status#10 = display_info_rom::info_status#0 [phi:display_info_cx16_rom->display_info_rom#2] -- register_copy + jsr display_info_rom + // display_info_cx16_rom::@return // } - // [1596] return + // [1116] return rts .segment Data - file_rom_cx16: .text "ROM.BIN" - .byte 0 - file_rom_card: .text "ROMn.BIN" - .byte 0 - rom_chip: .byte 0 + .label info_status = display_info_rom.info_status } .segment Code - // rom_read -// __mem() unsigned long rom_read(__mem() char rom_chip, __zp($56) char *file, __mem() char info_status, __mem() char brom_bank_start, __mem() unsigned long rom_size) -rom_read: { - .const bank_set_brom1_bank = 0 - .label rom_read__13 = $74 - .label rom_read__24 = $68 - .label fp = $b6 - .label rom_bram_ptr = $2d - .label file = $56 - .label rom_action_text = $54 - // rom_read::bank_set_bram1 - // BRAM = bank - // [1598] BRAM = 0 -- vbuz1=vbuc1 - lda #0 - sta.z BRAM - // rom_read::bank_set_brom1 - // BROM = bank - // [1599] BROM = rom_read::bank_set_brom1_bank#0 -- vbuz1=vbuc1 - lda #bank_set_brom1_bank - sta.z BROM - // rom_read::@23 - // if(info_status == STATUS_READING) - // [1600] if(rom_read::info_status#11==STATUS_READING) goto rom_read::@1 -- vbum1_eq_vbuc1_then_la1 - lda #STATUS_READING - cmp info_status - beq __b1 - // [1602] phi from rom_read::@23 to rom_read::@2 [phi:rom_read::@23->rom_read::@2] - // [1602] phi rom_read::rom_action_text#10 = smc_action_text#2 [phi:rom_read::@23->rom_read::@2#0] -- pbuz1=pbuc1 - lda #smc_action_text_1 - sta.z rom_action_text+1 - jmp __b2 - // [1601] phi from rom_read::@23 to rom_read::@1 [phi:rom_read::@23->rom_read::@1] - // rom_read::@1 + // strcpy +// Copies the C string pointed by source into the array pointed by destination, including the terminating null character (and stopping at that point). +// char * strcpy(__zp($36) char *destination, char *source) +strcpy: { + .label src = $34 + .label dst = $36 + .label destination = $36 + // [1118] phi from strcpy strcpy::@2 to strcpy::@1 [phi:strcpy/strcpy::@2->strcpy::@1] + // [1118] phi strcpy::dst#2 = strcpy::dst#0 [phi:strcpy/strcpy::@2->strcpy::@1#0] -- register_copy + // [1118] phi strcpy::src#2 = strcpy::src#0 [phi:strcpy/strcpy::@2->strcpy::@1#1] -- register_copy + // strcpy::@1 __b1: - // [1602] phi from rom_read::@1 to rom_read::@2 [phi:rom_read::@1->rom_read::@2] - // [1602] phi rom_read::rom_action_text#10 = smc_action_text#1 [phi:rom_read::@1->rom_read::@2#0] -- pbuz1=pbuc1 - lda #smc_action_text - sta.z rom_action_text+1 - // rom_read::@2 + // while(*src) + // [1119] if(0!=*strcpy::src#2) goto strcpy::@2 -- 0_neq__deref_pbuz1_then_la1 + ldy #0 + lda (src),y + cmp #0 + bne __b2 + // strcpy::@3 + // *dst = 0 + // [1120] *strcpy::dst#2 = 0 -- _deref_pbuz1=vbuc1 + tya + tay + sta (dst),y + // strcpy::@return + // } + // [1121] return + rts + // strcpy::@2 __b2: - // unsigned long rom_address = rom_address_from_bank(brom_bank_start) - // [1603] rom_address_from_bank::rom_bank#0 = rom_read::brom_bank_start#10 -- vbum1=vbum2 - lda brom_bank_start - sta rom_address_from_bank.rom_bank - // [1604] call rom_address_from_bank - // [2866] phi from rom_read::@2 to rom_address_from_bank [phi:rom_read::@2->rom_address_from_bank] - // [2866] phi rom_address_from_bank::rom_bank#3 = rom_address_from_bank::rom_bank#0 [phi:rom_read::@2->rom_address_from_bank#0] -- register_copy - jsr rom_address_from_bank - // unsigned long rom_address = rom_address_from_bank(brom_bank_start) - // [1605] rom_address_from_bank::return#2 = rom_address_from_bank::return#0 - // rom_read::@25 - // [1606] rom_read::rom_address#0 = rom_address_from_bank::return#2 - // sprintf(info_text, "Opening %s from SD card ...", file) - // [1607] call snprintf_init - // [1205] phi from rom_read::@25 to snprintf_init [phi:rom_read::@25->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:rom_read::@25->snprintf_init#0] -- pbuz1=pbuc1 - lda #info_text - sta.z snprintf_init.s+1 - jsr snprintf_init - // [1608] phi from rom_read::@25 to rom_read::@26 [phi:rom_read::@25->rom_read::@26] - // rom_read::@26 - // sprintf(info_text, "Opening %s from SD card ...", file) - // [1609] call printf_str - // [1210] phi from rom_read::@26 to printf_str [phi:rom_read::@26->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:rom_read::@26->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = rom_read::s [phi:rom_read::@26->printf_str#1] -- pbuz1=pbuc1 - lda #s - sta.z printf_str.s+1 - jsr printf_str - // rom_read::@27 - // sprintf(info_text, "Opening %s from SD card ...", file) - // [1610] printf_string::str#17 = rom_read::file#10 -- pbuz1=pbuz2 - lda.z file - sta.z printf_string.str - lda.z file+1 - sta.z printf_string.str+1 - // [1611] call printf_string - // [1219] phi from rom_read::@27 to printf_string [phi:rom_read::@27->printf_string] - // [1219] phi printf_string::putc#26 = &snputc [phi:rom_read::@27->printf_string#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#17 [phi:rom_read::@27->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 0 [phi:rom_read::@27->printf_string#2] -- vbum1=vbuc1 + // *dst++ = *src++ + // [1122] *strcpy::dst#2 = *strcpy::src#2 -- _deref_pbuz1=_deref_pbuz2 + ldy #0 + lda (src),y + sta (dst),y + // *dst++ = *src++; + // [1123] strcpy::dst#1 = ++ strcpy::dst#2 -- pbuz1=_inc_pbuz1 + inc.z dst + bne !+ + inc.z dst+1 + !: + // [1124] strcpy::src#1 = ++ strcpy::src#2 -- pbuz1=_inc_pbuz1 + inc.z src + bne !+ + inc.z src+1 + !: + jmp __b1 +} + // screenlayer +// --- layer management in VERA --- +// void screenlayer(char layer, __mem() char mapbase, __mem() char config) +screenlayer: { + .label screenlayer__0 = $58 + .label screenlayer__1 = $55 + .label screenlayer__2 = $74 + .label screenlayer__5 = $71 + .label screenlayer__6 = $71 + .label screenlayer__7 = $70 + .label screenlayer__8 = $70 + .label screenlayer__9 = $6e + .label screenlayer__10 = $6e + .label screenlayer__11 = $6e + .label screenlayer__12 = $6f + .label screenlayer__13 = $6f + .label screenlayer__14 = $6f + .label screenlayer__16 = $70 + .label screenlayer__17 = $67 + .label screenlayer__18 = $6e + .label screenlayer__19 = $6f + .label y = $64 + // __mem char vera_dc_hscale_temp = *VERA_DC_HSCALE + // [1125] screenlayer::vera_dc_hscale_temp#0 = *VERA_DC_HSCALE -- vbum1=_deref_pbuc1 + lda VERA_DC_HSCALE + sta vera_dc_hscale_temp + // __mem char vera_dc_vscale_temp = *VERA_DC_VSCALE + // [1126] screenlayer::vera_dc_vscale_temp#0 = *VERA_DC_VSCALE -- vbum1=_deref_pbuc1 + lda VERA_DC_VSCALE + sta vera_dc_vscale_temp + // __conio.layer = 0 + // [1127] *((char *)&__conio+2) = 0 -- _deref_pbuc1=vbuc2 lda #0 - sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = 0 [phi:rom_read::@27->printf_string#3] -- vbum1=vbuc1 - sta printf_string.format_min_length - jsr printf_string - // [1612] phi from rom_read::@27 to rom_read::@28 [phi:rom_read::@27->rom_read::@28] - // rom_read::@28 - // sprintf(info_text, "Opening %s from SD card ...", file) - // [1613] call printf_str - // [1210] phi from rom_read::@28 to printf_str [phi:rom_read::@28->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:rom_read::@28->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = rom_read::s1 [phi:rom_read::@28->printf_str#1] -- pbuz1=pbuc1 - lda #s1 - sta.z printf_str.s+1 - jsr printf_str - // rom_read::@29 - // sprintf(info_text, "Opening %s from SD card ...", file) - // [1614] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 + sta __conio+2 + // mapbase >> 7 + // [1128] screenlayer::$0 = screenlayer::mapbase#0 >> 7 -- vbuz1=vbum2_ror_7 + lda mapbase + rol + rol + and #1 + sta.z screenlayer__0 + // __conio.mapbase_bank = mapbase >> 7 + // [1129] *((char *)&__conio+5) = screenlayer::$0 -- _deref_pbuc1=vbuz1 + sta __conio+5 + // (mapbase)<<1 + // [1130] screenlayer::$1 = screenlayer::mapbase#0 << 1 -- vbuz1=vbum2_rol_1 + lda mapbase + asl + sta.z screenlayer__1 + // MAKEWORD((mapbase)<<1,0) + // [1131] screenlayer::$2 = screenlayer::$1 w= 0 -- vwuz1=vbuz2_word_vbuc1 lda #0 - pha - // [1615] callexecute snputc -- call_vprc1 - jsr snputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // display_action_text(info_text) - // [1617] call display_action_text - // [1357] phi from rom_read::@29 to display_action_text [phi:rom_read::@29->display_action_text] - // [1357] phi display_action_text::info_text#25 = info_text [phi:rom_read::@29->display_action_text#0] -- pbuz1=pbuc1 - lda #info_text - sta.z display_action_text.info_text+1 - jsr display_action_text - // rom_read::@30 - // FILE *fp = fopen(file, "r") - // [1618] fopen::path#4 = rom_read::file#10 -- pbuz1=pbuz2 - lda.z file - sta.z fopen.path - lda.z file+1 - sta.z fopen.path+1 - // [1619] call fopen - // [2416] phi from rom_read::@30 to fopen [phi:rom_read::@30->fopen] - // [2416] phi __errno#473 = __errno#105 [phi:rom_read::@30->fopen#0] -- register_copy - // [2416] phi fopen::pathtoken#0 = fopen::path#4 [phi:rom_read::@30->fopen#1] -- register_copy - // [2416] phi __stdio_filecount#27 = __stdio_filecount#100 [phi:rom_read::@30->fopen#2] -- register_copy - jsr fopen - // FILE *fp = fopen(file, "r") - // [1620] fopen::return#5 = fopen::return#2 - // rom_read::@31 - // [1621] rom_read::fp#0 = fopen::return#5 -- pssz1=pssz2 - lda.z fopen.return - sta.z fp - lda.z fopen.return+1 - sta.z fp+1 - // if (fp) - // [1622] if((struct $2 *)0==rom_read::fp#0) goto rom_read::@3 -- pssc1_eq_pssz1_then_la1 - lda.z fp - cmp #<0 - bne !+ - lda.z fp+1 - cmp #>0 - beq __b4 + ldy.z screenlayer__1 + sty.z screenlayer__2+1 + sta.z screenlayer__2 + // __conio.mapbase_offset = MAKEWORD((mapbase)<<1,0) + // [1132] *((unsigned int *)&__conio+3) = screenlayer::$2 -- _deref_pwuc1=vwuz1 + sta __conio+3 + tya + sta __conio+3+1 + // config & VERA_LAYER_WIDTH_MASK + // [1133] screenlayer::$7 = screenlayer::config#0 & VERA_LAYER_WIDTH_MASK -- vbuz1=vbum2_band_vbuc1 + lda #VERA_LAYER_WIDTH_MASK + and config + sta.z screenlayer__7 + // (config & VERA_LAYER_WIDTH_MASK) >> 4 + // [1134] screenlayer::$8 = screenlayer::$7 >> 4 -- vbuz1=vbuz1_ror_4 + lda.z screenlayer__8 + lsr + lsr + lsr + lsr + sta.z screenlayer__8 + // __conio.mapwidth = VERA_LAYER_DIM[ (config & VERA_LAYER_WIDTH_MASK) >> 4] + // [1135] *((char *)&__conio+8) = screenlayer::VERA_LAYER_DIM[screenlayer::$8] -- _deref_pbuc1=pbuc2_derefidx_vbuz1 + tay + lda VERA_LAYER_DIM,y + sta __conio+8 + // config & VERA_LAYER_HEIGHT_MASK + // [1136] screenlayer::$5 = screenlayer::config#0 & VERA_LAYER_HEIGHT_MASK -- vbuz1=vbum2_band_vbuc1 + lda #VERA_LAYER_HEIGHT_MASK + and config + sta.z screenlayer__5 + // (config & VERA_LAYER_HEIGHT_MASK) >> 6 + // [1137] screenlayer::$6 = screenlayer::$5 >> 6 -- vbuz1=vbuz1_ror_6 + lda.z screenlayer__6 + rol + rol + rol + and #3 + sta.z screenlayer__6 + // __conio.mapheight = VERA_LAYER_DIM[ (config & VERA_LAYER_HEIGHT_MASK) >> 6] + // [1138] *((char *)&__conio+9) = screenlayer::VERA_LAYER_DIM[screenlayer::$6] -- _deref_pbuc1=pbuc2_derefidx_vbuz1 + tay + lda VERA_LAYER_DIM,y + sta __conio+9 + // __conio.rowskip = VERA_LAYER_SKIP[(config & VERA_LAYER_WIDTH_MASK)>>4] + // [1139] screenlayer::$16 = screenlayer::$8 << 1 -- vbuz1=vbuz1_rol_1 + asl.z screenlayer__16 + // [1140] *((unsigned int *)&__conio+$a) = screenlayer::VERA_LAYER_SKIP[screenlayer::$16] -- _deref_pwuc1=pwuc2_derefidx_vbuz1 + // __conio.rowshift = ((config & VERA_LAYER_WIDTH_MASK)>>4)+6; + ldy.z screenlayer__16 + lda VERA_LAYER_SKIP,y + sta __conio+$a + lda VERA_LAYER_SKIP+1,y + sta __conio+$a+1 + // vera_dc_hscale_temp == 0x80 + // [1141] screenlayer::$9 = screenlayer::vera_dc_hscale_temp#0 == $80 -- vboz1=vbum2_eq_vbuc1 + lda vera_dc_hscale_temp + eor #$80 + beq !+ + lda #1 !: - // [1623] phi from rom_read::@31 to rom_read::@4 [phi:rom_read::@31->rom_read::@4] - // rom_read::@4 - // gotoxy(x, y) - // [1624] call gotoxy - // [802] phi from rom_read::@4 to gotoxy [phi:rom_read::@4->gotoxy] - // [802] phi gotoxy::y#37 = PROGRESS_Y [phi:rom_read::@4->gotoxy#0] -- vbum1=vbuc1 - lda #PROGRESS_Y - sta gotoxy.y - // [802] phi gotoxy::x#37 = PROGRESS_X [phi:rom_read::@4->gotoxy#1] -- vbum1=vbuc1 - lda #PROGRESS_X - sta gotoxy.x - jsr gotoxy - // [1625] phi from rom_read::@4 to rom_read::@5 [phi:rom_read::@4->rom_read::@5] - // [1625] phi rom_read::y#11 = PROGRESS_Y [phi:rom_read::@4->rom_read::@5#0] -- vbum1=vbuc1 - lda #PROGRESS_Y - sta y - // [1625] phi rom_read::rom_row_current#10 = 0 [phi:rom_read::@4->rom_read::@5#1] -- vwum1=vwuc1 - lda #<0 - sta rom_row_current - sta rom_row_current+1 - // [1625] phi rom_read::brom_bank_start#11 = rom_read::brom_bank_start#10 [phi:rom_read::@4->rom_read::@5#2] -- register_copy - // [1625] phi rom_read::rom_address#10 = rom_read::rom_address#0 [phi:rom_read::@4->rom_read::@5#3] -- register_copy - // [1625] phi rom_read::rom_bram_ptr#13 = (char *)$7800 [phi:rom_read::@4->rom_read::@5#4] -- pbuz1=pbuc1 - lda #<$7800 - sta.z rom_bram_ptr - lda #>$7800 - sta.z rom_bram_ptr+1 - // [1625] phi rom_read::rom_bram_bank#10 = 0 [phi:rom_read::@4->rom_read::@5#5] -- vbum1=vbuc1 - lda #0 - sta rom_bram_bank - // [1625] phi rom_read::rom_file_size#13 = 0 [phi:rom_read::@4->rom_read::@5#6] -- vdum1=vduc1 - sta rom_file_size - sta rom_file_size+1 - lda #<0>>$10 - sta rom_file_size+2 - lda #>0>>$10 - sta rom_file_size+3 - // rom_read::@5 - __b5: - // while (rom_file_size < rom_size) - // [1626] if(rom_read::rom_file_size#13fclose] - // [2551] phi fclose::stream#3 = fclose::stream#2 [phi:rom_read::@10->fclose#0] -- register_copy - jsr fclose - // [1629] phi from rom_read::@10 to rom_read::@3 [phi:rom_read::@10->rom_read::@3] - // [1629] phi __stdio_filecount#12 = __stdio_filecount#2 [phi:rom_read::@10->rom_read::@3#0] -- register_copy - // [1629] phi rom_read::return#0 = rom_read::rom_file_size#13 [phi:rom_read::@10->rom_read::@3#1] -- register_copy - rts - // [1629] phi from rom_read::@31 to rom_read::@3 [phi:rom_read::@31->rom_read::@3] - __b4: - // [1629] phi __stdio_filecount#12 = __stdio_filecount#1 [phi:rom_read::@31->rom_read::@3#0] -- register_copy - // [1629] phi rom_read::return#0 = 0 [phi:rom_read::@31->rom_read::@3#1] -- vdum1=vduc1 - lda #<0 - sta return - sta return+1 - lda #<0>>$10 - sta return+2 - lda #>0>>$10 - sta return+3 - // rom_read::@3 - // rom_read::@return - // } - // [1630] return - rts - // rom_read::@6 - __b6: - // if(info_status == STATUS_CHECKING) - // [1631] if(rom_read::info_status#11!=STATUS_CHECKING) goto rom_read::@35 -- vbum1_neq_vbuc1_then_la1 - lda #STATUS_CHECKING - cmp info_status - bne __b7 - // [1633] phi from rom_read::@6 to rom_read::@7 [phi:rom_read::@6->rom_read::@7] - // [1633] phi rom_read::rom_bram_ptr#10 = (char *) 1024 [phi:rom_read::@6->rom_read::@7#0] -- pbuz1=pbuc1 - lda #<$400 - sta.z rom_bram_ptr - lda #>$400 - sta.z rom_bram_ptr+1 - // [1632] phi from rom_read::@6 to rom_read::@35 [phi:rom_read::@6->rom_read::@35] - // rom_read::@35 - // [1633] phi from rom_read::@35 to rom_read::@7 [phi:rom_read::@35->rom_read::@7] - // [1633] phi rom_read::rom_bram_ptr#10 = rom_read::rom_bram_ptr#13 [phi:rom_read::@35->rom_read::@7#0] -- register_copy - // rom_read::@7 - __b7: - // display_action_text_reading(rom_action_text, file, rom_file_size, rom_size, rom_bram_bank, rom_bram_ptr) - // [1634] display_action_text_reading::action#2 = rom_read::rom_action_text#10 -- pbuz1=pbuz2 - lda.z rom_action_text - sta.z display_action_text_reading.action - lda.z rom_action_text+1 - sta.z display_action_text_reading.action+1 - // [1635] display_action_text_reading::file#2 = rom_read::file#10 -- pbuz1=pbuz2 - lda.z file - sta.z display_action_text_reading.file - lda.z file+1 - sta.z display_action_text_reading.file+1 - // [1636] display_action_text_reading::bytes#2 = rom_read::rom_file_size#13 -- vdum1=vdum2 - lda rom_file_size - sta display_action_text_reading.bytes - lda rom_file_size+1 - sta display_action_text_reading.bytes+1 - lda rom_file_size+2 - sta display_action_text_reading.bytes+2 - lda rom_file_size+3 - sta display_action_text_reading.bytes+3 - // [1637] display_action_text_reading::size#2 = rom_read::rom_size#12 -- vdum1=vdum2 - lda rom_size - sta display_action_text_reading.size - lda rom_size+1 - sta display_action_text_reading.size+1 - lda rom_size+2 - sta display_action_text_reading.size+2 - lda rom_size+3 - sta display_action_text_reading.size+3 - // [1638] display_action_text_reading::bram_bank#2 = rom_read::rom_bram_bank#10 -- vbum1=vbum2 - lda rom_bram_bank - sta display_action_text_reading.bram_bank - // [1639] display_action_text_reading::bram_ptr#2 = rom_read::rom_bram_ptr#10 -- pbuz1=pbuz2 - lda.z rom_bram_ptr - sta.z display_action_text_reading.bram_ptr - lda.z rom_bram_ptr+1 - sta.z display_action_text_reading.bram_ptr+1 - // [1640] call display_action_text_reading - // [2580] phi from rom_read::@7 to display_action_text_reading [phi:rom_read::@7->display_action_text_reading] - // [2580] phi display_action_text_reading::bram_ptr#10 = display_action_text_reading::bram_ptr#2 [phi:rom_read::@7->display_action_text_reading#0] -- register_copy - // [2580] phi display_action_text_reading::bram_bank#10 = display_action_text_reading::bram_bank#2 [phi:rom_read::@7->display_action_text_reading#1] -- register_copy - // [2580] phi display_action_text_reading::size#10 = display_action_text_reading::size#2 [phi:rom_read::@7->display_action_text_reading#2] -- register_copy - // [2580] phi display_action_text_reading::bytes#3 = display_action_text_reading::bytes#2 [phi:rom_read::@7->display_action_text_reading#3] -- register_copy - // [2580] phi display_action_text_reading::file#3 = display_action_text_reading::file#2 [phi:rom_read::@7->display_action_text_reading#4] -- register_copy - // [2580] phi display_action_text_reading::action#3 = display_action_text_reading::action#2 [phi:rom_read::@7->display_action_text_reading#5] -- register_copy - jsr display_action_text_reading - // rom_read::@32 - // rom_address % 0x04000 - // [1641] rom_read::$13 = rom_read::rom_address#10 & $4000-1 -- vduz1=vdum2_band_vduc1 - lda rom_address - and #<$4000-1 - sta.z rom_read__13 - lda rom_address+1 - and #>$4000-1 - sta.z rom_read__13+1 - lda rom_address+2 - and #<$4000-1>>$10 - sta.z rom_read__13+2 - lda rom_address+3 - and #>$4000-1>>$10 - sta.z rom_read__13+3 - // if (!(rom_address % 0x04000)) - // [1642] if(0!=rom_read::$13) goto rom_read::@8 -- 0_neq_vduz1_then_la1 - lda.z rom_read__13 - ora.z rom_read__13+1 - ora.z rom_read__13+2 - ora.z rom_read__13+3 - bne __b8 - // rom_read::@17 - // brom_bank_start++; - // [1643] rom_read::brom_bank_start#0 = ++ rom_read::brom_bank_start#11 -- vbum1=_inc_vbum1 - inc brom_bank_start - // [1644] phi from rom_read::@17 rom_read::@32 to rom_read::@8 [phi:rom_read::@17/rom_read::@32->rom_read::@8] - // [1644] phi rom_read::brom_bank_start#16 = rom_read::brom_bank_start#0 [phi:rom_read::@17/rom_read::@32->rom_read::@8#0] -- register_copy - // rom_read::@8 - __b8: - // rom_read::bank_set_bram2 - // BRAM = bank - // [1645] BRAM = rom_read::rom_bram_bank#10 -- vbuz1=vbum2 - lda rom_bram_bank - sta.z BRAM - // rom_read::@24 - // unsigned int rom_package_read = fgets(rom_bram_ptr, ROM_PROGRESS_CELL, fp) - // [1646] fgets::ptr#5 = rom_read::rom_bram_ptr#10 -- pbuz1=pbuz2 - lda.z rom_bram_ptr - sta.z fgets.ptr - lda.z rom_bram_ptr+1 - sta.z fgets.ptr+1 - // [1647] fgets::stream#3 = rom_read::fp#0 -- pssz1=pssz2 - lda.z fp - sta.z fgets.stream - lda.z fp+1 - sta.z fgets.stream+1 - // [1648] call fgets - // [2497] phi from rom_read::@24 to fgets [phi:rom_read::@24->fgets] - // [2497] phi fgets::ptr#14 = fgets::ptr#5 [phi:rom_read::@24->fgets#0] -- register_copy - // [2497] phi fgets::size#10 = ROM_PROGRESS_CELL [phi:rom_read::@24->fgets#1] -- vwum1=vwuc1 - lda #ROM_PROGRESS_CELL - sta fgets.size+1 - // [2497] phi fgets::stream#4 = fgets::stream#3 [phi:rom_read::@24->fgets#2] -- register_copy - jsr fgets - // unsigned int rom_package_read = fgets(rom_bram_ptr, ROM_PROGRESS_CELL, fp) - // [1649] fgets::return#13 = fgets::return#1 - // rom_read::@33 - // [1650] rom_read::rom_package_read#0 = fgets::return#13 -- vwum1=vwum2 - lda fgets.return - sta rom_package_read - lda fgets.return+1 - sta rom_package_read+1 - // if (!rom_package_read) - // [1651] if(0!=rom_read::rom_package_read#0) goto rom_read::@9 -- 0_neq_vwum1_then_la1 - lda rom_package_read - ora rom_package_read+1 - bne __b9 - jmp __b10 - // rom_read::@9 - __b9: - // if(info_status == STATUS_CHECKING) - // [1652] if(rom_read::info_status#11!=STATUS_CHECKING) goto rom_read::@11 -- vbum1_neq_vbuc1_then_la1 - lda #STATUS_CHECKING - cmp info_status - bne __b11 - // rom_read::@18 - // if(rom_file_size == 0x0) - // [1653] if(rom_read::rom_file_size#13!=0) goto rom_read::@12 -- vdum1_neq_0_then_la1 - lda rom_file_size - ora rom_file_size+1 - ora rom_file_size+2 - ora rom_file_size+3 - bne __b12 - // rom_read::@19 - // rom_chip*8 - // [1654] rom_read::$24 = rom_read::rom_chip#20 << 3 -- vbuz1=vbum2_rol_3 - lda rom_chip asl + dey + bne !- + !e: + sta.z screenlayer__10 + // (40 << (char)(vera_dc_hscale_temp == 0x80))-1 + // [1144] screenlayer::$11 = screenlayer::$10 - 1 -- vbuz1=vbuz1_minus_1 + dec.z screenlayer__11 + // __conio.width = (40 << (char)(vera_dc_hscale_temp == 0x80))-1 + // [1145] *((char *)&__conio+6) = screenlayer::$11 -- _deref_pbuc1=vbuz1 + lda.z screenlayer__11 + sta __conio+6 + // vera_dc_vscale_temp == 0x80 + // [1146] screenlayer::$12 = screenlayer::vera_dc_vscale_temp#0 == $80 -- vboz1=vbum2_eq_vbuc1 + lda vera_dc_vscale_temp + eor #$80 + beq !+ + lda #1 + !: + eor #1 + sta.z screenlayer__12 + // 30 << (char)(vera_dc_vscale_temp == 0x80) + // [1147] screenlayer::$19 = (char)screenlayer::$12 + // [1148] screenlayer::$13 = $1e << screenlayer::$19 -- vbuz1=vbuc1_rol_vbuz1 + lda #$1e + ldy.z screenlayer__13 + cpy #0 + beq !e+ + !: asl + dey + bne !- + !e: + sta.z screenlayer__13 + // (30 << (char)(vera_dc_vscale_temp == 0x80))-1 + // [1149] screenlayer::$14 = screenlayer::$13 - 1 -- vbuz1=vbuz1_minus_1 + dec.z screenlayer__14 + // __conio.height = (30 << (char)(vera_dc_vscale_temp == 0x80))-1 + // [1150] *((char *)&__conio+7) = screenlayer::$14 -- _deref_pbuc1=vbuz1 + lda.z screenlayer__14 + sta __conio+7 + // unsigned int mapbase_offset = __conio.mapbase_offset + // [1151] screenlayer::mapbase_offset#0 = *((unsigned int *)&__conio+3) -- vwum1=_deref_pwuc1 + lda __conio+3 + sta mapbase_offset + lda __conio+3+1 + sta mapbase_offset+1 + // [1152] phi from screenlayer to screenlayer::@1 [phi:screenlayer->screenlayer::@1] + // [1152] phi screenlayer::mapbase_offset#2 = screenlayer::mapbase_offset#0 [phi:screenlayer->screenlayer::@1#0] -- register_copy + // [1152] phi screenlayer::y#2 = 0 [phi:screenlayer->screenlayer::@1#1] -- vbuz1=vbuc1 + lda #0 + sta.z y + // screenlayer::@1 + __b1: + // for(register char y=0; y<=__conio.height; y++) + // [1153] if(screenlayer::y#2<=*((char *)&__conio+7)) goto screenlayer::@2 -- vbuz1_le__deref_pbuc1_then_la1 + lda __conio+7 + cmp.z y + bcs __b2 + // screenlayer::@return + // } + // [1154] return + rts + // screenlayer::@2 + __b2: + // __conio.offsets[y] = mapbase_offset + // [1155] screenlayer::$17 = screenlayer::y#2 << 1 -- vbuz1=vbuz2_rol_1 + lda.z y asl - sta.z rom_read__24 - // rom_get_github_commit_id(&rom_file_github[rom_chip*8], (char*)0x0400) - // [1655] rom_get_github_commit_id::commit_id#0 = rom_file_github + rom_read::$24 -- pbuz1=pbuc1_plus_vbuz2 + sta.z screenlayer__17 + // [1156] ((unsigned int *)&__conio+$15)[screenlayer::$17] = screenlayer::mapbase_offset#2 -- pwuc1_derefidx_vbuz1=vwum2 + tay + lda mapbase_offset + sta __conio+$15,y + lda mapbase_offset+1 + sta __conio+$15+1,y + // mapbase_offset += __conio.rowskip + // [1157] screenlayer::mapbase_offset#1 = screenlayer::mapbase_offset#2 + *((unsigned int *)&__conio+$a) -- vwum1=vwum1_plus__deref_pwuc1 clc - adc #rom_file_github - adc #0 - sta.z rom_get_github_commit_id.commit_id+1 - // [1656] call rom_get_github_commit_id - // [2069] phi from rom_read::@19 to rom_get_github_commit_id [phi:rom_read::@19->rom_get_github_commit_id] - // [2069] phi rom_get_github_commit_id::commit_id#6 = rom_get_github_commit_id::commit_id#0 [phi:rom_read::@19->rom_get_github_commit_id#0] -- register_copy - // [2069] phi rom_get_github_commit_id::from#6 = (char *) 1024 [phi:rom_read::@19->rom_get_github_commit_id#1] -- pbuz1=pbuc1 - lda #<$400 - sta.z rom_get_github_commit_id.from - lda #>$400 - sta.z rom_get_github_commit_id.from+1 - jsr rom_get_github_commit_id - // rom_read::@12 - __b12: - // if(rom_file_size == 0x3E00) - // [1657] if(rom_read::rom_file_size#13!=$3e00) goto rom_read::@11 -- vdum1_neq_vduc1_then_la1 - lda rom_file_size+3 - cmp #>$3e00>>$10 - bne __b11 - lda rom_file_size+2 - cmp #<$3e00>>$10 - bne __b11 - lda rom_file_size+1 - cmp #>$3e00 - bne __b11 - lda rom_file_size - cmp #<$3e00 - bne __b11 - // rom_read::@13 - // rom_file_release[rom_chip] = *((char*)(0x0400+0x0180)) - // [1658] rom_file_release[rom_read::rom_chip#20] = *((char *)$400+$180) -- pbuc1_derefidx_vbum1=_deref_pbuc2 - lda $400+$180 - ldy rom_chip - sta rom_file_release,y - // rom_read::@11 - __b11: - // if (rom_row_current == ROM_PROGRESS_ROW) - // [1659] if(rom_read::rom_row_current#10!=ROM_PROGRESS_ROW) goto rom_read::@14 -- vwum1_neq_vwuc1_then_la1 - lda rom_row_current+1 - cmp #>ROM_PROGRESS_ROW - bne __b14 - lda rom_row_current - cmp #gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#32 [phi:rom_read::@20->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = PROGRESS_X [phi:rom_read::@20->gotoxy#1] -- vbum1=vbuc1 - lda #PROGRESS_X - sta gotoxy.x - jsr gotoxy - // [1663] phi from rom_read::@20 to rom_read::@14 [phi:rom_read::@20->rom_read::@14] - // [1663] phi rom_read::y#33 = rom_read::y#1 [phi:rom_read::@20->rom_read::@14#0] -- register_copy - // [1663] phi rom_read::rom_row_current#4 = 0 [phi:rom_read::@20->rom_read::@14#1] -- vwum1=vbuc1 - lda #<0 - sta rom_row_current - sta rom_row_current+1 - // [1663] phi from rom_read::@11 to rom_read::@14 [phi:rom_read::@11->rom_read::@14] - // [1663] phi rom_read::y#33 = rom_read::y#11 [phi:rom_read::@11->rom_read::@14#0] -- register_copy - // [1663] phi rom_read::rom_row_current#4 = rom_read::rom_row_current#10 [phi:rom_read::@11->rom_read::@14#1] -- register_copy - // rom_read::@14 - __b14: - // if(info_status == STATUS_READING) - // [1664] if(rom_read::info_status#11!=STATUS_READING) goto rom_read::@15 -- vbum1_neq_vbuc1_then_la1 - lda #STATUS_READING - cmp info_status - bne __b15 - // rom_read::@21 - // cputc('.') - // [1665] stackpush(char) = '.' -- _stackpushbyte_=vbuc1 - lda #'.' - pha - // [1666] callexecute cputc -- call_vprc1 - jsr cputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // rom_read::@15 - __b15: - // rom_bram_ptr += rom_package_read - // [1668] rom_read::rom_bram_ptr#2 = rom_read::rom_bram_ptr#10 + rom_read::rom_package_read#0 -- pbuz1=pbuz1_plus_vwum2 - clc - lda.z rom_bram_ptr - adc rom_package_read - sta.z rom_bram_ptr - lda.z rom_bram_ptr+1 - adc rom_package_read+1 - sta.z rom_bram_ptr+1 - // rom_address += rom_package_read - // [1669] rom_read::rom_address#1 = rom_read::rom_address#10 + rom_read::rom_package_read#0 -- vdum1=vdum1_plus_vwum2 - lda rom_address - clc - adc rom_package_read - sta rom_address - lda rom_address+1 - adc rom_package_read+1 - sta rom_address+1 - lda rom_address+2 - adc #0 - sta rom_address+2 - lda rom_address+3 - adc #0 - sta rom_address+3 - // rom_file_size += rom_package_read - // [1670] rom_read::rom_file_size#1 = rom_read::rom_file_size#13 + rom_read::rom_package_read#0 -- vdum1=vdum1_plus_vwum2 - lda rom_file_size - clc - adc rom_package_read - sta rom_file_size - lda rom_file_size+1 - adc rom_package_read+1 - sta rom_file_size+1 - lda rom_file_size+2 - adc #0 - sta rom_file_size+2 - lda rom_file_size+3 - adc #0 - sta rom_file_size+3 - // rom_row_current += rom_package_read - // [1671] rom_read::rom_row_current#2 = rom_read::rom_row_current#4 + rom_read::rom_package_read#0 -- vwum1=vwum1_plus_vwum2 - clc - lda rom_row_current - adc rom_package_read - sta rom_row_current - lda rom_row_current+1 - adc rom_package_read+1 - sta rom_row_current+1 - // if (rom_bram_ptr == (bram_ptr_t)BRAM_HIGH) - // [1672] if(rom_read::rom_bram_ptr#2!=(char *)$c000) goto rom_read::@16 -- pbuz1_neq_pbuc1_then_la1 - lda.z rom_bram_ptr+1 - cmp #>$c000 - bne __b16 - lda.z rom_bram_ptr - cmp #<$c000 - bne __b16 - // rom_read::@22 - // rom_bram_bank++; - // [1673] rom_read::rom_bram_bank#1 = ++ rom_read::rom_bram_bank#10 -- vbum1=_inc_vbum1 - inc rom_bram_bank - // [1674] phi from rom_read::@22 to rom_read::@16 [phi:rom_read::@22->rom_read::@16] - // [1674] phi rom_read::rom_bram_bank#14 = rom_read::rom_bram_bank#1 [phi:rom_read::@22->rom_read::@16#0] -- register_copy - // [1674] phi rom_read::rom_bram_ptr#8 = (char *)$a000 [phi:rom_read::@22->rom_read::@16#1] -- pbuz1=pbuc1 - lda #<$a000 - sta.z rom_bram_ptr - lda #>$a000 - sta.z rom_bram_ptr+1 - // [1674] phi from rom_read::@15 to rom_read::@16 [phi:rom_read::@15->rom_read::@16] - // [1674] phi rom_read::rom_bram_bank#14 = rom_read::rom_bram_bank#10 [phi:rom_read::@15->rom_read::@16#0] -- register_copy - // [1674] phi rom_read::rom_bram_ptr#8 = rom_read::rom_bram_ptr#2 [phi:rom_read::@15->rom_read::@16#1] -- register_copy - // rom_read::@16 - __b16: - // if (rom_bram_ptr == (bram_ptr_t)RAM_HIGH) - // [1675] if(rom_read::rom_bram_ptr#8!=(char *)$9800) goto rom_read::@34 -- pbuz1_neq_pbuc1_then_la1 - lda.z rom_bram_ptr+1 - cmp #>$9800 - beq !__b5+ - jmp __b5 - !__b5: - lda.z rom_bram_ptr - cmp #<$9800 - beq !__b5+ - jmp __b5 - !__b5: - // [1625] phi from rom_read::@16 to rom_read::@5 [phi:rom_read::@16->rom_read::@5] - // [1625] phi rom_read::y#11 = rom_read::y#33 [phi:rom_read::@16->rom_read::@5#0] -- register_copy - // [1625] phi rom_read::rom_row_current#10 = rom_read::rom_row_current#2 [phi:rom_read::@16->rom_read::@5#1] -- register_copy - // [1625] phi rom_read::brom_bank_start#11 = rom_read::brom_bank_start#16 [phi:rom_read::@16->rom_read::@5#2] -- register_copy - // [1625] phi rom_read::rom_address#10 = rom_read::rom_address#1 [phi:rom_read::@16->rom_read::@5#3] -- register_copy - // [1625] phi rom_read::rom_bram_ptr#13 = (char *)$a000 [phi:rom_read::@16->rom_read::@5#4] -- pbuz1=pbuc1 - lda #<$a000 - sta.z rom_bram_ptr - lda #>$a000 - sta.z rom_bram_ptr+1 - // [1625] phi rom_read::rom_bram_bank#10 = 1 [phi:rom_read::@16->rom_read::@5#5] -- vbum1=vbuc1 - lda #1 - sta rom_bram_bank - // [1625] phi rom_read::rom_file_size#13 = rom_read::rom_file_size#1 [phi:rom_read::@16->rom_read::@5#6] -- register_copy - jmp __b5 - // [1676] phi from rom_read::@16 to rom_read::@34 [phi:rom_read::@16->rom_read::@34] - // rom_read::@34 - // [1625] phi from rom_read::@34 to rom_read::@5 [phi:rom_read::@34->rom_read::@5] - // [1625] phi rom_read::y#11 = rom_read::y#33 [phi:rom_read::@34->rom_read::@5#0] -- register_copy - // [1625] phi rom_read::rom_row_current#10 = rom_read::rom_row_current#2 [phi:rom_read::@34->rom_read::@5#1] -- register_copy - // [1625] phi rom_read::brom_bank_start#11 = rom_read::brom_bank_start#16 [phi:rom_read::@34->rom_read::@5#2] -- register_copy - // [1625] phi rom_read::rom_address#10 = rom_read::rom_address#1 [phi:rom_read::@34->rom_read::@5#3] -- register_copy - // [1625] phi rom_read::rom_bram_ptr#13 = rom_read::rom_bram_ptr#8 [phi:rom_read::@34->rom_read::@5#4] -- register_copy - // [1625] phi rom_read::rom_bram_bank#10 = rom_read::rom_bram_bank#14 [phi:rom_read::@34->rom_read::@5#5] -- register_copy - // [1625] phi rom_read::rom_file_size#13 = rom_read::rom_file_size#1 [phi:rom_read::@34->rom_read::@5#6] -- register_copy + lda mapbase_offset + adc __conio+$a + sta mapbase_offset + lda mapbase_offset+1 + adc __conio+$a+1 + sta mapbase_offset+1 + // for(register char y=0; y<=__conio.height; y++) + // [1158] screenlayer::y#1 = ++ screenlayer::y#2 -- vbuz1=_inc_vbuz1 + inc.z y + // [1152] phi from screenlayer::@2 to screenlayer::@1 [phi:screenlayer::@2->screenlayer::@1] + // [1152] phi screenlayer::mapbase_offset#2 = screenlayer::mapbase_offset#1 [phi:screenlayer::@2->screenlayer::@1#0] -- register_copy + // [1152] phi screenlayer::y#2 = screenlayer::y#1 [phi:screenlayer::@2->screenlayer::@1#1] -- register_copy + jmp __b1 .segment Data - s: .text "Opening " - .byte 0 - s1: .text " from SD card ..." - .byte 0 - rom_address: .dword 0 - return: .dword 0 - rom_package_read: .word 0 - brom_bank_start: .byte 0 - y: .byte 0 - .label rom_file_size = return - /// Holds the amount of bytes actually read in the memory to be flashed. - rom_row_current: .word 0 - // We start for ROM from 0x0:0x7800 !!!! - rom_bram_bank: .byte 0 - rom_chip: .byte 0 - rom_size: .dword 0 - info_status: .byte 0 + VERA_LAYER_DIM: .byte $1f, $3f, $7f, $ff + VERA_LAYER_SKIP: .word $40, $80, $100, $200 + mapbase: .byte 0 + config: .byte 0 + vera_dc_hscale_temp: .byte 0 + vera_dc_vscale_temp: .byte 0 + mapbase_offset: .word 0 } .segment Code - // rom_verify -// __mem() unsigned long rom_verify(__mem() char rom_chip, __mem() char rom_bank_start, __mem() unsigned long file_size) -rom_verify: { - .label rom_verify__17 = $70 - .label rom_bram_ptr = $47 - // rom_verify::bank_set_bram1 - // BRAM = bank - // [1678] BRAM = 0 -- vbuz1=vbuc1 + // cscroll +// Scroll the entire screen if the cursor is beyond the last line +cscroll: { + // if(__conio.cursor_y>__conio.height) + // [1159] if(*((char *)&__conio+1)<=*((char *)&__conio+7)) goto cscroll::@return -- _deref_pbuc1_le__deref_pbuc2_then_la1 + lda __conio+7 + cmp __conio+1 + bcs __breturn + // cscroll::@1 + // if(__conio.scroll[__conio.layer]) + // [1160] if(0!=((char *)&__conio+$f)[*((char *)&__conio+2)]) goto cscroll::@4 -- 0_neq_pbuc1_derefidx_(_deref_pbuc2)_then_la1 + ldy __conio+2 + lda __conio+$f,y + cmp #0 + bne __b4 + // cscroll::@2 + // if(__conio.cursor_y>__conio.height) + // [1161] if(*((char *)&__conio+1)<=*((char *)&__conio+7)) goto cscroll::@return -- _deref_pbuc1_le__deref_pbuc2_then_la1 + lda __conio+7 + cmp __conio+1 + bcs __breturn + // [1162] phi from cscroll::@2 to cscroll::@3 [phi:cscroll::@2->cscroll::@3] + // cscroll::@3 + // gotoxy(0,0) + // [1163] call gotoxy + // [457] phi from cscroll::@3 to gotoxy [phi:cscroll::@3->gotoxy] + // [457] phi gotoxy::y#26 = 0 [phi:cscroll::@3->gotoxy#0] -- vbum1=vbuc1 lda #0 - sta.z BRAM - // rom_verify::@11 - // unsigned long rom_address = rom_address_from_bank(rom_bank_start) - // [1679] rom_address_from_bank::rom_bank#1 = rom_verify::rom_bank_start#0 - // [1680] call rom_address_from_bank - // [2866] phi from rom_verify::@11 to rom_address_from_bank [phi:rom_verify::@11->rom_address_from_bank] - // [2866] phi rom_address_from_bank::rom_bank#3 = rom_address_from_bank::rom_bank#1 [phi:rom_verify::@11->rom_address_from_bank#0] -- register_copy - jsr rom_address_from_bank - // unsigned long rom_address = rom_address_from_bank(rom_bank_start) - // [1681] rom_address_from_bank::return#3 = rom_address_from_bank::return#0 -- vdum1=vdum2 - lda rom_address_from_bank.return - sta rom_address_from_bank.return_1 - lda rom_address_from_bank.return+1 - sta rom_address_from_bank.return_1+1 - lda rom_address_from_bank.return+2 - sta rom_address_from_bank.return_1+2 - lda rom_address_from_bank.return+3 - sta rom_address_from_bank.return_1+3 - // rom_verify::@12 - // [1682] rom_verify::rom_address#0 = rom_address_from_bank::return#3 - // unsigned long rom_boundary = rom_address + file_size - // [1683] rom_verify::rom_boundary#0 = rom_verify::rom_address#0 + rom_verify::file_size#0 -- vdum1=vdum2_plus_vdum1 - clc - lda rom_boundary - adc rom_address - sta rom_boundary - lda rom_boundary+1 - adc rom_address+1 - sta rom_boundary+1 - lda rom_boundary+2 - adc rom_address+2 - sta rom_boundary+2 - lda rom_boundary+3 - adc rom_address+3 - sta rom_boundary+3 - // display_info_rom(rom_chip, STATUS_COMPARING, "Comparing ...") - // [1684] display_info_rom::rom_chip#1 = rom_verify::rom_chip#0 - // [1685] call display_info_rom - // [1546] phi from rom_verify::@12 to display_info_rom [phi:rom_verify::@12->display_info_rom] - // [1546] phi display_info_rom::info_text#17 = rom_verify::info_text [phi:rom_verify::@12->display_info_rom#0] -- pbuz1=pbuc1 - lda #info_text - sta.z display_info_rom.info_text+1 - // [1546] phi display_info_rom::rom_chip#17 = display_info_rom::rom_chip#1 [phi:rom_verify::@12->display_info_rom#1] -- register_copy - // [1546] phi display_info_rom::info_status#17 = STATUS_COMPARING [phi:rom_verify::@12->display_info_rom#2] -- vbum1=vbuc1 - lda #STATUS_COMPARING - sta display_info_rom.info_status - jsr display_info_rom - // [1686] phi from rom_verify::@12 to rom_verify::@13 [phi:rom_verify::@12->rom_verify::@13] - // rom_verify::@13 - // gotoxy(x, y) - // [1687] call gotoxy - // [802] phi from rom_verify::@13 to gotoxy [phi:rom_verify::@13->gotoxy] - // [802] phi gotoxy::y#37 = PROGRESS_Y [phi:rom_verify::@13->gotoxy#0] -- vbum1=vbuc1 - lda #PROGRESS_Y sta gotoxy.y - // [802] phi gotoxy::x#37 = PROGRESS_X [phi:rom_verify::@13->gotoxy#1] -- vbum1=vbuc1 - lda #PROGRESS_X + // [457] phi gotoxy::x#26 = 0 [phi:cscroll::@3->gotoxy#1] -- vbum1=vbuc1 sta gotoxy.x jsr gotoxy - // [1688] phi from rom_verify::@13 to rom_verify::@1 [phi:rom_verify::@13->rom_verify::@1] - // [1688] phi rom_verify::y#3 = PROGRESS_Y [phi:rom_verify::@13->rom_verify::@1#0] -- vbum1=vbuc1 - lda #PROGRESS_Y - sta y - // [1688] phi rom_verify::progress_row_current#3 = 0 [phi:rom_verify::@13->rom_verify::@1#1] -- vwum1=vwuc1 - lda #<0 - sta progress_row_current - sta progress_row_current+1 - // [1688] phi rom_verify::rom_different_bytes#11 = 0 [phi:rom_verify::@13->rom_verify::@1#2] -- vdum1=vduc1 - sta rom_different_bytes - sta rom_different_bytes+1 - lda #<0>>$10 - sta rom_different_bytes+2 - lda #>0>>$10 - sta rom_different_bytes+3 - // [1688] phi rom_verify::rom_bram_ptr#10 = (char *)$7800 [phi:rom_verify::@13->rom_verify::@1#3] -- pbuz1=pbuc1 - lda #<$7800 - sta.z rom_bram_ptr - lda #>$7800 - sta.z rom_bram_ptr+1 - // [1688] phi rom_verify::rom_bram_bank#11 = 0 [phi:rom_verify::@13->rom_verify::@1#4] -- vbum1=vbuc1 - lda #0 - sta rom_bram_bank - // [1688] phi rom_verify::rom_address#12 = rom_verify::rom_address#0 [phi:rom_verify::@13->rom_verify::@1#5] -- register_copy - // rom_verify::@1 - __b1: - // while (rom_address < rom_boundary) - // [1689] if(rom_verify::rom_address#12rom_compare] - // [2870] phi rom_compare::ptr_ram#10 = rom_compare::ptr_ram#1 [phi:rom_verify::@2->rom_compare#0] -- register_copy - // [2870] phi rom_compare::rom_compare_size#11 = ROM_PROGRESS_CELL [phi:rom_verify::@2->rom_compare#1] -- vwum1=vwuc1 - lda #ROM_PROGRESS_CELL - sta rom_compare.rom_compare_size+1 - // [2870] phi rom_compare::rom_compare_address#3 = rom_compare::rom_compare_address#0 [phi:rom_verify::@2->rom_compare#2] -- register_copy - // [2870] phi rom_compare::bank_set_bram1_bank#0 = rom_compare::bank_ram#0 [phi:rom_verify::@2->rom_compare#3] -- register_copy - jsr rom_compare - // unsigned int equal_bytes = rom_compare(rom_bram_bank, (bram_ptr_t)rom_bram_ptr, rom_address, ROM_PROGRESS_CELL) - // [1695] rom_compare::return#2 = rom_compare::equal_bytes#2 - // rom_verify::@14 - // [1696] rom_verify::equal_bytes#0 = rom_compare::return#2 - // if (progress_row_current == ROM_PROGRESS_ROW) - // [1697] if(rom_verify::progress_row_current#3!=ROM_PROGRESS_ROW) goto rom_verify::@3 -- vwum1_neq_vwuc1_then_la1 - lda progress_row_current+1 - cmp #>ROM_PROGRESS_ROW - bne __b3 - lda progress_row_current - cmp #cscroll::@4] + // cscroll::@4 + __b4: + // insertup(1) + // [1166] call insertup + jsr insertup + // cscroll::@5 + // gotoxy( 0, __conio.height) + // [1167] gotoxy::y#3 = *((char *)&__conio+7) -- vbum1=_deref_pbuc1 + lda __conio+7 sta gotoxy.y - // [1700] call gotoxy - // [802] phi from rom_verify::@8 to gotoxy [phi:rom_verify::@8->gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#34 [phi:rom_verify::@8->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = PROGRESS_X [phi:rom_verify::@8->gotoxy#1] -- vbum1=vbuc1 - lda #PROGRESS_X + // [1168] call gotoxy + // [457] phi from cscroll::@5 to gotoxy [phi:cscroll::@5->gotoxy] + // [457] phi gotoxy::y#26 = gotoxy::y#3 [phi:cscroll::@5->gotoxy#0] -- register_copy + // [457] phi gotoxy::x#26 = 0 [phi:cscroll::@5->gotoxy#1] -- vbum1=vbuc1 + lda #0 sta gotoxy.x jsr gotoxy - // [1701] phi from rom_verify::@8 to rom_verify::@3 [phi:rom_verify::@8->rom_verify::@3] - // [1701] phi rom_verify::y#11 = rom_verify::y#1 [phi:rom_verify::@8->rom_verify::@3#0] -- register_copy - // [1701] phi rom_verify::progress_row_current#4 = 0 [phi:rom_verify::@8->rom_verify::@3#1] -- vwum1=vbuc1 - lda #<0 - sta progress_row_current - sta progress_row_current+1 - // [1701] phi from rom_verify::@14 to rom_verify::@3 [phi:rom_verify::@14->rom_verify::@3] - // [1701] phi rom_verify::y#11 = rom_verify::y#3 [phi:rom_verify::@14->rom_verify::@3#0] -- register_copy - // [1701] phi rom_verify::progress_row_current#4 = rom_verify::progress_row_current#3 [phi:rom_verify::@14->rom_verify::@3#1] -- register_copy - // rom_verify::@3 - __b3: - // if (equal_bytes != ROM_PROGRESS_CELL) - // [1702] if(rom_verify::equal_bytes#0!=ROM_PROGRESS_CELL) goto rom_verify::@4 -- vwum1_neq_vwuc1_then_la1 - lda equal_bytes+1 - cmp #>ROM_PROGRESS_CELL - beq !__b4+ - jmp __b4 - !__b4: - lda equal_bytes - cmp #printf_number_buffer] - // [2706] phi printf_number_buffer::putc#10 = &snputc [phi:printf_ulong::@2->printf_number_buffer#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_number_buffer.putc+1 - // [2706] phi printf_number_buffer::buffer_sign#10 = printf_number_buffer::buffer_sign#0 [phi:printf_ulong::@2->printf_number_buffer#1] -- register_copy - // [2706] phi printf_number_buffer::format_zero_padding#10 = printf_number_buffer::format_zero_padding#0 [phi:printf_ulong::@2->printf_number_buffer#2] -- register_copy - // [2706] phi printf_number_buffer::format_min_length#3 = printf_number_buffer::format_min_length#0 [phi:printf_ulong::@2->printf_number_buffer#3] -- register_copy - jsr printf_number_buffer - // printf_ulong::@return - // } - // [1750] return - rts - .segment Data - uvalue: .dword 0 - format_radix: .byte 0 - .label format_min_length = printf_uchar.format_min_length - .label format_zero_padding = printf_uchar.format_zero_padding -} -.segment Code - // rom_flash -// __mem() unsigned long rom_flash(__mem() char rom_chip, __mem() char rom_bank_start, __mem() unsigned long file_size) -rom_flash: { - .label rom_flash__29 = $74 - .label ram_address_sector = $7b - .label ram_address = $5a - // rom_flash::bank_set_bram1 - // BRAM = bank - // [1752] BRAM = 0 -- vbuz1=vbuc1 - lda #0 - sta.z BRAM - // [1753] phi from rom_flash::bank_set_bram1 to rom_flash::@19 [phi:rom_flash::bank_set_bram1->rom_flash::@19] - // rom_flash::@19 - // display_action_progress("Flashing ... (-) equal, (+) flashed, (!) error.") - // [1754] call display_action_progress - // Now we compare the RAM with the actual ROM contents. - // [904] phi from rom_flash::@19 to display_action_progress [phi:rom_flash::@19->display_action_progress] - // [904] phi display_action_progress::info_text#27 = string_0 [phi:rom_flash::@19->display_action_progress#0] -- pbuz1=pbuc1 - lda #string_0 - sta.z display_action_progress.info_text+1 - jsr display_action_progress - // rom_flash::@20 - // unsigned long rom_address_sector = rom_address_from_bank(rom_bank_start) - // [1755] rom_address_from_bank::rom_bank#2 = rom_flash::rom_bank_start#0 - // [1756] call rom_address_from_bank - // [2866] phi from rom_flash::@20 to rom_address_from_bank [phi:rom_flash::@20->rom_address_from_bank] - // [2866] phi rom_address_from_bank::rom_bank#3 = rom_address_from_bank::rom_bank#2 [phi:rom_flash::@20->rom_address_from_bank#0] -- register_copy - jsr rom_address_from_bank - // unsigned long rom_address_sector = rom_address_from_bank(rom_bank_start) - // [1757] rom_address_from_bank::return#4 = rom_address_from_bank::return#0 -- vdum1=vdum2 - lda rom_address_from_bank.return - sta rom_address_from_bank.return_2 - lda rom_address_from_bank.return+1 - sta rom_address_from_bank.return_2+1 - lda rom_address_from_bank.return+2 - sta rom_address_from_bank.return_2+2 - lda rom_address_from_bank.return+3 - sta rom_address_from_bank.return_2+3 - // rom_flash::@21 - // [1758] rom_flash::rom_address_sector#0 = rom_address_from_bank::return#4 - // unsigned long rom_boundary = rom_address_sector + file_size - // [1759] rom_flash::rom_boundary#0 = rom_flash::rom_address_sector#0 + rom_flash::file_size#0 -- vdum1=vdum2_plus_vdum3 - lda rom_address_sector - clc - adc file_size - sta rom_boundary - lda rom_address_sector+1 - adc file_size+1 - sta rom_boundary+1 - lda rom_address_sector+2 - adc file_size+2 - sta rom_boundary+2 - lda rom_address_sector+3 - adc file_size+3 - sta rom_boundary+3 - // display_info_rom(rom_chip, STATUS_FLASHING, "Flashing ...") - // [1760] display_info_rom::rom_chip#2 = rom_flash::rom_chip#0 -- vbum1=vbum2 - lda rom_chip - sta display_info_rom.rom_chip - // [1761] call display_info_rom - // [1546] phi from rom_flash::@21 to display_info_rom [phi:rom_flash::@21->display_info_rom] - // [1546] phi display_info_rom::info_text#17 = info_text1 [phi:rom_flash::@21->display_info_rom#0] -- pbuz1=pbuc1 - lda #info_text1 - sta.z display_info_rom.info_text+1 - // [1546] phi display_info_rom::rom_chip#17 = display_info_rom::rom_chip#2 [phi:rom_flash::@21->display_info_rom#1] -- register_copy - // [1546] phi display_info_rom::info_status#17 = STATUS_FLASHING [phi:rom_flash::@21->display_info_rom#2] -- vbum1=vbuc1 - lda #STATUS_FLASHING - sta display_info_rom.info_status - jsr display_info_rom - // [1762] phi from rom_flash::@21 to rom_flash::@1 [phi:rom_flash::@21->rom_flash::@1] - // [1762] phi rom_flash::flash_errors#12 = 0 [phi:rom_flash::@21->rom_flash::@1#0] -- vdum1=vduc1 - lda #<0 - sta flash_errors - sta flash_errors+1 - lda #<0>>$10 - sta flash_errors+2 - lda #>0>>$10 - sta flash_errors+3 - // [1762] phi rom_flash::y_sector#13 = PROGRESS_Y [phi:rom_flash::@21->rom_flash::@1#1] -- vbum1=vbuc1 - lda #PROGRESS_Y - sta y_sector - // [1762] phi rom_flash::x_sector#10 = PROGRESS_X [phi:rom_flash::@21->rom_flash::@1#2] -- vbum1=vbuc1 - lda #PROGRESS_X - sta x_sector - // [1762] phi rom_flash::ram_address_sector#11 = (char *)$7800 [phi:rom_flash::@21->rom_flash::@1#3] -- pbuz1=pbuc1 - lda #<$7800 - sta.z ram_address_sector - lda #>$7800 - sta.z ram_address_sector+1 - // [1762] phi rom_flash::bram_bank_sector#14 = 0 [phi:rom_flash::@21->rom_flash::@1#4] -- vbum1=vbuc1 - lda #0 - sta bram_bank_sector - // [1762] phi rom_flash::rom_address_sector#13 = rom_flash::rom_address_sector#0 [phi:rom_flash::@21->rom_flash::@1#5] -- register_copy - // rom_flash::@1 + !__b5: + // [1195] phi from display_frame::@36 display_frame::@4 to display_frame::@1 [phi:display_frame::@36/display_frame::@4->display_frame::@1] + // [1195] phi display_frame::x#24 = display_frame::x#30 [phi:display_frame::@36/display_frame::@4->display_frame::@1#0] -- register_copy + // display_frame::@1 __b1: - // while (rom_address_sector < rom_boundary) - // [1763] if(rom_flash::rom_address_sector#13display_action_text_flashed] - // [2926] phi display_action_text_flashed::chip#3 = chip [phi:rom_flash::@3->display_action_text_flashed#0] -- pbuz1=pbuc1 - lda #chip - sta.z display_action_text_flashed.chip+1 - // [2926] phi display_action_text_flashed::bytes#3 = display_action_text_flashed::bytes#2 [phi:rom_flash::@3->display_action_text_flashed#1] -- register_copy - jsr display_action_text_flashed - // [1766] phi from rom_flash::@3 to rom_flash::@23 [phi:rom_flash::@3->rom_flash::@23] - // rom_flash::@23 - // wait_moment(32) - // [1767] call wait_moment - // [1310] phi from rom_flash::@23 to wait_moment [phi:rom_flash::@23->wait_moment] - // [1310] phi wait_moment::w#13 = $20 [phi:rom_flash::@23->wait_moment#0] -- vbum1=vbuc1 - lda #$20 - sta wait_moment.w - jsr wait_moment - // rom_flash::@return - // } - // [1768] return - rts - // rom_flash::@2 - __b2: - // unsigned int equal_bytes = rom_compare(bram_bank_sector, (bram_ptr_t)ram_address_sector, rom_address_sector, ROM_SECTOR) - // [1769] rom_compare::bank_ram#1 = rom_flash::bram_bank_sector#14 -- vbum1=vbum2 - lda bram_bank_sector - sta rom_compare.bank_ram - // [1770] rom_compare::ptr_ram#2 = rom_flash::ram_address_sector#11 -- pbuz1=pbuz2 - lda.z ram_address_sector - sta.z rom_compare.ptr_ram - lda.z ram_address_sector+1 - sta.z rom_compare.ptr_ram+1 - // [1771] rom_compare::rom_compare_address#1 = rom_flash::rom_address_sector#13 -- vdum1=vdum2 - lda rom_address_sector - sta rom_compare.rom_compare_address - lda rom_address_sector+1 - sta rom_compare.rom_compare_address+1 - lda rom_address_sector+2 - sta rom_compare.rom_compare_address+2 - lda rom_address_sector+3 - sta rom_compare.rom_compare_address+3 - // [1772] call rom_compare - // {asm{.byte $db}} - // [2870] phi from rom_flash::@2 to rom_compare [phi:rom_flash::@2->rom_compare] - // [2870] phi rom_compare::ptr_ram#10 = rom_compare::ptr_ram#2 [phi:rom_flash::@2->rom_compare#0] -- register_copy - // [2870] phi rom_compare::rom_compare_size#11 = $1000 [phi:rom_flash::@2->rom_compare#1] -- vwum1=vwuc1 - lda #<$1000 - sta rom_compare.rom_compare_size - lda #>$1000 - sta rom_compare.rom_compare_size+1 - // [2870] phi rom_compare::rom_compare_address#3 = rom_compare::rom_compare_address#1 [phi:rom_flash::@2->rom_compare#2] -- register_copy - // [2870] phi rom_compare::bank_set_bram1_bank#0 = rom_compare::bank_ram#1 [phi:rom_flash::@2->rom_compare#3] -- register_copy - jsr rom_compare - // unsigned int equal_bytes = rom_compare(bram_bank_sector, (bram_ptr_t)ram_address_sector, rom_address_sector, ROM_SECTOR) - // [1773] rom_compare::return#3 = rom_compare::equal_bytes#2 - // rom_flash::@22 - // [1774] rom_flash::equal_bytes#0 = rom_compare::return#3 - // if (equal_bytes != ROM_SECTOR) - // [1775] if(rom_flash::equal_bytes#0!=$1000) goto rom_flash::@5 -- vwum1_neq_vwuc1_then_la1 - lda equal_bytes+1 - cmp #>$1000 - beq !__b3+ - jmp __b3 - !__b3: - lda equal_bytes - cmp #<$1000 - beq !__b3+ - jmp __b3 - !__b3: - // rom_flash::@16 - // cputsxy(x_sector, y_sector, "--------") - // [1776] cputsxy::x#1 = rom_flash::x_sector#10 -- vbum1=vbum2 - lda x_sector - sta cputsxy.x - // [1777] cputsxy::y#1 = rom_flash::y_sector#13 -- vbum1=vbum2 - lda y_sector - sta cputsxy.y - // [1778] call cputsxy - // [897] phi from rom_flash::@16 to cputsxy [phi:rom_flash::@16->cputsxy] - // [897] phi cputsxy::s#4 = rom_flash::s [phi:rom_flash::@16->cputsxy#0] -- pbuz1=pbuc1 - lda #s - sta.z cputsxy.s+1 - // [897] phi cputsxy::y#4 = cputsxy::y#1 [phi:rom_flash::@16->cputsxy#1] -- register_copy - // [897] phi cputsxy::x#4 = cputsxy::x#1 [phi:rom_flash::@16->cputsxy#2] -- register_copy - jsr cputsxy - // [1779] phi from rom_flash::@12 rom_flash::@16 to rom_flash::@4 [phi:rom_flash::@12/rom_flash::@16->rom_flash::@4] - // [1779] phi rom_flash::flash_errors#10 = rom_flash::flash_errors#1 [phi:rom_flash::@12/rom_flash::@16->rom_flash::@4#0] -- register_copy - // rom_flash::@4 - __b4: - // ram_address_sector += ROM_SECTOR - // [1780] rom_flash::ram_address_sector#1 = rom_flash::ram_address_sector#11 + $1000 -- pbuz1=pbuz1_plus_vwuc1 - lda.z ram_address_sector - clc - adc #<$1000 - sta.z ram_address_sector - lda.z ram_address_sector+1 - adc #>$1000 - sta.z ram_address_sector+1 - // rom_address_sector += ROM_SECTOR - // [1781] rom_flash::rom_address_sector#1 = rom_flash::rom_address_sector#13 + $1000 -- vdum1=vdum1_plus_vwuc1 - clc - lda rom_address_sector - adc #<$1000 - sta rom_address_sector - lda rom_address_sector+1 - adc #>$1000 - sta rom_address_sector+1 - lda rom_address_sector+2 - adc #0 - sta rom_address_sector+2 - lda rom_address_sector+3 - adc #0 - sta rom_address_sector+3 - // if (ram_address_sector == BRAM_HIGH) - // [1782] if(rom_flash::ram_address_sector#1!=$c000) goto rom_flash::@13 -- pbuz1_neq_vwuc1_then_la1 - lda.z ram_address_sector+1 - cmp #>$c000 - bne __b13 - lda.z ram_address_sector - cmp #<$c000 - bne __b13 - // rom_flash::@17 - // bram_bank_sector++; - // [1783] rom_flash::bram_bank_sector#1 = ++ rom_flash::bram_bank_sector#14 -- vbum1=_inc_vbum1 - inc bram_bank_sector - // [1784] phi from rom_flash::@17 to rom_flash::@13 [phi:rom_flash::@17->rom_flash::@13] - // [1784] phi rom_flash::bram_bank_sector#40 = rom_flash::bram_bank_sector#1 [phi:rom_flash::@17->rom_flash::@13#0] -- register_copy - // [1784] phi rom_flash::ram_address_sector#8 = (char *)$a000 [phi:rom_flash::@17->rom_flash::@13#1] -- pbuz1=pbuc1 - lda #<$a000 - sta.z ram_address_sector - lda #>$a000 - sta.z ram_address_sector+1 - // [1784] phi from rom_flash::@4 to rom_flash::@13 [phi:rom_flash::@4->rom_flash::@13] - // [1784] phi rom_flash::bram_bank_sector#40 = rom_flash::bram_bank_sector#14 [phi:rom_flash::@4->rom_flash::@13#0] -- register_copy - // [1784] phi rom_flash::ram_address_sector#8 = rom_flash::ram_address_sector#1 [phi:rom_flash::@4->rom_flash::@13#1] -- register_copy - // rom_flash::@13 - __b13: - // if (ram_address_sector == RAM_HIGH) - // [1785] if(rom_flash::ram_address_sector#8!=$9800) goto rom_flash::@36 -- pbuz1_neq_vwuc1_then_la1 - lda.z ram_address_sector+1 - cmp #>$9800 - bne __b14 - lda.z ram_address_sector - cmp #<$9800 - bne __b14 - // [1787] phi from rom_flash::@13 to rom_flash::@14 [phi:rom_flash::@13->rom_flash::@14] - // [1787] phi rom_flash::ram_address_sector#15 = (char *)$a000 [phi:rom_flash::@13->rom_flash::@14#0] -- pbuz1=pbuc1 - lda #<$a000 - sta.z ram_address_sector - lda #>$a000 - sta.z ram_address_sector+1 - // [1787] phi rom_flash::bram_bank_sector#12 = 1 [phi:rom_flash::@13->rom_flash::@14#1] -- vbum1=vbuc1 - lda #1 - sta bram_bank_sector - // [1786] phi from rom_flash::@13 to rom_flash::@36 [phi:rom_flash::@13->rom_flash::@36] - // rom_flash::@36 - // [1787] phi from rom_flash::@36 to rom_flash::@14 [phi:rom_flash::@36->rom_flash::@14] - // [1787] phi rom_flash::ram_address_sector#15 = rom_flash::ram_address_sector#8 [phi:rom_flash::@36->rom_flash::@14#0] -- register_copy - // [1787] phi rom_flash::bram_bank_sector#12 = rom_flash::bram_bank_sector#40 [phi:rom_flash::@36->rom_flash::@14#1] -- register_copy - // rom_flash::@14 - __b14: - // x_sector += 8 - // [1788] rom_flash::x_sector#1 = rom_flash::x_sector#10 + 8 -- vbum1=vbum1_plus_vbuc1 - lda #8 - clc - adc x_sector - sta x_sector - // rom_address_sector % ROM_PROGRESS_ROW - // [1789] rom_flash::$29 = rom_flash::rom_address_sector#1 & ROM_PROGRESS_ROW-1 -- vduz1=vdum2_band_vduc1 - lda rom_address_sector - and #ROM_PROGRESS_ROW-1 - sta.z rom_flash__29+1 - lda rom_address_sector+2 - and #>$10 - sta.z rom_flash__29+2 - lda rom_address_sector+3 - and #>ROM_PROGRESS_ROW-1>>$10 - sta.z rom_flash__29+3 - // if (!(rom_address_sector % ROM_PROGRESS_ROW)) - // [1790] if(0!=rom_flash::$29) goto rom_flash::@15 -- 0_neq_vduz1_then_la1 - lda.z rom_flash__29 - ora.z rom_flash__29+1 - ora.z rom_flash__29+2 - ora.z rom_flash__29+3 - bne __b15 - // rom_flash::@18 - // y_sector++; - // [1791] rom_flash::y_sector#1 = ++ rom_flash::y_sector#13 -- vbum1=_inc_vbum1 - inc y_sector - // [1792] phi from rom_flash::@18 to rom_flash::@15 [phi:rom_flash::@18->rom_flash::@15] - // [1792] phi rom_flash::y_sector#18 = rom_flash::y_sector#1 [phi:rom_flash::@18->rom_flash::@15#0] -- register_copy - // [1792] phi rom_flash::x_sector#20 = PROGRESS_X [phi:rom_flash::@18->rom_flash::@15#1] -- vbum1=vbuc1 - lda #PROGRESS_X - sta x_sector - // [1792] phi from rom_flash::@14 to rom_flash::@15 [phi:rom_flash::@14->rom_flash::@15] - // [1792] phi rom_flash::y_sector#18 = rom_flash::y_sector#13 [phi:rom_flash::@14->rom_flash::@15#0] -- register_copy - // [1792] phi rom_flash::x_sector#20 = rom_flash::x_sector#1 [phi:rom_flash::@14->rom_flash::@15#1] -- register_copy - // rom_flash::@15 - __b15: - // sprintf(info_text, "%u flash errors ...", flash_errors) - // [1793] call snprintf_init - // [1205] phi from rom_flash::@15 to snprintf_init [phi:rom_flash::@15->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:rom_flash::@15->snprintf_init#0] -- pbuz1=pbuc1 - lda #info_text - sta.z snprintf_init.s+1 - jsr snprintf_init - // rom_flash::@32 - // sprintf(info_text, "%u flash errors ...", flash_errors) - // [1794] printf_ulong::uvalue#9 = rom_flash::flash_errors#10 -- vdum1=vdum2 - lda flash_errors - sta printf_ulong.uvalue - lda flash_errors+1 - sta printf_ulong.uvalue+1 - lda flash_errors+2 - sta printf_ulong.uvalue+2 - lda flash_errors+3 - sta printf_ulong.uvalue+3 - // [1795] call printf_ulong - // [1741] phi from rom_flash::@32 to printf_ulong [phi:rom_flash::@32->printf_ulong] - // [1741] phi printf_ulong::format_zero_padding#15 = 0 [phi:rom_flash::@32->printf_ulong#0] -- vbum1=vbuc1 - lda #0 - sta printf_ulong.format_zero_padding - // [1741] phi printf_ulong::format_min_length#15 = 0 [phi:rom_flash::@32->printf_ulong#1] -- vbum1=vbuc1 - sta printf_ulong.format_min_length - // [1741] phi printf_ulong::format_radix#15 = DECIMAL [phi:rom_flash::@32->printf_ulong#2] -- vbum1=vbuc1 - lda #DECIMAL - sta printf_ulong.format_radix - // [1741] phi printf_ulong::uvalue#15 = printf_ulong::uvalue#9 [phi:rom_flash::@32->printf_ulong#3] -- register_copy - jsr printf_ulong - // [1796] phi from rom_flash::@32 to rom_flash::@33 [phi:rom_flash::@32->rom_flash::@33] - // rom_flash::@33 - // sprintf(info_text, "%u flash errors ...", flash_errors) - // [1797] call printf_str - // [1210] phi from rom_flash::@33 to printf_str [phi:rom_flash::@33->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:rom_flash::@33->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = rom_flash::s2 [phi:rom_flash::@33->printf_str#1] -- pbuz1=pbuc1 - lda #s2 - sta.z printf_str.s+1 - jsr printf_str - // rom_flash::@34 - // sprintf(info_text, "%u flash errors ...", flash_errors) - // [1798] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 - lda #0 - pha - // [1799] callexecute snputc -- call_vprc1 - jsr snputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // display_info_rom(rom_chip, STATUS_FLASHING, info_text) - // [1801] display_info_rom::rom_chip#3 = rom_flash::rom_chip#0 -- vbum1=vbum2 - lda rom_chip - sta display_info_rom.rom_chip - // [1802] call display_info_rom - // [1546] phi from rom_flash::@34 to display_info_rom [phi:rom_flash::@34->display_info_rom] - // [1546] phi display_info_rom::info_text#17 = info_text [phi:rom_flash::@34->display_info_rom#0] -- pbuz1=pbuc1 - lda #info_text - sta.z display_info_rom.info_text+1 - // [1546] phi display_info_rom::rom_chip#17 = display_info_rom::rom_chip#3 [phi:rom_flash::@34->display_info_rom#1] -- register_copy - // [1546] phi display_info_rom::info_status#17 = STATUS_FLASHING [phi:rom_flash::@34->display_info_rom#2] -- vbum1=vbuc1 - lda #STATUS_FLASHING - sta display_info_rom.info_status - jsr display_info_rom - // [1762] phi from rom_flash::@34 to rom_flash::@1 [phi:rom_flash::@34->rom_flash::@1] - // [1762] phi rom_flash::flash_errors#12 = rom_flash::flash_errors#10 [phi:rom_flash::@34->rom_flash::@1#0] -- register_copy - // [1762] phi rom_flash::y_sector#13 = rom_flash::y_sector#18 [phi:rom_flash::@34->rom_flash::@1#1] -- register_copy - // [1762] phi rom_flash::x_sector#10 = rom_flash::x_sector#20 [phi:rom_flash::@34->rom_flash::@1#2] -- register_copy - // [1762] phi rom_flash::ram_address_sector#11 = rom_flash::ram_address_sector#15 [phi:rom_flash::@34->rom_flash::@1#3] -- register_copy - // [1762] phi rom_flash::bram_bank_sector#14 = rom_flash::bram_bank_sector#12 [phi:rom_flash::@34->rom_flash::@1#4] -- register_copy - // [1762] phi rom_flash::rom_address_sector#13 = rom_flash::rom_address_sector#1 [phi:rom_flash::@34->rom_flash::@1#5] -- register_copy - jmp __b1 - // [1803] phi from rom_flash::@22 to rom_flash::@5 [phi:rom_flash::@22->rom_flash::@5] - __b3: - // [1803] phi rom_flash::flash_errors_sector#10 = 0 [phi:rom_flash::@22->rom_flash::@5#0] -- vwum1=vwuc1 - lda #<0 - sta flash_errors_sector - sta flash_errors_sector+1 - // [1803] phi rom_flash::retries#12 = 0 [phi:rom_flash::@22->rom_flash::@5#1] -- vbum1=vbuc1 - sta retries - // [1803] phi from rom_flash::@35 to rom_flash::@5 [phi:rom_flash::@35->rom_flash::@5] - // [1803] phi rom_flash::flash_errors_sector#10 = rom_flash::flash_errors_sector#11 [phi:rom_flash::@35->rom_flash::@5#0] -- register_copy - // [1803] phi rom_flash::retries#12 = rom_flash::retries#1 [phi:rom_flash::@35->rom_flash::@5#1] -- register_copy - // rom_flash::@5 - __b5: - // rom_sector_erase(rom_address_sector) - // [1804] rom_sector_erase::address#0 = rom_flash::rom_address_sector#13 -- vdum1=vdum2 - lda rom_address_sector - sta rom_sector_erase.address - lda rom_address_sector+1 - sta rom_sector_erase.address+1 - lda rom_address_sector+2 - sta rom_sector_erase.address+2 - lda rom_address_sector+3 - sta rom_sector_erase.address+3 - // [1805] call rom_sector_erase - // [2943] phi from rom_flash::@5 to rom_sector_erase [phi:rom_flash::@5->rom_sector_erase] - jsr rom_sector_erase - // rom_flash::@24 - // unsigned long rom_sector_boundary = rom_address_sector + ROM_SECTOR - // [1806] rom_flash::rom_sector_boundary#0 = rom_flash::rom_address_sector#13 + $1000 -- vdum1=vdum2_plus_vwuc1 - clc - lda rom_address_sector - adc #<$1000 - sta rom_sector_boundary - lda rom_address_sector+1 - adc #>$1000 - sta rom_sector_boundary+1 - lda rom_address_sector+2 - adc #0 - sta rom_sector_boundary+2 - lda rom_address_sector+3 - adc #0 - sta rom_sector_boundary+3 - // gotoxy(x, y) - // [1807] gotoxy::x#35 = rom_flash::x_sector#10 -- vbum1=vbum2 - lda x_sector - sta gotoxy.x - // [1808] gotoxy::y#35 = rom_flash::y_sector#13 -- vbum1=vbum2 - lda y_sector - sta gotoxy.y - // [1809] call gotoxy - // [802] phi from rom_flash::@24 to gotoxy [phi:rom_flash::@24->gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#35 [phi:rom_flash::@24->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = gotoxy::x#35 [phi:rom_flash::@24->gotoxy#1] -- register_copy - jsr gotoxy - // [1810] phi from rom_flash::@24 to rom_flash::@25 [phi:rom_flash::@24->rom_flash::@25] - // rom_flash::@25 - // printf("........") - // [1811] call printf_str - // [1210] phi from rom_flash::@25 to printf_str [phi:rom_flash::@25->printf_str] - // [1210] phi printf_str::putc#84 = &cputc [phi:rom_flash::@25->printf_str#0] -- pprz1=pprc1 - lda #cputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = rom_flash::s1 [phi:rom_flash::@25->printf_str#1] -- pbuz1=pbuc1 - lda #s1 - sta.z printf_str.s+1 - jsr printf_str - // rom_flash::@26 - // [1812] rom_flash::rom_address#16 = rom_flash::rom_address_sector#13 -- vdum1=vdum2 - lda rom_address_sector - sta rom_address - lda rom_address_sector+1 - sta rom_address+1 - lda rom_address_sector+2 - sta rom_address+2 - lda rom_address_sector+3 - sta rom_address+3 - // [1813] rom_flash::ram_address#16 = rom_flash::ram_address_sector#11 -- pbuz1=pbuz2 - lda.z ram_address_sector - sta.z ram_address - lda.z ram_address_sector+1 - sta.z ram_address+1 - // [1814] rom_flash::x#16 = rom_flash::x_sector#10 -- vbum1=vbum2 - lda x_sector - sta x - // [1815] phi from rom_flash::@10 rom_flash::@26 to rom_flash::@6 [phi:rom_flash::@10/rom_flash::@26->rom_flash::@6] - // [1815] phi rom_flash::x#10 = rom_flash::x#1 [phi:rom_flash::@10/rom_flash::@26->rom_flash::@6#0] -- register_copy - // [1815] phi rom_flash::ram_address#10 = rom_flash::ram_address#1 [phi:rom_flash::@10/rom_flash::@26->rom_flash::@6#1] -- register_copy - // [1815] phi rom_flash::flash_errors_sector#11 = rom_flash::flash_errors_sector#7 [phi:rom_flash::@10/rom_flash::@26->rom_flash::@6#2] -- register_copy - // [1815] phi rom_flash::rom_address#11 = rom_flash::rom_address#1 [phi:rom_flash::@10/rom_flash::@26->rom_flash::@6#3] -- register_copy - // rom_flash::@6 + // display_frame_maskxy(x, y) + // [1196] display_frame_maskxy::x#1 = display_frame::x#24 -- vbum1=vbum2 + lda x_1 + sta display_frame_maskxy.x + // [1197] display_frame_maskxy::y#1 = display_frame::y#0 -- vbum1=vbum2 + lda y + sta display_frame_maskxy.y + // [1198] call display_frame_maskxy + // [1747] phi from display_frame::@1 to display_frame_maskxy [phi:display_frame::@1->display_frame_maskxy] + // [1747] phi display_frame_maskxy::cpeekcxy1_y#0 = display_frame_maskxy::y#1 [phi:display_frame::@1->display_frame_maskxy#0] -- register_copy + // [1747] phi display_frame_maskxy::cpeekcxy1_x#0 = display_frame_maskxy::x#1 [phi:display_frame::@1->display_frame_maskxy#1] -- register_copy + jsr display_frame_maskxy + // display_frame_maskxy(x, y) + // [1199] display_frame_maskxy::return#14 = display_frame_maskxy::return#12 + // display_frame::@16 + // mask = display_frame_maskxy(x, y) + // [1200] display_frame::mask#2 = display_frame_maskxy::return#14 + // mask |= 0b0011 + // [1201] display_frame::mask#3 = display_frame::mask#2 | 3 -- vbum1=vbum1_bor_vbuc1 + lda #3 + ora mask + sta mask + // display_frame_char(mask) + // [1202] display_frame_char::mask#1 = display_frame::mask#3 + // [1203] call display_frame_char + // [1773] phi from display_frame::@16 to display_frame_char [phi:display_frame::@16->display_frame_char] + // [1773] phi display_frame_char::mask#10 = display_frame_char::mask#1 [phi:display_frame::@16->display_frame_char#0] -- register_copy + jsr display_frame_char + // display_frame_char(mask) + // [1204] display_frame_char::return#14 = display_frame_char::return#12 + // display_frame::@17 + // c = display_frame_char(mask) + // [1205] display_frame::c#1 = display_frame_char::return#14 + // cputcxy(x, y, c) + // [1206] cputcxy::x#3 = display_frame::x#24 -- vbum1=vbum2 + lda x_1 + sta cputcxy.x + // [1207] cputcxy::y#3 = display_frame::y#0 -- vbum1=vbum2 + lda y + sta cputcxy.y + // [1208] cputcxy::c#3 = display_frame::c#1 + // [1209] call cputcxy + // [1346] phi from display_frame::@17 to cputcxy [phi:display_frame::@17->cputcxy] + // [1346] phi cputcxy::c#15 = cputcxy::c#3 [phi:display_frame::@17->cputcxy#0] -- register_copy + // [1346] phi cputcxy::y#15 = cputcxy::y#3 [phi:display_frame::@17->cputcxy#1] -- register_copy + // [1346] phi cputcxy::x#15 = cputcxy::x#3 [phi:display_frame::@17->cputcxy#2] -- register_copy + jsr cputcxy + // display_frame::@18 + // if(h>=2) + // [1210] if(display_frame::h#0<2) goto display_frame::@return -- vbum1_lt_vbuc1_then_la1 + lda h + cmp #2 + bcc __breturn + // display_frame::@3 + // y++; + // [1211] display_frame::y#1 = ++ display_frame::y#0 -- vbum1=_inc_vbum2 + lda y + inc + sta y_1 + // [1212] phi from display_frame::@27 display_frame::@3 to display_frame::@6 [phi:display_frame::@27/display_frame::@3->display_frame::@6] + // [1212] phi display_frame::y#10 = display_frame::y#2 [phi:display_frame::@27/display_frame::@3->display_frame::@6#0] -- register_copy + // display_frame::@6 __b6: - // while (rom_address < rom_sector_boundary) - // [1816] if(rom_flash::rom_address#11display_action_text_flashing] - // [2955] phi display_action_text_flashing::address#10 = display_action_text_flashing::address#2 [phi:rom_flash::@7->display_action_text_flashing#0] -- register_copy - // [2955] phi display_action_text_flashing::chip#10 = chip [phi:rom_flash::@7->display_action_text_flashing#1] -- pbuz1=pbuc1 - lda #chip - sta.z display_action_text_flashing.chip+1 - // [2955] phi display_action_text_flashing::bram_ptr#3 = display_action_text_flashing::bram_ptr#2 [phi:rom_flash::@7->display_action_text_flashing#2] -- register_copy - // [2955] phi display_action_text_flashing::bram_bank#3 = display_action_text_flashing::bram_bank#2 [phi:rom_flash::@7->display_action_text_flashing#3] -- register_copy - // [2955] phi display_action_text_flashing::bytes#3 = $1000 [phi:rom_flash::@7->display_action_text_flashing#4] -- vdum1=vduc1 - lda #<$1000 - sta display_action_text_flashing.bytes - lda #>$1000 - sta display_action_text_flashing.bytes+1 - lda #<$1000>>$10 - sta display_action_text_flashing.bytes+2 - lda #>$1000>>$10 - sta display_action_text_flashing.bytes+3 - jsr display_action_text_flashing - // rom_flash::@27 - // unsigned long written_bytes = rom_write(bram_bank, (bram_ptr_t)ram_address, rom_address, ROM_PROGRESS_CELL) - // [1825] rom_write::flash_ram_bank#0 = rom_flash::bram_bank_sector#14 -- vbum1=vbum2 - lda bram_bank_sector - sta rom_write.flash_ram_bank - // [1826] rom_write::flash_ram_address#1 = rom_flash::ram_address#10 -- pbuz1=pbuz2 - lda.z ram_address - sta.z rom_write.flash_ram_address - lda.z ram_address+1 - sta.z rom_write.flash_ram_address+1 - // [1827] rom_write::flash_rom_address#1 = rom_flash::rom_address#11 -- vdum1=vdum2 - lda rom_address - sta rom_write.flash_rom_address - lda rom_address+1 - sta rom_write.flash_rom_address+1 - lda rom_address+2 - sta rom_write.flash_rom_address+2 - lda rom_address+3 - sta rom_write.flash_rom_address+3 - // [1828] call rom_write - jsr rom_write - // rom_flash::@28 - // rom_compare(bram_bank, (bram_ptr_t)ram_address, rom_address, ROM_PROGRESS_CELL) - // [1829] rom_compare::bank_ram#2 = rom_flash::bram_bank_sector#14 -- vbum1=vbum2 - lda bram_bank_sector - sta rom_compare.bank_ram - // [1830] rom_compare::ptr_ram#3 = rom_flash::ram_address#10 -- pbuz1=pbuz2 - lda.z ram_address - sta.z rom_compare.ptr_ram - lda.z ram_address+1 - sta.z rom_compare.ptr_ram+1 - // [1831] rom_compare::rom_compare_address#2 = rom_flash::rom_address#11 -- vdum1=vdum2 - lda rom_address - sta rom_compare.rom_compare_address - lda rom_address+1 - sta rom_compare.rom_compare_address+1 - lda rom_address+2 - sta rom_compare.rom_compare_address+2 - lda rom_address+3 - sta rom_compare.rom_compare_address+3 - // [1832] call rom_compare - // [2870] phi from rom_flash::@28 to rom_compare [phi:rom_flash::@28->rom_compare] - // [2870] phi rom_compare::ptr_ram#10 = rom_compare::ptr_ram#3 [phi:rom_flash::@28->rom_compare#0] -- register_copy - // [2870] phi rom_compare::rom_compare_size#11 = ROM_PROGRESS_CELL [phi:rom_flash::@28->rom_compare#1] -- vwum1=vwuc1 - lda #ROM_PROGRESS_CELL - sta rom_compare.rom_compare_size+1 - // [2870] phi rom_compare::rom_compare_address#3 = rom_compare::rom_compare_address#2 [phi:rom_flash::@28->rom_compare#2] -- register_copy - // [2870] phi rom_compare::bank_set_bram1_bank#0 = rom_compare::bank_ram#2 [phi:rom_flash::@28->rom_compare#3] -- register_copy - jsr rom_compare - // rom_compare(bram_bank, (bram_ptr_t)ram_address, rom_address, ROM_PROGRESS_CELL) - // [1833] rom_compare::return#4 = rom_compare::equal_bytes#2 - // rom_flash::@29 - // equal_bytes = rom_compare(bram_bank, (bram_ptr_t)ram_address, rom_address, ROM_PROGRESS_CELL) - // [1834] rom_flash::equal_bytes#1 = rom_compare::return#4 -- vwum1=vwum2 - lda rom_compare.return - sta equal_bytes_1 - lda rom_compare.return+1 - sta equal_bytes_1+1 - // gotoxy(x, y) - // [1835] gotoxy::x#36 = rom_flash::x#10 -- vbum1=vbum2 + // while(y < y1) + // [1213] if(display_frame::y#10gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#36 [phi:rom_flash::@29->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = gotoxy::x#36 [phi:rom_flash::@29->gotoxy#1] -- register_copy - jsr gotoxy - // rom_flash::@30 - // if (equal_bytes != ROM_PROGRESS_CELL) - // [1838] if(rom_flash::equal_bytes#1!=ROM_PROGRESS_CELL) goto rom_flash::@9 -- vwum1_neq_vwuc1_then_la1 - lda equal_bytes_1+1 - cmp #>ROM_PROGRESS_CELL - bne __b9 - lda equal_bytes_1 - cmp #display_frame_maskxy] + // [1747] phi display_frame_maskxy::cpeekcxy1_y#0 = display_frame_maskxy::y#5 [phi:display_frame::@8->display_frame_maskxy#0] -- register_copy + // [1747] phi display_frame_maskxy::cpeekcxy1_x#0 = display_frame_maskxy::x#5 [phi:display_frame::@8->display_frame_maskxy#1] -- register_copy + jsr display_frame_maskxy + // display_frame_maskxy(x, y) + // [1217] display_frame_maskxy::return#18 = display_frame_maskxy::return#12 + // display_frame::@28 + // mask = display_frame_maskxy(x, y) + // [1218] display_frame::mask#10 = display_frame_maskxy::return#18 + // mask |= 0b1100 + // [1219] display_frame::mask#11 = display_frame::mask#10 | $c -- vbum1=vbum1_bor_vbuc1 + lda #$c + ora mask + sta mask + // display_frame_char(mask) + // [1220] display_frame_char::mask#5 = display_frame::mask#11 + // [1221] call display_frame_char + // [1773] phi from display_frame::@28 to display_frame_char [phi:display_frame::@28->display_frame_char] + // [1773] phi display_frame_char::mask#10 = display_frame_char::mask#5 [phi:display_frame::@28->display_frame_char#0] -- register_copy + jsr display_frame_char + // display_frame_char(mask) + // [1222] display_frame_char::return#18 = display_frame_char::return#12 + // display_frame::@29 + // c = display_frame_char(mask) + // [1223] display_frame::c#5 = display_frame_char::return#18 + // cputcxy(x, y, c) + // [1224] cputcxy::x#7 = display_frame::x#0 -- vbum1=vbum2 lda x sta cputcxy.x - // [1840] cputcxy::y#16 = rom_flash::y_sector#13 -- vbum1=vbum2 - lda y_sector + // [1225] cputcxy::y#7 = display_frame::y#10 -- vbum1=vbum2 + lda y_1 sta cputcxy.y - // [1841] call cputcxy - // [2293] phi from rom_flash::@11 to cputcxy [phi:rom_flash::@11->cputcxy] - // [2293] phi cputcxy::c#17 = '+' [phi:rom_flash::@11->cputcxy#0] -- vbum1=vbuc1 - lda #'+' - sta cputcxy.c - // [2293] phi cputcxy::y#17 = cputcxy::y#16 [phi:rom_flash::@11->cputcxy#1] -- register_copy - // [2293] phi cputcxy::x#17 = cputcxy::x#16 [phi:rom_flash::@11->cputcxy#2] -- register_copy + // [1226] cputcxy::c#7 = display_frame::c#5 + // [1227] call cputcxy + // [1346] phi from display_frame::@29 to cputcxy [phi:display_frame::@29->cputcxy] + // [1346] phi cputcxy::c#15 = cputcxy::c#7 [phi:display_frame::@29->cputcxy#0] -- register_copy + // [1346] phi cputcxy::y#15 = cputcxy::y#7 [phi:display_frame::@29->cputcxy#1] -- register_copy + // [1346] phi cputcxy::x#15 = cputcxy::x#7 [phi:display_frame::@29->cputcxy#2] -- register_copy jsr cputcxy - // [1842] phi from rom_flash::@11 rom_flash::@31 to rom_flash::@10 [phi:rom_flash::@11/rom_flash::@31->rom_flash::@10] - // [1842] phi rom_flash::flash_errors_sector#7 = rom_flash::flash_errors_sector#11 [phi:rom_flash::@11/rom_flash::@31->rom_flash::@10#0] -- register_copy - // rom_flash::@10 - __b10: - // ram_address += ROM_PROGRESS_CELL - // [1843] rom_flash::ram_address#1 = rom_flash::ram_address#10 + ROM_PROGRESS_CELL -- pbuz1=pbuz1_plus_vwuc1 - lda.z ram_address - clc - adc #ROM_PROGRESS_CELL - sta.z ram_address+1 - // rom_address += ROM_PROGRESS_CELL - // [1844] rom_flash::rom_address#1 = rom_flash::rom_address#11 + ROM_PROGRESS_CELL -- vdum1=vdum1_plus_vwuc1 - clc - lda rom_address - adc #ROM_PROGRESS_CELL - sta rom_address+1 - lda rom_address+2 - adc #0 - sta rom_address+2 - lda rom_address+3 - adc #0 - sta rom_address+3 + // display_frame::@30 + // if(w>=2) + // [1228] if(display_frame::w#0<2) goto display_frame::@10 -- vbum1_lt_vbuc1_then_la1 + lda w + cmp #2 + bcc __b10 + // display_frame::@9 // x++; - // [1845] rom_flash::x#1 = ++ rom_flash::x#10 -- vbum1=_inc_vbum1 + // [1229] display_frame::x#4 = ++ display_frame::x#0 -- vbum1=_inc_vbum1 inc x - jmp __b6 - // rom_flash::@9 - __b9: - // cputcxy(x,y,'!') - // [1846] cputcxy::x#15 = rom_flash::x#10 -- vbum1=vbum2 + // [1230] phi from display_frame::@35 display_frame::@9 to display_frame::@11 [phi:display_frame::@35/display_frame::@9->display_frame::@11] + // [1230] phi display_frame::x#18 = display_frame::x#5 [phi:display_frame::@35/display_frame::@9->display_frame::@11#0] -- register_copy + // display_frame::@11 + __b11: + // while(x < x1) + // [1231] if(display_frame::x#18display_frame::@10] + // [1232] phi display_frame::x#15 = display_frame::x#18 [phi:display_frame::@11/display_frame::@30->display_frame::@10#0] -- register_copy + // display_frame::@10 + __b10: + // display_frame_maskxy(x, y) + // [1233] display_frame_maskxy::x#6 = display_frame::x#15 -- vbum1=vbum2 + lda x + sta display_frame_maskxy.x + // [1234] display_frame_maskxy::y#6 = display_frame::y#10 -- vbum1=vbum2 + lda y_1 + sta display_frame_maskxy.y + // [1235] call display_frame_maskxy + // [1747] phi from display_frame::@10 to display_frame_maskxy [phi:display_frame::@10->display_frame_maskxy] + // [1747] phi display_frame_maskxy::cpeekcxy1_y#0 = display_frame_maskxy::y#6 [phi:display_frame::@10->display_frame_maskxy#0] -- register_copy + // [1747] phi display_frame_maskxy::cpeekcxy1_x#0 = display_frame_maskxy::x#6 [phi:display_frame::@10->display_frame_maskxy#1] -- register_copy + jsr display_frame_maskxy + // display_frame_maskxy(x, y) + // [1236] display_frame_maskxy::return#19 = display_frame_maskxy::return#12 + // display_frame::@31 + // mask = display_frame_maskxy(x, y) + // [1237] display_frame::mask#12 = display_frame_maskxy::return#19 + // mask |= 0b1001 + // [1238] display_frame::mask#13 = display_frame::mask#12 | 9 -- vbum1=vbum1_bor_vbuc1 + lda #9 + ora mask + sta mask + // display_frame_char(mask) + // [1239] display_frame_char::mask#6 = display_frame::mask#13 + // [1240] call display_frame_char + // [1773] phi from display_frame::@31 to display_frame_char [phi:display_frame::@31->display_frame_char] + // [1773] phi display_frame_char::mask#10 = display_frame_char::mask#6 [phi:display_frame::@31->display_frame_char#0] -- register_copy + jsr display_frame_char + // display_frame_char(mask) + // [1241] display_frame_char::return#19 = display_frame_char::return#12 + // display_frame::@32 + // c = display_frame_char(mask) + // [1242] display_frame::c#6 = display_frame_char::return#19 + // cputcxy(x, y, c) + // [1243] cputcxy::x#8 = display_frame::x#15 -- vbum1=vbum2 lda x sta cputcxy.x - // [1847] cputcxy::y#15 = rom_flash::y_sector#13 -- vbum1=vbum2 - lda y_sector + // [1244] cputcxy::y#8 = display_frame::y#10 -- vbum1=vbum2 + lda y_1 sta cputcxy.y - // [1848] call cputcxy - // [2293] phi from rom_flash::@9 to cputcxy [phi:rom_flash::@9->cputcxy] - // [2293] phi cputcxy::c#17 = '!' [phi:rom_flash::@9->cputcxy#0] -- vbum1=vbuc1 - lda #'!' - sta cputcxy.c - // [2293] phi cputcxy::y#17 = cputcxy::y#15 [phi:rom_flash::@9->cputcxy#1] -- register_copy - // [2293] phi cputcxy::x#17 = cputcxy::x#15 [phi:rom_flash::@9->cputcxy#2] -- register_copy + // [1245] cputcxy::c#8 = display_frame::c#6 + // [1246] call cputcxy + // [1346] phi from display_frame::@32 to cputcxy [phi:display_frame::@32->cputcxy] + // [1346] phi cputcxy::c#15 = cputcxy::c#8 [phi:display_frame::@32->cputcxy#0] -- register_copy + // [1346] phi cputcxy::y#15 = cputcxy::y#8 [phi:display_frame::@32->cputcxy#1] -- register_copy + // [1346] phi cputcxy::x#15 = cputcxy::x#8 [phi:display_frame::@32->cputcxy#2] -- register_copy jsr cputcxy - // rom_flash::@31 - // flash_errors_sector++; - // [1849] rom_flash::flash_errors_sector#1 = ++ rom_flash::flash_errors_sector#11 -- vwum1=_inc_vwum1 - inc flash_errors_sector - bne !+ - inc flash_errors_sector+1 - !: - jmp __b10 - .segment Data - s: .text "--------" - .byte 0 - s1: .text "........" - .byte 0 - s2: .text " flash errors ..." - .byte 0 - rom_address_sector: .dword 0 - rom_boundary: .dword 0 - .label equal_bytes = rom_compare.equal_bytes - rom_sector_boundary: .dword 0 - equal_bytes_1: .word 0 - retries: .byte 0 - flash_errors_sector: .word 0 - rom_address: .dword 0 - x: .byte 0 - flash_errors: .dword 0 - // We start for ROM from 0x0:0x7800 !!!! - bram_bank_sector: .byte 0 - x_sector: .byte 0 - y_sector: .byte 0 - rom_chip: .byte 0 - .label rom_bank_start = rom_address_from_bank.rom_bank - file_size: .dword 0 - .label return = flash_errors -} -.segment Code - // smc_flash -/** - * @brief Flash the SMC using the new firmware stored in RAM. - * The bootloader starts from address 0x1E00 in the SMC, and should never be overwritten! - * The flashing starts by pressing the POWER and RESET button on the CX16 board simultaneously. - * - * @param smc_bytes_total Total bytes to flash the SMC from RAM. - * @return unsigned int Total bytes flashed, 0 if there is an error. - */ -// __mem() unsigned int smc_flash(__mem() unsigned int smc_bytes_total) -smc_flash: { - .const smc_bram_bank = 1 - .label smc_flash__29 = $78 - .label smc_flash__30 = $78 - .label smc_bram_ptr = $6e - // smc_flash::bank_set_bram1 - // BRAM = bank - // [1851] BRAM = smc_flash::smc_bram_bank -- vbuz1=vbuc1 - lda #smc_bram_bank - sta.z BRAM - // [1852] phi from smc_flash::bank_set_bram1 to smc_flash::@24 [phi:smc_flash::bank_set_bram1->smc_flash::@24] - // smc_flash::@24 - // display_action_progress("To start the SMC update, do the following ...") - // [1853] call display_action_progress - // [904] phi from smc_flash::@24 to display_action_progress [phi:smc_flash::@24->display_action_progress] - // [904] phi display_action_progress::info_text#27 = smc_flash::info_text [phi:smc_flash::@24->display_action_progress#0] -- pbuz1=pbuc1 - lda #info_text - sta.z display_action_progress.info_text+1 - jsr display_action_progress - // smc_flash::@28 - // unsigned char smc_bootloader_start = cx16_k_i2c_write_byte(FLASH_I2C_SMC_DEVICE, FLASH_I2C_SMC_BOOTLOADER_RESET, 0x31) - // [1854] smc_flash::cx16_k_i2c_write_byte1_device = $42 -- vbum1=vbuc1 - lda #$42 - sta cx16_k_i2c_write_byte1_device - // [1855] smc_flash::cx16_k_i2c_write_byte1_offset = $8f -- vbum1=vbuc1 - lda #$8f - sta cx16_k_i2c_write_byte1_offset - // [1856] smc_flash::cx16_k_i2c_write_byte1_value = $31 -- vbum1=vbuc1 - lda #$31 - sta cx16_k_i2c_write_byte1_value - // smc_flash::cx16_k_i2c_write_byte1 - // unsigned char result - // [1857] smc_flash::cx16_k_i2c_write_byte1_result = 0 -- vbum1=vbuc1 - lda #0 - sta cx16_k_i2c_write_byte1_result - // asm - // asm { ldxdevice ldyoffset ldavalue stzresult jsrCX16_I2C_WRITE_BYTE rolresult } - ldx cx16_k_i2c_write_byte1_device - ldy cx16_k_i2c_write_byte1_offset - lda cx16_k_i2c_write_byte1_value - stz cx16_k_i2c_write_byte1_result - jsr CX16_I2C_WRITE_BYTE - rol cx16_k_i2c_write_byte1_result - // return result; - // [1859] smc_flash::cx16_k_i2c_write_byte1_return#0 = smc_flash::cx16_k_i2c_write_byte1_result -- vbum1=vbum2 - lda cx16_k_i2c_write_byte1_result - sta cx16_k_i2c_write_byte1_return - // smc_flash::cx16_k_i2c_write_byte1_@return + // display_frame::@return + __breturn: // } - // [1860] smc_flash::cx16_k_i2c_write_byte1_return#1 = smc_flash::cx16_k_i2c_write_byte1_return#0 - // smc_flash::@25 - // unsigned char smc_bootloader_start = cx16_k_i2c_write_byte(FLASH_I2C_SMC_DEVICE, FLASH_I2C_SMC_BOOTLOADER_RESET, 0x31) - // [1861] smc_flash::smc_bootloader_start#0 = smc_flash::cx16_k_i2c_write_byte1_return#1 - // if(smc_bootloader_start) - // [1862] if(0==smc_flash::smc_bootloader_start#0) goto smc_flash::@3 -- 0_eq_vbum1_then_la1 - lda smc_bootloader_start - beq __b6 - // [1863] phi from smc_flash::@25 to smc_flash::@2 [phi:smc_flash::@25->smc_flash::@2] - // smc_flash::@2 - // sprintf(info_text, "There was a problem starting the SMC bootloader: %x", smc_bootloader_start) - // [1864] call snprintf_init - // [1205] phi from smc_flash::@2 to snprintf_init [phi:smc_flash::@2->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:smc_flash::@2->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 - jsr snprintf_init - // [1865] phi from smc_flash::@2 to smc_flash::@29 [phi:smc_flash::@2->smc_flash::@29] - // smc_flash::@29 - // sprintf(info_text, "There was a problem starting the SMC bootloader: %x", smc_bootloader_start) - // [1866] call printf_str - // [1210] phi from smc_flash::@29 to printf_str [phi:smc_flash::@29->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:smc_flash::@29->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = smc_flash::s [phi:smc_flash::@29->printf_str#1] -- pbuz1=pbuc1 - lda #s - sta.z printf_str.s+1 - jsr printf_str - // smc_flash::@30 - // sprintf(info_text, "There was a problem starting the SMC bootloader: %x", smc_bootloader_start) - // [1867] printf_uchar::uvalue#10 = smc_flash::smc_bootloader_start#0 -- vbum1=vbum2 - lda smc_bootloader_start - sta printf_uchar.uvalue - // [1868] call printf_uchar - // [1346] phi from smc_flash::@30 to printf_uchar [phi:smc_flash::@30->printf_uchar] - // [1346] phi printf_uchar::format_zero_padding#18 = 0 [phi:smc_flash::@30->printf_uchar#0] -- vbum1=vbuc1 - lda #0 - sta printf_uchar.format_zero_padding - // [1346] phi printf_uchar::format_min_length#18 = 0 [phi:smc_flash::@30->printf_uchar#1] -- vbum1=vbuc1 - sta printf_uchar.format_min_length - // [1346] phi printf_uchar::putc#18 = &snputc [phi:smc_flash::@30->printf_uchar#2] -- pprz1=pprc1 - lda #snputc - sta.z printf_uchar.putc+1 - // [1346] phi printf_uchar::format_radix#18 = HEXADECIMAL [phi:smc_flash::@30->printf_uchar#3] -- vbum1=vbuc1 - lda #HEXADECIMAL - sta printf_uchar.format_radix - // [1346] phi printf_uchar::uvalue#18 = printf_uchar::uvalue#10 [phi:smc_flash::@30->printf_uchar#4] -- register_copy - jsr printf_uchar - // smc_flash::@31 - // sprintf(info_text, "There was a problem starting the SMC bootloader: %x", smc_bootloader_start) - // [1869] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 - lda #0 - pha - // [1870] callexecute snputc -- call_vprc1 - jsr snputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // display_action_text(info_text) - // [1872] call display_action_text - // [1357] phi from smc_flash::@31 to display_action_text [phi:smc_flash::@31->display_action_text] - // [1357] phi display_action_text::info_text#25 = info_text [phi:smc_flash::@31->display_action_text#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z display_action_text.info_text - lda #>@info_text - sta.z display_action_text.info_text+1 - jsr display_action_text - // smc_flash::@32 - // cx16_k_i2c_write_byte(FLASH_I2C_SMC_DEVICE, FLASH_I2C_SMC_REBOOT, 0) - // [1873] smc_flash::cx16_k_i2c_write_byte2_device = $42 -- vbum1=vbuc1 - lda #$42 - sta cx16_k_i2c_write_byte2_device - // [1874] smc_flash::cx16_k_i2c_write_byte2_offset = $82 -- vbum1=vbuc1 - lda #$82 - sta cx16_k_i2c_write_byte2_offset - // [1875] smc_flash::cx16_k_i2c_write_byte2_value = 0 -- vbum1=vbuc1 - lda #0 - sta cx16_k_i2c_write_byte2_value - // smc_flash::cx16_k_i2c_write_byte2 - // unsigned char result - // [1876] smc_flash::cx16_k_i2c_write_byte2_result = 0 -- vbum1=vbuc1 - sta cx16_k_i2c_write_byte2_result - // asm - // asm { ldxdevice ldyoffset ldavalue stzresult jsrCX16_I2C_WRITE_BYTE rolresult } - ldx cx16_k_i2c_write_byte2_device - ldy cx16_k_i2c_write_byte2_offset - lda cx16_k_i2c_write_byte2_value - stz cx16_k_i2c_write_byte2_result - jsr CX16_I2C_WRITE_BYTE - rol cx16_k_i2c_write_byte2_result - // [1878] phi from smc_flash::@50 smc_flash::cx16_k_i2c_write_byte2 to smc_flash::@return [phi:smc_flash::@50/smc_flash::cx16_k_i2c_write_byte2->smc_flash::@return] - __b2: - // [1878] phi smc_flash::return#1 = 0 [phi:smc_flash::@50/smc_flash::cx16_k_i2c_write_byte2->smc_flash::@return#0] -- vwum1=vbuc1 - lda #<0 - sta return - sta return+1 - // smc_flash::@return - // } - // [1879] return + // [1247] return rts - // [1880] phi from smc_flash::@25 to smc_flash::@3 [phi:smc_flash::@25->smc_flash::@3] - __b6: - // [1880] phi smc_flash::smc_bootloader_activation_countdown#10 = $80 [phi:smc_flash::@25->smc_flash::@3#0] -- vbum1=vbuc1 - lda #$80 - sta smc_bootloader_activation_countdown - // smc_flash::@3 - __b3: - // while(smc_bootloader_activation_countdown) - // [1881] if(0!=smc_flash::smc_bootloader_activation_countdown#10) goto smc_flash::@4 -- 0_neq_vbum1_then_la1 - lda smc_bootloader_activation_countdown - beq !__b4+ - jmp __b4 - !__b4: - // [1882] phi from smc_flash::@3 smc_flash::@33 to smc_flash::@7 [phi:smc_flash::@3/smc_flash::@33->smc_flash::@7] - __b9: - // [1882] phi smc_flash::smc_bootloader_activation_countdown#12 = $a [phi:smc_flash::@3/smc_flash::@33->smc_flash::@7#0] -- vbum1=vbuc1 - lda #$a - sta smc_bootloader_activation_countdown_1 - // smc_flash::@7 + // display_frame::@12 + __b12: + // display_frame_maskxy(x, y) + // [1248] display_frame_maskxy::x#7 = display_frame::x#18 -- vbum1=vbum2 + lda x + sta display_frame_maskxy.x + // [1249] display_frame_maskxy::y#7 = display_frame::y#10 -- vbum1=vbum2 + lda y_1 + sta display_frame_maskxy.y + // [1250] call display_frame_maskxy + // [1747] phi from display_frame::@12 to display_frame_maskxy [phi:display_frame::@12->display_frame_maskxy] + // [1747] phi display_frame_maskxy::cpeekcxy1_y#0 = display_frame_maskxy::y#7 [phi:display_frame::@12->display_frame_maskxy#0] -- register_copy + // [1747] phi display_frame_maskxy::cpeekcxy1_x#0 = display_frame_maskxy::x#7 [phi:display_frame::@12->display_frame_maskxy#1] -- register_copy + jsr display_frame_maskxy + // display_frame_maskxy(x, y) + // [1251] display_frame_maskxy::return#20 = display_frame_maskxy::return#12 + // display_frame::@33 + // mask = display_frame_maskxy(x, y) + // [1252] display_frame::mask#14 = display_frame_maskxy::return#20 + // mask |= 0b0101 + // [1253] display_frame::mask#15 = display_frame::mask#14 | 5 -- vbum1=vbum1_bor_vbuc1 + lda #5 + ora mask + sta mask + // display_frame_char(mask) + // [1254] display_frame_char::mask#7 = display_frame::mask#15 + // [1255] call display_frame_char + // [1773] phi from display_frame::@33 to display_frame_char [phi:display_frame::@33->display_frame_char] + // [1773] phi display_frame_char::mask#10 = display_frame_char::mask#7 [phi:display_frame::@33->display_frame_char#0] -- register_copy + jsr display_frame_char + // display_frame_char(mask) + // [1256] display_frame_char::return#20 = display_frame_char::return#12 + // display_frame::@34 + // c = display_frame_char(mask) + // [1257] display_frame::c#7 = display_frame_char::return#20 + // cputcxy(x, y, c) + // [1258] cputcxy::x#9 = display_frame::x#18 -- vbum1=vbum2 + lda x + sta cputcxy.x + // [1259] cputcxy::y#9 = display_frame::y#10 -- vbum1=vbum2 + lda y_1 + sta cputcxy.y + // [1260] cputcxy::c#9 = display_frame::c#7 + // [1261] call cputcxy + // [1346] phi from display_frame::@34 to cputcxy [phi:display_frame::@34->cputcxy] + // [1346] phi cputcxy::c#15 = cputcxy::c#9 [phi:display_frame::@34->cputcxy#0] -- register_copy + // [1346] phi cputcxy::y#15 = cputcxy::y#9 [phi:display_frame::@34->cputcxy#1] -- register_copy + // [1346] phi cputcxy::x#15 = cputcxy::x#9 [phi:display_frame::@34->cputcxy#2] -- register_copy + jsr cputcxy + // display_frame::@35 + // x++; + // [1262] display_frame::x#5 = ++ display_frame::x#18 -- vbum1=_inc_vbum1 + inc x + jmp __b11 + // display_frame::@7 __b7: - // while(smc_bootloader_activation_countdown) - // [1883] if(0!=smc_flash::smc_bootloader_activation_countdown#12) goto smc_flash::@8 -- 0_neq_vbum1_then_la1 - lda smc_bootloader_activation_countdown_1 - beq !__b8+ - jmp __b8 - !__b8: - // smc_flash::@9 - // cx16_k_i2c_read_byte(FLASH_I2C_SMC_DEVICE, FLASH_I2C_SMC_OFFSET) - // [1884] cx16_k_i2c_read_byte::device = $42 -- vbum1=vbuc1 - lda #$42 - sta cx16_k_i2c_read_byte.device - // [1885] cx16_k_i2c_read_byte::offset = $8e -- vbum1=vbuc1 - lda #$8e - sta cx16_k_i2c_read_byte.offset - // [1886] call cx16_k_i2c_read_byte - jsr cx16_k_i2c_read_byte - // [1887] cx16_k_i2c_read_byte::return#12 = cx16_k_i2c_read_byte::return#1 - // smc_flash::@45 - // smc_bootloader_not_activated = cx16_k_i2c_read_byte(FLASH_I2C_SMC_DEVICE, FLASH_I2C_SMC_OFFSET) - // [1888] smc_flash::smc_bootloader_not_activated#1 = cx16_k_i2c_read_byte::return#12 - // if(smc_bootloader_not_activated) - // [1889] if(0==smc_flash::smc_bootloader_not_activated#1) goto smc_flash::@1 -- 0_eq_vwum1_then_la1 - lda smc_bootloader_not_activated - ora smc_bootloader_not_activated+1 - beq __b1 - // [1890] phi from smc_flash::@45 to smc_flash::@10 [phi:smc_flash::@45->smc_flash::@10] - // smc_flash::@10 - // sprintf(info_text, "There was a problem activating the SMC bootloader: %x", smc_bootloader_not_activated) - // [1891] call snprintf_init - // [1205] phi from smc_flash::@10 to snprintf_init [phi:smc_flash::@10->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:smc_flash::@10->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 - jsr snprintf_init - // [1892] phi from smc_flash::@10 to smc_flash::@48 [phi:smc_flash::@10->smc_flash::@48] - // smc_flash::@48 - // sprintf(info_text, "There was a problem activating the SMC bootloader: %x", smc_bootloader_not_activated) - // [1893] call printf_str - // [1210] phi from smc_flash::@48 to printf_str [phi:smc_flash::@48->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:smc_flash::@48->printf_str#0] -- pprz1=pprc1 - lda #display_frame_maskxy] + // [1747] phi display_frame_maskxy::cpeekcxy1_y#0 = display_frame_maskxy::y#3 [phi:display_frame::@7->display_frame_maskxy#0] -- register_copy + // [1747] phi display_frame_maskxy::cpeekcxy1_x#0 = display_frame_maskxy::x#3 [phi:display_frame::@7->display_frame_maskxy#1] -- register_copy + jsr display_frame_maskxy + // display_frame_maskxy(x0, y) + // [1266] display_frame_maskxy::return#16 = display_frame_maskxy::return#12 + // display_frame::@22 + // mask = display_frame_maskxy(x0, y) + // [1267] display_frame::mask#6 = display_frame_maskxy::return#16 + // mask |= 0b1010 + // [1268] display_frame::mask#7 = display_frame::mask#6 | $a -- vbum1=vbum1_bor_vbuc1 + lda #$a + ora mask + sta mask + // display_frame_char(mask) + // [1269] display_frame_char::mask#3 = display_frame::mask#7 + // [1270] call display_frame_char + // [1773] phi from display_frame::@22 to display_frame_char [phi:display_frame::@22->display_frame_char] + // [1773] phi display_frame_char::mask#10 = display_frame_char::mask#3 [phi:display_frame::@22->display_frame_char#0] -- register_copy + jsr display_frame_char + // display_frame_char(mask) + // [1271] display_frame_char::return#16 = display_frame_char::return#12 + // display_frame::@23 + // c = display_frame_char(mask) + // [1272] display_frame::c#3 = display_frame_char::return#16 + // cputcxy(x0, y, c) + // [1273] cputcxy::x#5 = display_frame::x#0 -- vbum1=vbum2 + lda x + sta cputcxy.x + // [1274] cputcxy::y#5 = display_frame::y#10 -- vbum1=vbum2 + lda y_1 + sta cputcxy.y + // [1275] cputcxy::c#5 = display_frame::c#3 + // [1276] call cputcxy + // [1346] phi from display_frame::@23 to cputcxy [phi:display_frame::@23->cputcxy] + // [1346] phi cputcxy::c#15 = cputcxy::c#5 [phi:display_frame::@23->cputcxy#0] -- register_copy + // [1346] phi cputcxy::y#15 = cputcxy::y#5 [phi:display_frame::@23->cputcxy#1] -- register_copy + // [1346] phi cputcxy::x#15 = cputcxy::x#5 [phi:display_frame::@23->cputcxy#2] -- register_copy + jsr cputcxy + // display_frame::@24 + // display_frame_maskxy(x1, y) + // [1277] display_frame_maskxy::x#4 = display_frame::x1#16 -- vbum1=vbum2 + lda x1 + sta display_frame_maskxy.x + // [1278] display_frame_maskxy::y#4 = display_frame::y#10 -- vbum1=vbum2 + lda y_1 + sta display_frame_maskxy.y + // [1279] call display_frame_maskxy + // [1747] phi from display_frame::@24 to display_frame_maskxy [phi:display_frame::@24->display_frame_maskxy] + // [1747] phi display_frame_maskxy::cpeekcxy1_y#0 = display_frame_maskxy::y#4 [phi:display_frame::@24->display_frame_maskxy#0] -- register_copy + // [1747] phi display_frame_maskxy::cpeekcxy1_x#0 = display_frame_maskxy::x#4 [phi:display_frame::@24->display_frame_maskxy#1] -- register_copy + jsr display_frame_maskxy + // display_frame_maskxy(x1, y) + // [1280] display_frame_maskxy::return#17 = display_frame_maskxy::return#12 + // display_frame::@25 + // mask = display_frame_maskxy(x1, y) + // [1281] display_frame::mask#8 = display_frame_maskxy::return#17 + // mask |= 0b1010 + // [1282] display_frame::mask#9 = display_frame::mask#8 | $a -- vbum1=vbum1_bor_vbuc1 + lda #$a + ora mask + sta mask + // display_frame_char(mask) + // [1283] display_frame_char::mask#4 = display_frame::mask#9 + // [1284] call display_frame_char + // [1773] phi from display_frame::@25 to display_frame_char [phi:display_frame::@25->display_frame_char] + // [1773] phi display_frame_char::mask#10 = display_frame_char::mask#4 [phi:display_frame::@25->display_frame_char#0] -- register_copy + jsr display_frame_char + // display_frame_char(mask) + // [1285] display_frame_char::return#17 = display_frame_char::return#12 + // display_frame::@26 + // c = display_frame_char(mask) + // [1286] display_frame::c#4 = display_frame_char::return#17 + // cputcxy(x1, y, c) + // [1287] cputcxy::x#6 = display_frame::x1#16 -- vbum1=vbum2 + lda x1 + sta cputcxy.x + // [1288] cputcxy::y#6 = display_frame::y#10 -- vbum1=vbum2 + lda y_1 + sta cputcxy.y + // [1289] cputcxy::c#6 = display_frame::c#4 + // [1290] call cputcxy + // [1346] phi from display_frame::@26 to cputcxy [phi:display_frame::@26->cputcxy] + // [1346] phi cputcxy::c#15 = cputcxy::c#6 [phi:display_frame::@26->cputcxy#0] -- register_copy + // [1346] phi cputcxy::y#15 = cputcxy::y#6 [phi:display_frame::@26->cputcxy#1] -- register_copy + // [1346] phi cputcxy::x#15 = cputcxy::x#6 [phi:display_frame::@26->cputcxy#2] -- register_copy + jsr cputcxy + // display_frame::@27 + // y++; + // [1291] display_frame::y#2 = ++ display_frame::y#10 -- vbum1=_inc_vbum1 + inc y_1 + jmp __b6 + // display_frame::@5 + __b5: + // display_frame_maskxy(x, y) + // [1292] display_frame_maskxy::x#2 = display_frame::x#10 -- vbum1=vbum2 + lda x_1 + sta display_frame_maskxy.x + // [1293] display_frame_maskxy::y#2 = display_frame::y#0 -- vbum1=vbum2 + lda y + sta display_frame_maskxy.y + // [1294] call display_frame_maskxy + // [1747] phi from display_frame::@5 to display_frame_maskxy [phi:display_frame::@5->display_frame_maskxy] + // [1747] phi display_frame_maskxy::cpeekcxy1_y#0 = display_frame_maskxy::y#2 [phi:display_frame::@5->display_frame_maskxy#0] -- register_copy + // [1747] phi display_frame_maskxy::cpeekcxy1_x#0 = display_frame_maskxy::x#2 [phi:display_frame::@5->display_frame_maskxy#1] -- register_copy + jsr display_frame_maskxy + // display_frame_maskxy(x, y) + // [1295] display_frame_maskxy::return#15 = display_frame_maskxy::return#12 + // display_frame::@19 + // mask = display_frame_maskxy(x, y) + // [1296] display_frame::mask#4 = display_frame_maskxy::return#15 + // mask |= 0b0101 + // [1297] display_frame::mask#5 = display_frame::mask#4 | 5 -- vbum1=vbum1_bor_vbuc1 + lda #5 + ora mask + sta mask + // display_frame_char(mask) + // [1298] display_frame_char::mask#2 = display_frame::mask#5 + // [1299] call display_frame_char + // [1773] phi from display_frame::@19 to display_frame_char [phi:display_frame::@19->display_frame_char] + // [1773] phi display_frame_char::mask#10 = display_frame_char::mask#2 [phi:display_frame::@19->display_frame_char#0] -- register_copy + jsr display_frame_char + // display_frame_char(mask) + // [1300] display_frame_char::return#15 = display_frame_char::return#12 + // display_frame::@20 + // c = display_frame_char(mask) + // [1301] display_frame::c#2 = display_frame_char::return#15 + // cputcxy(x, y, c) + // [1302] cputcxy::x#4 = display_frame::x#10 -- vbum1=vbum2 + lda x_1 + sta cputcxy.x + // [1303] cputcxy::y#4 = display_frame::y#0 -- vbum1=vbum2 + lda y + sta cputcxy.y + // [1304] cputcxy::c#4 = display_frame::c#2 + // [1305] call cputcxy + // [1346] phi from display_frame::@20 to cputcxy [phi:display_frame::@20->cputcxy] + // [1346] phi cputcxy::c#15 = cputcxy::c#4 [phi:display_frame::@20->cputcxy#0] -- register_copy + // [1346] phi cputcxy::y#15 = cputcxy::y#4 [phi:display_frame::@20->cputcxy#1] -- register_copy + // [1346] phi cputcxy::x#15 = cputcxy::x#4 [phi:display_frame::@20->cputcxy#2] -- register_copy + jsr cputcxy + // display_frame::@21 + // x++; + // [1306] display_frame::x#2 = ++ display_frame::x#10 -- vbum1=_inc_vbum1 + inc x_1 + jmp __b4 + // display_frame::@36 + __b36: + // [1307] display_frame::x#30 = display_frame::x#0 -- vbum1=vbum2 + lda x + sta x_1 + jmp __b1 + .segment Data + w: .byte 0 + h: .byte 0 + x: .byte 0 + y: .byte 0 + .label mask = display_frame_maskxy.return + .label c = cputcxy.c + x_1: .byte 0 + y_1: .byte 0 + x1: .byte 0 + y1: .byte 0 +} +.segment Code + // printf_string +// Print a string value using a specific format +// Handles justification and min length +// void printf_string(__zp($3e) void (*putc)(char), __zp($42) char *str, __mem() char format_min_length, __mem() char format_justify_left) +printf_string: { + .label printf_string__9 = $51 + .label str = $42 + .label str_1 = $4f + .label putc = $3e + // if(format.min_length) + // [1309] if(0==printf_string::format_min_length#17) goto printf_string::@1 -- 0_eq_vbum1_then_la1 + lda format_min_length + beq __b3 + // printf_string::@3 + // strlen(str) + // [1310] strlen::str#3 = printf_string::str#17 -- pbuz1=pbuz2 + lda.z str + sta.z strlen.str + lda.z str+1 + sta.z strlen.str+1 + // [1311] call strlen + // [1788] phi from printf_string::@3 to strlen [phi:printf_string::@3->strlen] + // [1788] phi strlen::str#8 = strlen::str#3 [phi:printf_string::@3->strlen#0] -- register_copy + jsr strlen + // strlen(str) + // [1312] strlen::return#10 = strlen::len#2 + // printf_string::@6 + // [1313] printf_string::$9 = strlen::return#10 -- vwuz1=vwum2 + lda strlen.return + sta.z printf_string__9 + lda strlen.return+1 + sta.z printf_string__9+1 + // signed char len = (signed char)strlen(str) + // [1314] printf_string::len#0 = (signed char)printf_string::$9 -- vbsm1=_sbyte_vwuz2 + lda.z printf_string__9 + sta len + // padding = (signed char)format.min_length - len + // [1315] printf_string::padding#1 = (signed char)printf_string::format_min_length#17 - printf_string::len#0 -- vbsm1=vbsm1_minus_vbsm2 + lda padding + sec + sbc len + sta padding + // if(padding<0) + // [1316] if(printf_string::padding#1>=0) goto printf_string::@10 -- vbsm1_ge_0_then_la1 + cmp #0 + bpl __b1 + // [1318] phi from printf_string printf_string::@6 to printf_string::@1 [phi:printf_string/printf_string::@6->printf_string::@1] + __b3: + // [1318] phi printf_string::padding#3 = 0 [phi:printf_string/printf_string::@6->printf_string::@1#0] -- vbsm1=vbsc1 + lda #0 + sta padding + // [1317] phi from printf_string::@6 to printf_string::@10 [phi:printf_string::@6->printf_string::@10] + // printf_string::@10 + // [1318] phi from printf_string::@10 to printf_string::@1 [phi:printf_string::@10->printf_string::@1] + // [1318] phi printf_string::padding#3 = printf_string::padding#1 [phi:printf_string::@10->printf_string::@1#0] -- register_copy + // printf_string::@1 + __b1: + // if(!format.justify_left && padding) + // [1319] if(0!=printf_string::format_justify_left#17) goto printf_string::@2 -- 0_neq_vbum1_then_la1 + lda format_justify_left + bne __b2 + // printf_string::@8 + // [1320] if(0!=printf_string::padding#3) goto printf_string::@4 -- 0_neq_vbsm1_then_la1 + lda padding + cmp #0 + bne __b4 + jmp __b2 + // printf_string::@4 + __b4: + // printf_padding(putc, ' ',(char)padding) + // [1321] printf_padding::putc#3 = printf_string::putc#17 -- pprz1=pprz2 + lda.z putc + sta.z printf_padding.putc + lda.z putc+1 + sta.z printf_padding.putc+1 + // [1322] printf_padding::length#3 = (char)printf_string::padding#3 -- vbum1=vbum2 + lda padding + sta printf_padding.length + // [1323] call printf_padding + // [1794] phi from printf_string::@4 to printf_padding [phi:printf_string::@4->printf_padding] + // [1794] phi printf_padding::putc#7 = printf_padding::putc#3 [phi:printf_string::@4->printf_padding#0] -- register_copy + // [1794] phi printf_padding::pad#7 = ' ' [phi:printf_string::@4->printf_padding#1] -- vbum1=vbuc1 + lda #' ' + sta printf_padding.pad + // [1794] phi printf_padding::length#6 = printf_padding::length#3 [phi:printf_string::@4->printf_padding#2] -- register_copy + jsr printf_padding + // printf_string::@2 + __b2: + // printf_str(putc, str) + // [1324] printf_str::putc#1 = printf_string::putc#17 -- pprz1=pprz2 + lda.z putc sta.z printf_str.putc - lda #>snputc + lda.z putc+1 sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = smc_flash::s5 [phi:smc_flash::@48->printf_str#1] -- pbuz1=pbuc1 - lda #s5 - sta.z printf_str.s+1 + // [1325] printf_str::s#2 = printf_string::str#17 + // [1326] call printf_str + // [785] phi from printf_string::@2 to printf_str [phi:printf_string::@2->printf_str] + // [785] phi printf_str::putc#53 = printf_str::putc#1 [phi:printf_string::@2->printf_str#0] -- register_copy + // [785] phi printf_str::s#53 = printf_str::s#2 [phi:printf_string::@2->printf_str#1] -- register_copy jsr printf_str - // smc_flash::@49 - // sprintf(info_text, "There was a problem activating the SMC bootloader: %x", smc_bootloader_not_activated) - // [1894] printf_uint::uvalue#4 = smc_flash::smc_bootloader_not_activated#1 - // [1895] call printf_uint - // [2086] phi from smc_flash::@49 to printf_uint [phi:smc_flash::@49->printf_uint] - // [2086] phi printf_uint::format_zero_padding#10 = 0 [phi:smc_flash::@49->printf_uint#0] -- vbum1=vbuc1 - lda #0 - sta printf_uint.format_zero_padding - // [2086] phi printf_uint::format_min_length#10 = 0 [phi:smc_flash::@49->printf_uint#1] -- vbum1=vbuc1 - sta printf_uint.format_min_length - // [2086] phi printf_uint::putc#10 = &snputc [phi:smc_flash::@49->printf_uint#2] -- pprz1=pprc1 - lda #snputc - sta.z printf_uint.putc+1 - // [2086] phi printf_uint::format_radix#10 = HEXADECIMAL [phi:smc_flash::@49->printf_uint#3] -- vbum1=vbuc1 - lda #HEXADECIMAL - sta printf_uint.format_radix - // [2086] phi printf_uint::uvalue#10 = printf_uint::uvalue#4 [phi:smc_flash::@49->printf_uint#4] -- register_copy - jsr printf_uint - // smc_flash::@50 - // sprintf(info_text, "There was a problem activating the SMC bootloader: %x", smc_bootloader_not_activated) - // [1896] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 - lda #0 - pha - // [1897] callexecute snputc -- call_vprc1 - jsr snputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // display_action_text(info_text) - // [1899] call display_action_text - // [1357] phi from smc_flash::@50 to display_action_text [phi:smc_flash::@50->display_action_text] - // [1357] phi display_action_text::info_text#25 = info_text [phi:smc_flash::@50->display_action_text#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z display_action_text.info_text - lda #>@info_text - sta.z display_action_text.info_text+1 - jsr display_action_text - jmp __b2 - // [1900] phi from smc_flash::@45 to smc_flash::@1 [phi:smc_flash::@45->smc_flash::@1] - // smc_flash::@1 + // printf_string::@7 + // if(format.justify_left && padding) + // [1327] if(0==printf_string::format_justify_left#17) goto printf_string::@return -- 0_eq_vbum1_then_la1 + lda format_justify_left + beq __breturn + // printf_string::@9 + // [1328] if(0!=printf_string::padding#3) goto printf_string::@5 -- 0_neq_vbsm1_then_la1 + lda padding + cmp #0 + bne __b5 + rts + // printf_string::@5 + __b5: + // printf_padding(putc, ' ',(char)padding) + // [1329] printf_padding::putc#4 = printf_string::putc#17 -- pprz1=pprz2 + lda.z putc + sta.z printf_padding.putc + lda.z putc+1 + sta.z printf_padding.putc+1 + // [1330] printf_padding::length#4 = (char)printf_string::padding#3 -- vbum1=vbum2 + lda padding + sta printf_padding.length + // [1331] call printf_padding + // [1794] phi from printf_string::@5 to printf_padding [phi:printf_string::@5->printf_padding] + // [1794] phi printf_padding::putc#7 = printf_padding::putc#4 [phi:printf_string::@5->printf_padding#0] -- register_copy + // [1794] phi printf_padding::pad#7 = ' ' [phi:printf_string::@5->printf_padding#1] -- vbum1=vbuc1 + lda #' ' + sta printf_padding.pad + // [1794] phi printf_padding::length#6 = printf_padding::length#4 [phi:printf_string::@5->printf_padding#2] -- register_copy + jsr printf_padding + // printf_string::@return + __breturn: + // } + // [1332] return + rts + .segment Data + len: .byte 0 + .label padding = format_min_length + format_min_length: .byte 0 + format_justify_left: .byte 0 +} +.segment Code + // cputs +// Output a NUL-terminated string at the current cursor position +// void cputs(__zp($2d) const char *s) +cputs: { + .label s = $2d + // [1334] phi from cputs cputs::@2 to cputs::@1 [phi:cputs/cputs::@2->cputs::@1] + // [1334] phi cputs::s#2 = cputs::s#1 [phi:cputs/cputs::@2->cputs::@1#0] -- register_copy + // cputs::@1 __b1: - // display_action_progress("Updating SMC firmware ... (+) Updated") - // [1901] call display_action_progress - // [904] phi from smc_flash::@1 to display_action_progress [phi:smc_flash::@1->display_action_progress] - // [904] phi display_action_progress::info_text#27 = smc_flash::info_text1 [phi:smc_flash::@1->display_action_progress#0] -- pbuz1=pbuc1 - lda #info_text1 - sta.z display_action_progress.info_text+1 - jsr display_action_progress - // [1902] phi from smc_flash::@1 to smc_flash::@46 [phi:smc_flash::@1->smc_flash::@46] - // smc_flash::@46 - // textcolor(WHITE) - // [1903] call textcolor - // [784] phi from smc_flash::@46 to textcolor [phi:smc_flash::@46->textcolor] - // [784] phi textcolor::color#23 = WHITE [phi:smc_flash::@46->textcolor#0] -- vbum1=vbuc1 - lda #WHITE - sta textcolor.color - jsr textcolor - // [1904] phi from smc_flash::@46 to smc_flash::@47 [phi:smc_flash::@46->smc_flash::@47] - // smc_flash::@47 - // gotoxy(x, y) - // [1905] call gotoxy - // [802] phi from smc_flash::@47 to gotoxy [phi:smc_flash::@47->gotoxy] - // [802] phi gotoxy::y#37 = PROGRESS_Y [phi:smc_flash::@47->gotoxy#0] -- vbum1=vbuc1 - lda #PROGRESS_Y - sta gotoxy.y - // [802] phi gotoxy::x#37 = PROGRESS_X [phi:smc_flash::@47->gotoxy#1] -- vbum1=vbuc1 - lda #PROGRESS_X - sta gotoxy.x - jsr gotoxy - // [1906] phi from smc_flash::@47 to smc_flash::@11 [phi:smc_flash::@47->smc_flash::@11] - // [1906] phi smc_flash::y#36 = PROGRESS_Y [phi:smc_flash::@47->smc_flash::@11#0] -- vbum1=vbuc1 - lda #PROGRESS_Y - sta y - // [1906] phi smc_flash::smc_row_bytes#16 = 0 [phi:smc_flash::@47->smc_flash::@11#1] -- vwum1=vwuc1 - lda #<0 - sta smc_row_bytes - sta smc_row_bytes+1 - // [1906] phi smc_flash::smc_bram_ptr#14 = (char *)$a000 [phi:smc_flash::@47->smc_flash::@11#2] -- pbuz1=pbuc1 - lda #<$a000 - sta.z smc_bram_ptr - lda #>$a000 - sta.z smc_bram_ptr+1 - // [1906] phi smc_flash::smc_bytes_flashed#13 = 0 [phi:smc_flash::@47->smc_flash::@11#3] -- vwum1=vwuc1 - lda #<0 - sta smc_bytes_flashed - sta smc_bytes_flashed+1 - // [1906] phi from smc_flash::@15 to smc_flash::@11 [phi:smc_flash::@15->smc_flash::@11] - // [1906] phi smc_flash::y#36 = smc_flash::y#21 [phi:smc_flash::@15->smc_flash::@11#0] -- register_copy - // [1906] phi smc_flash::smc_row_bytes#16 = smc_flash::smc_row_bytes#11 [phi:smc_flash::@15->smc_flash::@11#1] -- register_copy - // [1906] phi smc_flash::smc_bram_ptr#14 = smc_flash::smc_bram_ptr#12 [phi:smc_flash::@15->smc_flash::@11#2] -- register_copy - // [1906] phi smc_flash::smc_bytes_flashed#13 = smc_flash::smc_bytes_flashed#12 [phi:smc_flash::@15->smc_flash::@11#3] -- register_copy - // smc_flash::@11 - __b11: - // while(smc_bytes_flashed < smc_bytes_total) - // [1907] if(smc_flash::smc_bytes_flashed#13display_action_text_flashed] - // [2926] phi display_action_text_flashed::chip#3 = smc_flash::chip [phi:smc_flash::@12->display_action_text_flashed#0] -- pbuz1=pbuc1 - lda #chip - sta.z display_action_text_flashed.chip+1 - // [2926] phi display_action_text_flashed::bytes#3 = display_action_text_flashed::bytes#1 [phi:smc_flash::@12->display_action_text_flashed#1] -- register_copy - jsr display_action_text_flashed - // [1878] phi from smc_flash::@12 to smc_flash::@return [phi:smc_flash::@12->smc_flash::@return] - // [1878] phi smc_flash::return#1 = smc_flash::smc_bytes_flashed#13 [phi:smc_flash::@12->smc_flash::@return#0] -- register_copy + // [1337] if(0!=cputs::c#1) goto cputs::@2 -- 0_neq_vbum1_then_la1 + lda c + bne __b2 + // cputs::@return + // } + // [1338] return rts - // [1910] phi from smc_flash::@11 to smc_flash::@13 [phi:smc_flash::@11->smc_flash::@13] - __b10: - // [1910] phi smc_flash::y#21 = smc_flash::y#36 [phi:smc_flash::@11->smc_flash::@13#0] -- register_copy - // [1910] phi smc_flash::smc_row_bytes#11 = smc_flash::smc_row_bytes#16 [phi:smc_flash::@11->smc_flash::@13#1] -- register_copy - // [1910] phi smc_flash::smc_bytes_flashed#12 = smc_flash::smc_bytes_flashed#13 [phi:smc_flash::@11->smc_flash::@13#2] -- register_copy - // [1910] phi smc_flash::smc_bram_ptr#12 = smc_flash::smc_bram_ptr#14 [phi:smc_flash::@11->smc_flash::@13#3] -- register_copy - // [1910] phi smc_flash::smc_attempts_flashed#15 = 0 [phi:smc_flash::@11->smc_flash::@13#4] -- vbum1=vbuc1 - lda #0 - sta smc_attempts_flashed - // [1910] phi smc_flash::smc_package_committed#10 = 0 [phi:smc_flash::@11->smc_flash::@13#5] -- vbum1=vbuc1 - sta smc_package_committed - // smc_flash::@13 - __b13: - // while(!smc_package_committed && smc_attempts_flashed < 10) - // [1911] if(0!=smc_flash::smc_package_committed#10) goto smc_flash::@15 -- 0_neq_vbum1_then_la1 - lda smc_package_committed - bne __b15 - // smc_flash::@55 - // [1912] if(smc_flash::smc_attempts_flashed#15<$a) goto smc_flash::@14 -- vbum1_lt_vbuc1_then_la1 - lda smc_attempts_flashed - cmp #$a - bcc __b14 - // smc_flash::@15 - __b15: - // if(smc_attempts_flashed >= 10) - // [1913] if(smc_flash::smc_attempts_flashed#15<$a) goto smc_flash::@11 -- vbum1_lt_vbuc1_then_la1 - lda smc_attempts_flashed - cmp #$a - bcc __b11 - // [1914] phi from smc_flash::@15 to smc_flash::@23 [phi:smc_flash::@15->smc_flash::@23] - // smc_flash::@23 - // sprintf(info_text, "There were too many attempts trying to flash the SMC at location %04x", smc_bytes_flashed) - // [1915] call snprintf_init - // [1205] phi from smc_flash::@23 to snprintf_init [phi:smc_flash::@23->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:smc_flash::@23->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 - jsr snprintf_init - // [1916] phi from smc_flash::@23 to smc_flash::@52 [phi:smc_flash::@23->smc_flash::@52] - // smc_flash::@52 - // sprintf(info_text, "There were too many attempts trying to flash the SMC at location %04x", smc_bytes_flashed) - // [1917] call printf_str - // [1210] phi from smc_flash::@52 to printf_str [phi:smc_flash::@52->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:smc_flash::@52->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = smc_flash::s6 [phi:smc_flash::@52->printf_str#1] -- pbuz1=pbuc1 - lda #s6 - sta.z printf_str.s+1 - jsr printf_str - // smc_flash::@53 - // sprintf(info_text, "There were too many attempts trying to flash the SMC at location %04x", smc_bytes_flashed) - // [1918] printf_uint::uvalue#5 = smc_flash::smc_bytes_flashed#12 -- vwum1=vwum2 - lda smc_bytes_flashed - sta printf_uint.uvalue - lda smc_bytes_flashed+1 - sta printf_uint.uvalue+1 - // [1919] call printf_uint - // [2086] phi from smc_flash::@53 to printf_uint [phi:smc_flash::@53->printf_uint] - // [2086] phi printf_uint::format_zero_padding#10 = 1 [phi:smc_flash::@53->printf_uint#0] -- vbum1=vbuc1 - lda #1 - sta printf_uint.format_zero_padding - // [2086] phi printf_uint::format_min_length#10 = 4 [phi:smc_flash::@53->printf_uint#1] -- vbum1=vbuc1 - lda #4 - sta printf_uint.format_min_length - // [2086] phi printf_uint::putc#10 = &snputc [phi:smc_flash::@53->printf_uint#2] -- pprz1=pprc1 - lda #snputc - sta.z printf_uint.putc+1 - // [2086] phi printf_uint::format_radix#10 = HEXADECIMAL [phi:smc_flash::@53->printf_uint#3] -- vbum1=vbuc1 - lda #HEXADECIMAL - sta printf_uint.format_radix - // [2086] phi printf_uint::uvalue#10 = printf_uint::uvalue#5 [phi:smc_flash::@53->printf_uint#4] -- register_copy - jsr printf_uint - // smc_flash::@54 - // sprintf(info_text, "There were too many attempts trying to flash the SMC at location %04x", smc_bytes_flashed) - // [1920] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 - lda #0 + // cputs::@2 + __b2: + // cputc(c) + // [1339] stackpush(char) = cputs::c#1 -- _stackpushbyte_=vbum1 + lda c pha - // [1921] callexecute snputc -- call_vprc1 - jsr snputc + // [1340] callexecute cputc -- call_vprc1 + jsr cputc // sideeffect stackpullpadding(1) -- _stackpullpadding_1 pla - // display_action_text(info_text) - // [1923] call display_action_text - // [1357] phi from smc_flash::@54 to display_action_text [phi:smc_flash::@54->display_action_text] - // [1357] phi display_action_text::info_text#25 = info_text [phi:smc_flash::@54->display_action_text#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z display_action_text.info_text - lda #>@info_text - sta.z display_action_text.info_text+1 - jsr display_action_text - // [1878] phi from smc_flash::@54 to smc_flash::@return [phi:smc_flash::@54->smc_flash::@return] - // [1878] phi smc_flash::return#1 = $ffff [phi:smc_flash::@54->smc_flash::@return#0] -- vwum1=vwuc1 - lda #<$ffff + jmp __b1 + .segment Data + c: .byte 0 +} +.segment Code + // wherex +// Return the x position of the cursor +wherex: { + // return __conio.cursor_x; + // [1342] wherex::return#0 = *((char *)&__conio) -- vbum1=_deref_pbuc1 + lda __conio sta return - lda #>$ffff - sta return+1 + // wherex::@return + // } + // [1343] return rts - // smc_flash::@14 - __b14: - // display_action_text_flashing(8, "SMC", smc_bram_bank, smc_bram_ptr, smc_bytes_flashed) - // [1924] display_action_text_flashing::bram_ptr#1 = smc_flash::smc_bram_ptr#12 -- pbuz1=pbuz2 - lda.z smc_bram_ptr - sta.z display_action_text_flashing.bram_ptr - lda.z smc_bram_ptr+1 - sta.z display_action_text_flashing.bram_ptr+1 - // [1925] display_action_text_flashing::address#1 = smc_flash::smc_bytes_flashed#12 -- vdum1=vwum2 - lda smc_bytes_flashed - sta display_action_text_flashing.address - lda smc_bytes_flashed+1 - sta display_action_text_flashing.address+1 - lda #0 - sta display_action_text_flashing.address+2 - sta display_action_text_flashing.address+3 - // [1926] call display_action_text_flashing - // [2955] phi from smc_flash::@14 to display_action_text_flashing [phi:smc_flash::@14->display_action_text_flashing] - // [2955] phi display_action_text_flashing::address#10 = display_action_text_flashing::address#1 [phi:smc_flash::@14->display_action_text_flashing#0] -- register_copy - // [2955] phi display_action_text_flashing::chip#10 = smc_flash::chip [phi:smc_flash::@14->display_action_text_flashing#1] -- pbuz1=pbuc1 - lda #chip - sta.z display_action_text_flashing.chip+1 - // [2955] phi display_action_text_flashing::bram_ptr#3 = display_action_text_flashing::bram_ptr#1 [phi:smc_flash::@14->display_action_text_flashing#2] -- register_copy - // [2955] phi display_action_text_flashing::bram_bank#3 = smc_flash::smc_bram_bank [phi:smc_flash::@14->display_action_text_flashing#3] -- vbum1=vbuc1 - lda #smc_bram_bank - sta display_action_text_flashing.bram_bank - // [2955] phi display_action_text_flashing::bytes#3 = 8 [phi:smc_flash::@14->display_action_text_flashing#4] -- vdum1=vbuc1 - lda #8 - sta display_action_text_flashing.bytes - lda #0 - sta display_action_text_flashing.bytes+1 - sta display_action_text_flashing.bytes+2 - sta display_action_text_flashing.bytes+3 - jsr display_action_text_flashing - // [1927] phi from smc_flash::@14 to smc_flash::@16 [phi:smc_flash::@14->smc_flash::@16] - // [1927] phi smc_flash::smc_bytes_checksum#2 = 0 [phi:smc_flash::@14->smc_flash::@16#0] -- vbum1=vbuc1 - lda #0 - sta smc_bytes_checksum - // [1927] phi smc_flash::smc_bram_ptr#10 = smc_flash::smc_bram_ptr#12 [phi:smc_flash::@14->smc_flash::@16#1] -- register_copy - // [1927] phi smc_flash::smc_package_flashed#2 = 0 [phi:smc_flash::@14->smc_flash::@16#2] -- vwum1=vwuc1 - sta smc_package_flashed - sta smc_package_flashed+1 - // smc_flash::@16 - __b16: - // while(smc_package_flashed < SMC_PROGRESS_CELL) - // [1928] if(smc_flash::smc_package_flashed#2smc_flash::@13] - // [1910] phi smc_flash::y#21 = smc_flash::y#21 [phi:smc_flash::@19->smc_flash::@13#0] -- register_copy - // [1910] phi smc_flash::smc_row_bytes#11 = smc_flash::smc_row_bytes#11 [phi:smc_flash::@19->smc_flash::@13#1] -- register_copy - // [1910] phi smc_flash::smc_bytes_flashed#12 = smc_flash::smc_bytes_flashed#12 [phi:smc_flash::@19->smc_flash::@13#2] -- register_copy - // [1910] phi smc_flash::smc_bram_ptr#12 = smc_flash::smc_bram_ptr#2 [phi:smc_flash::@19->smc_flash::@13#3] -- register_copy - // [1910] phi smc_flash::smc_attempts_flashed#15 = smc_flash::smc_attempts_flashed#1 [phi:smc_flash::@19->smc_flash::@13#4] -- register_copy - // [1910] phi smc_flash::smc_package_committed#10 = smc_flash::smc_package_committed#10 [phi:smc_flash::@19->smc_flash::@13#5] -- register_copy - jmp __b13 - // smc_flash::@20 - __b20: - // if (smc_row_bytes == SMC_PROGRESS_ROW) - // [1944] if(smc_flash::smc_row_bytes#11!=SMC_PROGRESS_ROW) goto smc_flash::@21 -- vwum1_neq_vwuc1_then_la1 - lda smc_row_bytes+1 - cmp #>SMC_PROGRESS_ROW - bne __b21 - lda smc_row_bytes - cmp #gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#29 [phi:smc_flash::@22->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = PROGRESS_X [phi:smc_flash::@22->gotoxy#1] -- vbum1=vbuc1 - lda #PROGRESS_X - sta gotoxy.x + // [1349] call gotoxy + // [457] phi from cputcxy to gotoxy [phi:cputcxy->gotoxy] + // [457] phi gotoxy::y#26 = gotoxy::y#0 [phi:cputcxy->gotoxy#0] -- register_copy + // [457] phi gotoxy::x#26 = gotoxy::x#0 [phi:cputcxy->gotoxy#1] -- register_copy jsr gotoxy - // [1948] phi from smc_flash::@22 to smc_flash::@21 [phi:smc_flash::@22->smc_flash::@21] - // [1948] phi smc_flash::y#38 = smc_flash::y#1 [phi:smc_flash::@22->smc_flash::@21#0] -- register_copy - // [1948] phi smc_flash::smc_row_bytes#4 = 0 [phi:smc_flash::@22->smc_flash::@21#1] -- vwum1=vbuc1 - lda #<0 - sta smc_row_bytes - sta smc_row_bytes+1 - // [1948] phi from smc_flash::@20 to smc_flash::@21 [phi:smc_flash::@20->smc_flash::@21] - // [1948] phi smc_flash::y#38 = smc_flash::y#21 [phi:smc_flash::@20->smc_flash::@21#0] -- register_copy - // [1948] phi smc_flash::smc_row_bytes#4 = smc_flash::smc_row_bytes#11 [phi:smc_flash::@20->smc_flash::@21#1] -- register_copy - // smc_flash::@21 - __b21: - // cputc('+') - // [1949] stackpush(char) = '+' -- _stackpushbyte_=vbuc1 - lda #'+' + // cputcxy::@1 + // cputc(c) + // [1350] stackpush(char) = cputcxy::c#15 -- _stackpushbyte_=vbum1 + lda c pha - // [1950] callexecute cputc -- call_vprc1 + // [1351] callexecute cputc -- call_vprc1 jsr cputc // sideeffect stackpullpadding(1) -- _stackpullpadding_1 pla - // smc_bytes_flashed += SMC_PROGRESS_CELL - // [1952] smc_flash::smc_bytes_flashed#1 = smc_flash::smc_bytes_flashed#12 + SMC_PROGRESS_CELL -- vwum1=vwum1_plus_vbuc1 - lda #SMC_PROGRESS_CELL - clc - adc smc_bytes_flashed - sta smc_bytes_flashed - bcc !+ - inc smc_bytes_flashed+1 - !: - // smc_row_bytes += SMC_PROGRESS_CELL - // [1953] smc_flash::smc_row_bytes#1 = smc_flash::smc_row_bytes#4 + SMC_PROGRESS_CELL -- vwum1=vwum1_plus_vbuc1 - lda #SMC_PROGRESS_CELL - clc - adc smc_row_bytes - sta smc_row_bytes - bcc !+ - inc smc_row_bytes+1 - !: - // [1910] phi from smc_flash::@21 to smc_flash::@13 [phi:smc_flash::@21->smc_flash::@13] - // [1910] phi smc_flash::y#21 = smc_flash::y#38 [phi:smc_flash::@21->smc_flash::@13#0] -- register_copy - // [1910] phi smc_flash::smc_row_bytes#11 = smc_flash::smc_row_bytes#1 [phi:smc_flash::@21->smc_flash::@13#1] -- register_copy - // [1910] phi smc_flash::smc_bytes_flashed#12 = smc_flash::smc_bytes_flashed#1 [phi:smc_flash::@21->smc_flash::@13#2] -- register_copy - // [1910] phi smc_flash::smc_bram_ptr#12 = smc_flash::smc_bram_ptr#10 [phi:smc_flash::@21->smc_flash::@13#3] -- register_copy - // [1910] phi smc_flash::smc_attempts_flashed#15 = smc_flash::smc_attempts_flashed#15 [phi:smc_flash::@21->smc_flash::@13#4] -- register_copy - // [1910] phi smc_flash::smc_package_committed#10 = 1 [phi:smc_flash::@21->smc_flash::@13#5] -- vbum1=vbuc1 - lda #1 - sta smc_package_committed - jmp __b13 - // smc_flash::@17 - __b17: - // unsigned char smc_byte_upload = *smc_bram_ptr - // [1954] smc_flash::smc_byte_upload#0 = *smc_flash::smc_bram_ptr#10 -- vbum1=_deref_pbuz2 - ldy #0 - lda (smc_bram_ptr),y - sta smc_byte_upload - // smc_bram_ptr++; - // [1955] smc_flash::smc_bram_ptr#1 = ++ smc_flash::smc_bram_ptr#10 -- pbuz1=_inc_pbuz1 - inc.z smc_bram_ptr - bne !+ - inc.z smc_bram_ptr+1 - !: - // smc_bytes_checksum += smc_byte_upload - // [1956] smc_flash::smc_bytes_checksum#1 = smc_flash::smc_bytes_checksum#2 + smc_flash::smc_byte_upload#0 -- vbum1=vbum1_plus_vbum2 - lda smc_bytes_checksum - clc - adc smc_byte_upload - sta smc_bytes_checksum - // unsigned char smc_upload_result = cx16_k_i2c_write_byte(FLASH_I2C_SMC_DEVICE, FLASH_I2C_SMC_UPLOAD, smc_byte_upload) - // [1957] smc_flash::cx16_k_i2c_write_byte3_device = $42 -- vbum1=vbuc1 - lda #$42 - sta cx16_k_i2c_write_byte3_device - // [1958] smc_flash::cx16_k_i2c_write_byte3_offset = $80 -- vbum1=vbuc1 - lda #$80 - sta cx16_k_i2c_write_byte3_offset - // [1959] smc_flash::cx16_k_i2c_write_byte3_value = smc_flash::smc_byte_upload#0 -- vbum1=vbum2 - lda smc_byte_upload - sta cx16_k_i2c_write_byte3_value - // smc_flash::cx16_k_i2c_write_byte3 - // unsigned char result - // [1960] smc_flash::cx16_k_i2c_write_byte3_result = 0 -- vbum1=vbuc1 - lda #0 - sta cx16_k_i2c_write_byte3_result - // asm - // asm { ldxdevice ldyoffset ldavalue stzresult jsrCX16_I2C_WRITE_BYTE rolresult } - ldx cx16_k_i2c_write_byte3_device - ldy cx16_k_i2c_write_byte3_offset - lda cx16_k_i2c_write_byte3_value - stz cx16_k_i2c_write_byte3_result - jsr CX16_I2C_WRITE_BYTE - rol cx16_k_i2c_write_byte3_result - // smc_flash::@26 - // smc_package_flashed++; - // [1962] smc_flash::smc_package_flashed#1 = ++ smc_flash::smc_package_flashed#2 -- vwum1=_inc_vwum1 - inc smc_package_flashed - bne !+ - inc smc_package_flashed+1 - !: - // [1927] phi from smc_flash::@26 to smc_flash::@16 [phi:smc_flash::@26->smc_flash::@16] - // [1927] phi smc_flash::smc_bytes_checksum#2 = smc_flash::smc_bytes_checksum#1 [phi:smc_flash::@26->smc_flash::@16#0] -- register_copy - // [1927] phi smc_flash::smc_bram_ptr#10 = smc_flash::smc_bram_ptr#1 [phi:smc_flash::@26->smc_flash::@16#1] -- register_copy - // [1927] phi smc_flash::smc_package_flashed#2 = smc_flash::smc_package_flashed#1 [phi:smc_flash::@26->smc_flash::@16#2] -- register_copy - jmp __b16 - // [1963] phi from smc_flash::@7 to smc_flash::@8 [phi:smc_flash::@7->smc_flash::@8] - // smc_flash::@8 - __b8: - // wait_moment(1) - // [1964] call wait_moment - // [1310] phi from smc_flash::@8 to wait_moment [phi:smc_flash::@8->wait_moment] - // [1310] phi wait_moment::w#13 = 1 [phi:smc_flash::@8->wait_moment#0] -- vbum1=vbuc1 - lda #1 - sta wait_moment.w - jsr wait_moment - // [1965] phi from smc_flash::@8 to smc_flash::@39 [phi:smc_flash::@8->smc_flash::@39] - // smc_flash::@39 - // sprintf(info_text, "Updating SMC in %u ...", smc_bootloader_activation_countdown) - // [1966] call snprintf_init - // [1205] phi from smc_flash::@39 to snprintf_init [phi:smc_flash::@39->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:smc_flash::@39->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 - jsr snprintf_init - // [1967] phi from smc_flash::@39 to smc_flash::@40 [phi:smc_flash::@39->smc_flash::@40] - // smc_flash::@40 - // sprintf(info_text, "Updating SMC in %u ...", smc_bootloader_activation_countdown) - // [1968] call printf_str - // [1210] phi from smc_flash::@40 to printf_str [phi:smc_flash::@40->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:smc_flash::@40->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = smc_flash::s3 [phi:smc_flash::@40->printf_str#1] -- pbuz1=pbuc1 - lda #s3 - sta.z printf_str.s+1 - jsr printf_str - // smc_flash::@41 - // sprintf(info_text, "Updating SMC in %u ...", smc_bootloader_activation_countdown) - // [1969] printf_uchar::uvalue#12 = smc_flash::smc_bootloader_activation_countdown#12 -- vbum1=vbum2 - lda smc_bootloader_activation_countdown_1 - sta printf_uchar.uvalue - // [1970] call printf_uchar - // [1346] phi from smc_flash::@41 to printf_uchar [phi:smc_flash::@41->printf_uchar] - // [1346] phi printf_uchar::format_zero_padding#18 = 0 [phi:smc_flash::@41->printf_uchar#0] -- vbum1=vbuc1 - lda #0 - sta printf_uchar.format_zero_padding - // [1346] phi printf_uchar::format_min_length#18 = 0 [phi:smc_flash::@41->printf_uchar#1] -- vbum1=vbuc1 - sta printf_uchar.format_min_length - // [1346] phi printf_uchar::putc#18 = &snputc [phi:smc_flash::@41->printf_uchar#2] -- pprz1=pprc1 - lda #snputc - sta.z printf_uchar.putc+1 - // [1346] phi printf_uchar::format_radix#18 = DECIMAL [phi:smc_flash::@41->printf_uchar#3] -- vbum1=vbuc1 - lda #DECIMAL - sta printf_uchar.format_radix - // [1346] phi printf_uchar::uvalue#18 = printf_uchar::uvalue#12 [phi:smc_flash::@41->printf_uchar#4] -- register_copy - jsr printf_uchar - // [1971] phi from smc_flash::@41 to smc_flash::@42 [phi:smc_flash::@41->smc_flash::@42] - // smc_flash::@42 - // sprintf(info_text, "Updating SMC in %u ...", smc_bootloader_activation_countdown) - // [1972] call printf_str - // [1210] phi from smc_flash::@42 to printf_str [phi:smc_flash::@42->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:smc_flash::@42->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s6 [phi:smc_flash::@42->printf_str#1] -- pbuz1=pbuc1 - lda #<@s6 - sta.z printf_str.s - lda #>@s6 - sta.z printf_str.s+1 - jsr printf_str - // smc_flash::@43 - // sprintf(info_text, "Updating SMC in %u ...", smc_bootloader_activation_countdown) - // [1973] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 - lda #0 - pha - // [1974] callexecute snputc -- call_vprc1 - jsr snputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // display_action_text(info_text) - // [1976] call display_action_text - // [1357] phi from smc_flash::@43 to display_action_text [phi:smc_flash::@43->display_action_text] - // [1357] phi display_action_text::info_text#25 = info_text [phi:smc_flash::@43->display_action_text#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z display_action_text.info_text - lda #>@info_text - sta.z display_action_text.info_text+1 - jsr display_action_text - // smc_flash::@44 - // smc_bootloader_activation_countdown--; - // [1977] smc_flash::smc_bootloader_activation_countdown#3 = -- smc_flash::smc_bootloader_activation_countdown#12 -- vbum1=_dec_vbum1 - dec smc_bootloader_activation_countdown_1 - // [1882] phi from smc_flash::@44 to smc_flash::@7 [phi:smc_flash::@44->smc_flash::@7] - // [1882] phi smc_flash::smc_bootloader_activation_countdown#12 = smc_flash::smc_bootloader_activation_countdown#3 [phi:smc_flash::@44->smc_flash::@7#0] -- register_copy - jmp __b7 - // smc_flash::@4 - __b4: - // unsigned int smc_bootloader_not_activated = cx16_k_i2c_read_byte(FLASH_I2C_SMC_DEVICE, FLASH_I2C_SMC_OFFSET) - // [1978] cx16_k_i2c_read_byte::device = $42 -- vbum1=vbuc1 - lda #$42 - sta cx16_k_i2c_read_byte.device - // [1979] cx16_k_i2c_read_byte::offset = $8e -- vbum1=vbuc1 - lda #$8e - sta cx16_k_i2c_read_byte.offset - // [1980] call cx16_k_i2c_read_byte - jsr cx16_k_i2c_read_byte - // [1981] cx16_k_i2c_read_byte::return#11 = cx16_k_i2c_read_byte::return#1 - // smc_flash::@33 - // [1982] smc_flash::smc_bootloader_not_activated1#0 = cx16_k_i2c_read_byte::return#11 - // if(smc_bootloader_not_activated) - // [1983] if(0!=smc_flash::smc_bootloader_not_activated1#0) goto smc_flash::@5 -- 0_neq_vwum1_then_la1 - lda smc_bootloader_not_activated1 - ora smc_bootloader_not_activated1+1 - bne __b5 - jmp __b9 - // [1984] phi from smc_flash::@33 to smc_flash::@5 [phi:smc_flash::@33->smc_flash::@5] - // smc_flash::@5 - __b5: - // wait_moment(1) - // [1985] call wait_moment - // [1310] phi from smc_flash::@5 to wait_moment [phi:smc_flash::@5->wait_moment] - // [1310] phi wait_moment::w#13 = 1 [phi:smc_flash::@5->wait_moment#0] -- vbum1=vbuc1 - lda #1 - sta wait_moment.w - jsr wait_moment - // [1986] phi from smc_flash::@5 to smc_flash::@34 [phi:smc_flash::@5->smc_flash::@34] - // smc_flash::@34 - // sprintf(info_text, "[%03u] Press POWER and RESET on the CX16 to start the SMC update!", smc_bootloader_activation_countdown) - // [1987] call snprintf_init - // [1205] phi from smc_flash::@34 to snprintf_init [phi:smc_flash::@34->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:smc_flash::@34->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 - jsr snprintf_init - // [1988] phi from smc_flash::@34 to smc_flash::@35 [phi:smc_flash::@34->smc_flash::@35] - // smc_flash::@35 - // sprintf(info_text, "[%03u] Press POWER and RESET on the CX16 to start the SMC update!", smc_bootloader_activation_countdown) - // [1989] call printf_str - // [1210] phi from smc_flash::@35 to printf_str [phi:smc_flash::@35->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:smc_flash::@35->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s21 [phi:smc_flash::@35->printf_str#1] -- pbuz1=pbuc1 - lda #s21 - sta.z printf_str.s+1 - jsr printf_str - // smc_flash::@36 - // sprintf(info_text, "[%03u] Press POWER and RESET on the CX16 to start the SMC update!", smc_bootloader_activation_countdown) - // [1990] printf_uchar::uvalue#11 = smc_flash::smc_bootloader_activation_countdown#10 -- vbum1=vbum2 - lda smc_bootloader_activation_countdown - sta printf_uchar.uvalue - // [1991] call printf_uchar - // [1346] phi from smc_flash::@36 to printf_uchar [phi:smc_flash::@36->printf_uchar] - // [1346] phi printf_uchar::format_zero_padding#18 = 1 [phi:smc_flash::@36->printf_uchar#0] -- vbum1=vbuc1 - lda #1 - sta printf_uchar.format_zero_padding - // [1346] phi printf_uchar::format_min_length#18 = 3 [phi:smc_flash::@36->printf_uchar#1] -- vbum1=vbuc1 - lda #3 - sta printf_uchar.format_min_length - // [1346] phi printf_uchar::putc#18 = &snputc [phi:smc_flash::@36->printf_uchar#2] -- pprz1=pprc1 - lda #snputc - sta.z printf_uchar.putc+1 - // [1346] phi printf_uchar::format_radix#18 = DECIMAL [phi:smc_flash::@36->printf_uchar#3] -- vbum1=vbuc1 - lda #DECIMAL - sta printf_uchar.format_radix - // [1346] phi printf_uchar::uvalue#18 = printf_uchar::uvalue#11 [phi:smc_flash::@36->printf_uchar#4] -- register_copy - jsr printf_uchar - // [1992] phi from smc_flash::@36 to smc_flash::@37 [phi:smc_flash::@36->smc_flash::@37] - // smc_flash::@37 - // sprintf(info_text, "[%03u] Press POWER and RESET on the CX16 to start the SMC update!", smc_bootloader_activation_countdown) - // [1993] call printf_str - // [1210] phi from smc_flash::@37 to printf_str [phi:smc_flash::@37->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:smc_flash::@37->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = smc_flash::s2 [phi:smc_flash::@37->printf_str#1] -- pbuz1=pbuc1 - lda #s2 - sta.z printf_str.s+1 - jsr printf_str - // smc_flash::@38 - // sprintf(info_text, "[%03u] Press POWER and RESET on the CX16 to start the SMC update!", smc_bootloader_activation_countdown) - // [1994] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 - lda #0 - pha - // [1995] callexecute snputc -- call_vprc1 - jsr snputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // display_action_text(info_text) - // [1997] call display_action_text - // [1357] phi from smc_flash::@38 to display_action_text [phi:smc_flash::@38->display_action_text] - // [1357] phi display_action_text::info_text#25 = info_text [phi:smc_flash::@38->display_action_text#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z display_action_text.info_text - lda #>@info_text - sta.z display_action_text.info_text+1 - jsr display_action_text - // smc_flash::@6 - // smc_bootloader_activation_countdown--; - // [1998] smc_flash::smc_bootloader_activation_countdown#2 = -- smc_flash::smc_bootloader_activation_countdown#10 -- vbum1=_dec_vbum1 - dec smc_bootloader_activation_countdown - // [1880] phi from smc_flash::@6 to smc_flash::@3 [phi:smc_flash::@6->smc_flash::@3] - // [1880] phi smc_flash::smc_bootloader_activation_countdown#10 = smc_flash::smc_bootloader_activation_countdown#2 [phi:smc_flash::@6->smc_flash::@3#0] -- register_copy - jmp __b3 + // cputcxy::@return + // } + // [1353] return + rts .segment Data - info_text: .text "To start the SMC update, do the following ..." - .byte 0 - s: .text "There was a problem starting the SMC bootloader: " - .byte 0 - s2: .text "] Press POWER and RESET on the CX16 to start the SMC update!" - .byte 0 - s3: .text "Updating SMC in " - .byte 0 - info_text1: .text "Updating SMC firmware ... (+) Updated" - .byte 0 - s5: .text "There was a problem activating the SMC bootloader: " - .byte 0 - chip: .text "SMC" - .byte 0 - s6: .text "There were too many attempts trying to flash the SMC at location " - .byte 0 - cx16_k_i2c_write_byte1_device: .byte 0 - cx16_k_i2c_write_byte1_offset: .byte 0 - cx16_k_i2c_write_byte1_value: .byte 0 - cx16_k_i2c_write_byte1_result: .byte 0 - cx16_k_i2c_write_byte2_device: .byte 0 - cx16_k_i2c_write_byte2_offset: .byte 0 - cx16_k_i2c_write_byte2_value: .byte 0 - cx16_k_i2c_write_byte2_result: .byte 0 - cx16_k_i2c_write_byte3_device: .byte 0 - cx16_k_i2c_write_byte3_offset: .byte 0 - cx16_k_i2c_write_byte3_value: .byte 0 - cx16_k_i2c_write_byte3_result: .byte 0 - cx16_k_i2c_write_byte4_device: .byte 0 - cx16_k_i2c_write_byte4_offset: .byte 0 - cx16_k_i2c_write_byte4_value: .byte 0 - cx16_k_i2c_write_byte4_result: .byte 0 - cx16_k_i2c_write_byte1_return: .byte 0 - .label smc_bootloader_start = cx16_k_i2c_write_byte1_return - return: .word 0 - .label smc_bootloader_not_activated1 = smc_detect.return - // Waiting a bit to ensure the bootloader is activated. - smc_bootloader_activation_countdown: .byte 0 - // Waiting a bit to ensure the bootloader is activated. - smc_bootloader_activation_countdown_1: .byte 0 - .label smc_bootloader_not_activated = smc_detect.return - smc_byte_upload: .byte 0 - smc_bytes_checksum: .byte 0 - smc_package_flashed: .word 0 - .label smc_commit_result = smc_detect.return - smc_attempts_flashed: .byte 0 - .label smc_bytes_flashed = return - smc_row_bytes: .word 0 + x: .byte 0 y: .byte 0 - smc_bytes_total: .word 0 - smc_package_committed: .byte 0 + c: .byte 0 } .segment Code - // util_wait_key + // display_smc_led /** - * @brief + * @brief Print SMC led above the SMC chip. * - * @param info_text - * @param filter - * @return unsigned char + * @param c Led color */ -// __mem() char util_wait_key(__zp($4a) char *info_text, __zp($43) char *filter) -util_wait_key: { - .const bank_set_bram1_bank = 0 - .const bank_set_brom1_bank = 4 - .label util_wait_key__9 = $5e - .label info_text = $4a - .label filter = $43 - // display_action_text(info_text) - // [2000] display_action_text::info_text#10 = util_wait_key::info_text#3 - // [2001] call display_action_text - // [1357] phi from util_wait_key to display_action_text [phi:util_wait_key->display_action_text] - // [1357] phi display_action_text::info_text#25 = display_action_text::info_text#10 [phi:util_wait_key->display_action_text#0] -- register_copy - jsr display_action_text - // util_wait_key::bank_get_bram1 - // return BRAM; - // [2002] util_wait_key::bram#0 = BRAM -- vbum1=vbuz2 - lda.z BRAM - sta bram - // util_wait_key::bank_get_brom1 - // return BROM; - // [2003] util_wait_key::bank_get_brom1_return#0 = BROM -- vbum1=vbuz2 - lda.z BROM - sta bank_get_brom1_return - // util_wait_key::bank_set_bram1 - // BRAM = bank - // [2004] BRAM = util_wait_key::bank_set_bram1_bank#0 -- vbuz1=vbuc1 - lda #bank_set_bram1_bank - sta.z BRAM - // util_wait_key::bank_set_brom1 - // BROM = bank - // [2005] BROM = util_wait_key::bank_set_brom1_bank#0 -- vbuz1=vbuc1 - lda #bank_set_brom1_bank - sta.z BROM - // [2006] phi from util_wait_key::@2 util_wait_key::@5 util_wait_key::bank_set_brom1 to util_wait_key::kbhit1 [phi:util_wait_key::@2/util_wait_key::@5/util_wait_key::bank_set_brom1->util_wait_key::kbhit1] - // util_wait_key::kbhit1 - kbhit1: - // util_wait_key::kbhit1_cbm_k_clrchn1 - // asm - // asm { jsrCBM_CLRCHN } - jsr CBM_CLRCHN - // [2008] phi from util_wait_key::kbhit1_cbm_k_clrchn1 to util_wait_key::kbhit1_@2 [phi:util_wait_key::kbhit1_cbm_k_clrchn1->util_wait_key::kbhit1_@2] - // util_wait_key::kbhit1_@2 - // cbm_k_getin() - // [2009] call cbm_k_getin - jsr cbm_k_getin - // [2010] cbm_k_getin::return#2 = cbm_k_getin::return#1 - // util_wait_key::@4 - // [2011] util_wait_key::ch#4 = cbm_k_getin::return#2 -- vwum1=vbum2 - lda cbm_k_getin.return - sta ch - lda #0 - sta ch+1 - // util_wait_key::@3 - // if (filter) - // [2012] if((char *)0!=util_wait_key::filter#13) goto util_wait_key::@1 -- pbuc1_neq_pbuz1_then_la1 - // if there is a filter, check the filter, otherwise return ch. - lda.z filter+1 - cmp #>0 - bne __b1 - lda.z filter - cmp #<0 - bne __b1 - // util_wait_key::@2 - // if(ch) - // [2013] if(0!=util_wait_key::ch#4) goto util_wait_key::bank_set_bram2 -- 0_neq_vwum1_then_la1 - lda ch - ora ch+1 - bne bank_set_bram2 - jmp kbhit1 - // util_wait_key::bank_set_bram2 - bank_set_bram2: - // BRAM = bank - // [2014] BRAM = util_wait_key::bram#0 -- vbuz1=vbum2 - lda bram - sta.z BRAM - // util_wait_key::bank_set_brom2 - // BROM = bank - // [2015] BROM = util_wait_key::bank_get_brom1_return#0 -- vbuz1=vbum2 - lda bank_get_brom1_return - sta.z BROM - // util_wait_key::@return - // } - // [2016] return - rts - // util_wait_key::@1 - __b1: - // strchr(filter, ch) - // [2017] strchr::str#0 = (const void *)util_wait_key::filter#13 -- pvoz1=pvoz2 - lda.z filter - sta.z strchr.str - lda.z filter+1 - sta.z strchr.str+1 - // [2018] strchr::c#0 = util_wait_key::ch#4 -- vbum1=vwum2 - lda ch - sta strchr.c - // [2019] call strchr - // [2023] phi from util_wait_key::@1 to strchr [phi:util_wait_key::@1->strchr] - // [2023] phi strchr::c#4 = strchr::c#0 [phi:util_wait_key::@1->strchr#0] -- register_copy - // [2023] phi strchr::str#2 = strchr::str#0 [phi:util_wait_key::@1->strchr#1] -- register_copy - jsr strchr - // strchr(filter, ch) - // [2020] strchr::return#3 = strchr::return#2 - // util_wait_key::@5 - // [2021] util_wait_key::$9 = strchr::return#3 - // if(strchr(filter, ch) != NULL) - // [2022] if(util_wait_key::$9!=0) goto util_wait_key::bank_set_bram2 -- pvoz1_neq_0_then_la1 - lda.z util_wait_key__9 - ora.z util_wait_key__9+1 - bne bank_set_bram2 - jmp kbhit1 - .segment Data - bram: .byte 0 - bank_get_brom1_return: .byte 0 - return: .byte 0 - return_1: .byte 0 - ch: .word 0 -} -.segment Code - // strchr -// Searches for the first occurrence of the character c (an unsigned char) in the string pointed to, by the argument str. -// - str: The memory to search -// - c: A character to search for -// Return: A pointer to the matching byte or NULL if the character does not occur in the given memory area. -// __zp($5e) void * strchr(__zp($5e) const void *str, __mem() char c) -strchr: { - .label ptr = $5e - .label return = $5e - .label str = $5e - // [2024] strchr::ptr#6 = (char *)strchr::str#2 - // [2025] phi from strchr strchr::@3 to strchr::@1 [phi:strchr/strchr::@3->strchr::@1] - // [2025] phi strchr::ptr#2 = strchr::ptr#6 [phi:strchr/strchr::@3->strchr::@1#0] -- register_copy - // strchr::@1 - __b1: - // while(*ptr) - // [2026] if(0!=*strchr::ptr#2) goto strchr::@2 -- 0_neq__deref_pbuz1_then_la1 - ldy #0 - lda (ptr),y - cmp #0 - bne __b2 - // [2027] phi from strchr::@1 to strchr::@return [phi:strchr::@1->strchr::@return] - // [2027] phi strchr::return#2 = (void *) 0 [phi:strchr::@1->strchr::@return#0] -- pvoz1=pvoc1 - tya - sta.z return - sta.z return+1 - // strchr::@return +// void display_smc_led(__mem() char c) +display_smc_led: { + // display_chip_led(CHIP_SMC_X+1, CHIP_SMC_Y, CHIP_SMC_W, c, BLUE) + // [1355] display_chip_led::tc#0 = display_smc_led::c#2 -- vbum1=vbum2 + lda c + sta display_chip_led.tc + // [1356] call display_chip_led + // [1802] phi from display_smc_led to display_chip_led [phi:display_smc_led->display_chip_led] + // [1802] phi display_chip_led::w#7 = 5 [phi:display_smc_led->display_chip_led#0] -- vbum1=vbuc1 + lda #5 + sta display_chip_led.w + // [1802] phi display_chip_led::x#7 = 1+1 [phi:display_smc_led->display_chip_led#1] -- vbum1=vbuc1 + lda #1+1 + sta display_chip_led.x + // [1802] phi display_chip_led::tc#3 = display_chip_led::tc#0 [phi:display_smc_led->display_chip_led#2] -- register_copy + jsr display_chip_led + // display_smc_led::@1 + // display_info_led(INFO_X-2, INFO_Y, c, BLUE) + // [1357] display_info_led::tc#0 = display_smc_led::c#2 + // [1358] call display_info_led + // [1444] phi from display_smc_led::@1 to display_info_led [phi:display_smc_led::@1->display_info_led] + // [1444] phi display_info_led::y#4 = $11 [phi:display_smc_led::@1->display_info_led#0] -- vbum1=vbuc1 + lda #$11 + sta display_info_led.y + // [1444] phi display_info_led::x#4 = 4-2 [phi:display_smc_led::@1->display_info_led#1] -- vbum1=vbuc1 + lda #4-2 + sta display_info_led.x + // [1444] phi display_info_led::tc#4 = display_info_led::tc#0 [phi:display_smc_led::@1->display_info_led#2] -- register_copy + jsr display_info_led + // display_smc_led::@return // } - // [2028] return - rts - // strchr::@2 - __b2: - // if(*ptr==c) - // [2029] if(*strchr::ptr#2!=strchr::c#4) goto strchr::@3 -- _deref_pbuz1_neq_vbum2_then_la1 - ldy #0 - lda (ptr),y - cmp c - bne __b3 - // strchr::@4 - // [2030] strchr::return#8 = (void *)strchr::ptr#2 - // [2027] phi from strchr::@4 to strchr::@return [phi:strchr::@4->strchr::@return] - // [2027] phi strchr::return#2 = strchr::return#8 [phi:strchr::@4->strchr::@return#0] -- register_copy + // [1359] return rts - // strchr::@3 - __b3: - // ptr++; - // [2031] strchr::ptr#1 = ++ strchr::ptr#2 -- pbuz1=_inc_pbuz1 - inc.z ptr - bne !+ - inc.z ptr+1 - !: - jmp __b1 .segment Data c: .byte 0 } .segment Code - // display_info_cx16_rom + // display_print_chip /** - * @brief Display the ROM status of the main CX16 ROM chip. + * @brief Print a full chip. * - * @param info_status The status. - * @param info_text The status text. + * @param x Start X + * @param y Start Y + * @param w Width + * @param text Vertical text to be displayed in the chip, starting from the top. */ -// void display_info_cx16_rom(__mem() char info_status, __zp($3f) char *info_text) -display_info_cx16_rom: { - .label info_text = $3f - // display_info_rom(0, info_status, info_text) - // [2033] display_info_rom::info_status#0 = display_info_cx16_rom::info_status#4 - // [2034] display_info_rom::info_text#0 = display_info_cx16_rom::info_text#4 - // [2035] call display_info_rom - // [1546] phi from display_info_cx16_rom to display_info_rom [phi:display_info_cx16_rom->display_info_rom] - // [1546] phi display_info_rom::info_text#17 = display_info_rom::info_text#0 [phi:display_info_cx16_rom->display_info_rom#0] -- register_copy - // [1546] phi display_info_rom::rom_chip#17 = 0 [phi:display_info_cx16_rom->display_info_rom#1] -- vbum1=vbuc1 - lda #0 - sta display_info_rom.rom_chip - // [1546] phi display_info_rom::info_status#17 = display_info_rom::info_status#0 [phi:display_info_cx16_rom->display_info_rom#2] -- register_copy - jsr display_info_rom - // display_info_cx16_rom::@return +// void display_print_chip(__mem() char x, char y, __mem() char w, __zp($51) char *text) +display_print_chip: { + .label y = 3+2+1+1+1+1+1+1+1+1 + .label text = $51 + .label text_1 = $4f + .label text_2 = $40 + .label text_3 = $6c + .label text_4 = $4b + .label text_5 = $45 + .label text_6 = $53 + // display_chip_line(x, y++, w, *text++) + // [1361] display_chip_line::x#0 = display_print_chip::x#10 -- vbum1=vbum2 + lda x + sta display_chip_line.x + // [1362] display_chip_line::w#0 = display_print_chip::w#10 -- vbum1=vbum2 + lda w + sta display_chip_line.w + // [1363] display_chip_line::c#0 = *display_print_chip::text#11 -- vbum1=_deref_pbuz2 + ldy #0 + lda (text_2),y + sta display_chip_line.c + // [1364] call display_chip_line + // [1820] phi from display_print_chip to display_chip_line [phi:display_print_chip->display_chip_line] + // [1820] phi display_chip_line::c#15 = display_chip_line::c#0 [phi:display_print_chip->display_chip_line#0] -- register_copy + // [1820] phi display_chip_line::w#10 = display_chip_line::w#0 [phi:display_print_chip->display_chip_line#1] -- register_copy + // [1820] phi display_chip_line::y#16 = 3+2 [phi:display_print_chip->display_chip_line#2] -- vbum1=vbuc1 + lda #3+2 + sta display_chip_line.y + // [1820] phi display_chip_line::x#16 = display_chip_line::x#0 [phi:display_print_chip->display_chip_line#3] -- register_copy + jsr display_chip_line + // display_print_chip::@1 + // display_chip_line(x, y++, w, *text++); + // [1365] display_print_chip::text#0 = ++ display_print_chip::text#11 -- pbuz1=_inc_pbuz2 + clc + lda.z text_2 + adc #1 + sta.z text + lda.z text_2+1 + adc #0 + sta.z text+1 + // display_chip_line(x, y++, w, *text++) + // [1366] display_chip_line::x#1 = display_print_chip::x#10 -- vbum1=vbum2 + lda x + sta display_chip_line.x + // [1367] display_chip_line::w#1 = display_print_chip::w#10 -- vbum1=vbum2 + lda w + sta display_chip_line.w + // [1368] display_chip_line::c#1 = *display_print_chip::text#0 -- vbum1=_deref_pbuz2 + ldy #0 + lda (text),y + sta display_chip_line.c + // [1369] call display_chip_line + // [1820] phi from display_print_chip::@1 to display_chip_line [phi:display_print_chip::@1->display_chip_line] + // [1820] phi display_chip_line::c#15 = display_chip_line::c#1 [phi:display_print_chip::@1->display_chip_line#0] -- register_copy + // [1820] phi display_chip_line::w#10 = display_chip_line::w#1 [phi:display_print_chip::@1->display_chip_line#1] -- register_copy + // [1820] phi display_chip_line::y#16 = ++3+2 [phi:display_print_chip::@1->display_chip_line#2] -- vbum1=vbuc1 + lda #3+2+1 + sta display_chip_line.y + // [1820] phi display_chip_line::x#16 = display_chip_line::x#1 [phi:display_print_chip::@1->display_chip_line#3] -- register_copy + jsr display_chip_line + // display_print_chip::@2 + // display_chip_line(x, y++, w, *text++); + // [1370] display_print_chip::text#1 = ++ display_print_chip::text#0 -- pbuz1=_inc_pbuz2 + clc + lda.z text + adc #1 + sta.z text_1 + lda.z text+1 + adc #0 + sta.z text_1+1 + // display_chip_line(x, y++, w, *text++) + // [1371] display_chip_line::x#2 = display_print_chip::x#10 -- vbum1=vbum2 + lda x + sta display_chip_line.x + // [1372] display_chip_line::w#2 = display_print_chip::w#10 -- vbum1=vbum2 + lda w + sta display_chip_line.w + // [1373] display_chip_line::c#2 = *display_print_chip::text#1 -- vbum1=_deref_pbuz2 + ldy #0 + lda (text_1),y + sta display_chip_line.c + // [1374] call display_chip_line + // [1820] phi from display_print_chip::@2 to display_chip_line [phi:display_print_chip::@2->display_chip_line] + // [1820] phi display_chip_line::c#15 = display_chip_line::c#2 [phi:display_print_chip::@2->display_chip_line#0] -- register_copy + // [1820] phi display_chip_line::w#10 = display_chip_line::w#2 [phi:display_print_chip::@2->display_chip_line#1] -- register_copy + // [1820] phi display_chip_line::y#16 = ++++3+2 [phi:display_print_chip::@2->display_chip_line#2] -- vbum1=vbuc1 + lda #3+2+1+1 + sta display_chip_line.y + // [1820] phi display_chip_line::x#16 = display_chip_line::x#2 [phi:display_print_chip::@2->display_chip_line#3] -- register_copy + jsr display_chip_line + // display_print_chip::@3 + // display_chip_line(x, y++, w, *text++); + // [1375] display_print_chip::text#15 = ++ display_print_chip::text#1 -- pbuz1=_inc_pbuz2 + clc + lda.z text_1 + adc #1 + sta.z text_3 + lda.z text_1+1 + adc #0 + sta.z text_3+1 + // display_chip_line(x, y++, w, *text++) + // [1376] display_chip_line::x#3 = display_print_chip::x#10 -- vbum1=vbum2 + lda x + sta display_chip_line.x + // [1377] display_chip_line::w#3 = display_print_chip::w#10 -- vbum1=vbum2 + lda w + sta display_chip_line.w + // [1378] display_chip_line::c#3 = *display_print_chip::text#15 -- vbum1=_deref_pbuz2 + ldy #0 + lda (text_3),y + sta display_chip_line.c + // [1379] call display_chip_line + // [1820] phi from display_print_chip::@3 to display_chip_line [phi:display_print_chip::@3->display_chip_line] + // [1820] phi display_chip_line::c#15 = display_chip_line::c#3 [phi:display_print_chip::@3->display_chip_line#0] -- register_copy + // [1820] phi display_chip_line::w#10 = display_chip_line::w#3 [phi:display_print_chip::@3->display_chip_line#1] -- register_copy + // [1820] phi display_chip_line::y#16 = ++++++3+2 [phi:display_print_chip::@3->display_chip_line#2] -- vbum1=vbuc1 + lda #3+2+1+1+1 + sta display_chip_line.y + // [1820] phi display_chip_line::x#16 = display_chip_line::x#3 [phi:display_print_chip::@3->display_chip_line#3] -- register_copy + jsr display_chip_line + // display_print_chip::@4 + // display_chip_line(x, y++, w, *text++); + // [1380] display_print_chip::text#16 = ++ display_print_chip::text#15 -- pbuz1=_inc_pbuz2 + clc + lda.z text_3 + adc #1 + sta.z text_4 + lda.z text_3+1 + adc #0 + sta.z text_4+1 + // display_chip_line(x, y++, w, *text++) + // [1381] display_chip_line::x#4 = display_print_chip::x#10 -- vbum1=vbum2 + lda x + sta display_chip_line.x + // [1382] display_chip_line::w#4 = display_print_chip::w#10 -- vbum1=vbum2 + lda w + sta display_chip_line.w + // [1383] display_chip_line::c#4 = *display_print_chip::text#16 -- vbum1=_deref_pbuz2 + ldy #0 + lda (text_4),y + sta display_chip_line.c + // [1384] call display_chip_line + // [1820] phi from display_print_chip::@4 to display_chip_line [phi:display_print_chip::@4->display_chip_line] + // [1820] phi display_chip_line::c#15 = display_chip_line::c#4 [phi:display_print_chip::@4->display_chip_line#0] -- register_copy + // [1820] phi display_chip_line::w#10 = display_chip_line::w#4 [phi:display_print_chip::@4->display_chip_line#1] -- register_copy + // [1820] phi display_chip_line::y#16 = ++++++++3+2 [phi:display_print_chip::@4->display_chip_line#2] -- vbum1=vbuc1 + lda #3+2+1+1+1+1 + sta display_chip_line.y + // [1820] phi display_chip_line::x#16 = display_chip_line::x#4 [phi:display_print_chip::@4->display_chip_line#3] -- register_copy + jsr display_chip_line + // display_print_chip::@5 + // display_chip_line(x, y++, w, *text++); + // [1385] display_print_chip::text#17 = ++ display_print_chip::text#16 -- pbuz1=_inc_pbuz2 + clc + lda.z text_4 + adc #1 + sta.z text_5 + lda.z text_4+1 + adc #0 + sta.z text_5+1 + // display_chip_line(x, y++, w, *text++) + // [1386] display_chip_line::x#5 = display_print_chip::x#10 -- vbum1=vbum2 + lda x + sta display_chip_line.x + // [1387] display_chip_line::w#5 = display_print_chip::w#10 -- vbum1=vbum2 + lda w + sta display_chip_line.w + // [1388] display_chip_line::c#5 = *display_print_chip::text#17 -- vbum1=_deref_pbuz2 + ldy #0 + lda (text_5),y + sta display_chip_line.c + // [1389] call display_chip_line + // [1820] phi from display_print_chip::@5 to display_chip_line [phi:display_print_chip::@5->display_chip_line] + // [1820] phi display_chip_line::c#15 = display_chip_line::c#5 [phi:display_print_chip::@5->display_chip_line#0] -- register_copy + // [1820] phi display_chip_line::w#10 = display_chip_line::w#5 [phi:display_print_chip::@5->display_chip_line#1] -- register_copy + // [1820] phi display_chip_line::y#16 = ++++++++++3+2 [phi:display_print_chip::@5->display_chip_line#2] -- vbum1=vbuc1 + lda #3+2+1+1+1+1+1 + sta display_chip_line.y + // [1820] phi display_chip_line::x#16 = display_chip_line::x#5 [phi:display_print_chip::@5->display_chip_line#3] -- register_copy + jsr display_chip_line + // display_print_chip::@6 + // display_chip_line(x, y++, w, *text++); + // [1390] display_print_chip::text#18 = ++ display_print_chip::text#17 -- pbuz1=_inc_pbuz2 + clc + lda.z text_5 + adc #1 + sta.z text_6 + lda.z text_5+1 + adc #0 + sta.z text_6+1 + // display_chip_line(x, y++, w, *text++) + // [1391] display_chip_line::x#6 = display_print_chip::x#10 -- vbum1=vbum2 + lda x + sta display_chip_line.x + // [1392] display_chip_line::w#6 = display_print_chip::w#10 -- vbum1=vbum2 + lda w + sta display_chip_line.w + // [1393] display_chip_line::c#6 = *display_print_chip::text#18 -- vbum1=_deref_pbuz2 + ldy #0 + lda (text_6),y + sta display_chip_line.c + // [1394] call display_chip_line + // [1820] phi from display_print_chip::@6 to display_chip_line [phi:display_print_chip::@6->display_chip_line] + // [1820] phi display_chip_line::c#15 = display_chip_line::c#6 [phi:display_print_chip::@6->display_chip_line#0] -- register_copy + // [1820] phi display_chip_line::w#10 = display_chip_line::w#6 [phi:display_print_chip::@6->display_chip_line#1] -- register_copy + // [1820] phi display_chip_line::y#16 = ++++++++++++3+2 [phi:display_print_chip::@6->display_chip_line#2] -- vbum1=vbuc1 + lda #3+2+1+1+1+1+1+1 + sta display_chip_line.y + // [1820] phi display_chip_line::x#16 = display_chip_line::x#6 [phi:display_print_chip::@6->display_chip_line#3] -- register_copy + jsr display_chip_line + // display_print_chip::@7 + // display_chip_line(x, y++, w, *text++); + // [1395] display_print_chip::text#19 = ++ display_print_chip::text#18 -- pbuz1=_inc_pbuz1 + inc.z text_6 + bne !+ + inc.z text_6+1 + !: + // display_chip_line(x, y++, w, *text++) + // [1396] display_chip_line::x#7 = display_print_chip::x#10 -- vbum1=vbum2 + lda x + sta display_chip_line.x + // [1397] display_chip_line::w#7 = display_print_chip::w#10 -- vbum1=vbum2 + lda w + sta display_chip_line.w + // [1398] display_chip_line::c#7 = *display_print_chip::text#19 -- vbum1=_deref_pbuz2 + ldy #0 + lda (text_6),y + sta display_chip_line.c + // [1399] call display_chip_line + // [1820] phi from display_print_chip::@7 to display_chip_line [phi:display_print_chip::@7->display_chip_line] + // [1820] phi display_chip_line::c#15 = display_chip_line::c#7 [phi:display_print_chip::@7->display_chip_line#0] -- register_copy + // [1820] phi display_chip_line::w#10 = display_chip_line::w#7 [phi:display_print_chip::@7->display_chip_line#1] -- register_copy + // [1820] phi display_chip_line::y#16 = ++++++++++++++3+2 [phi:display_print_chip::@7->display_chip_line#2] -- vbum1=vbuc1 + lda #3+2+1+1+1+1+1+1+1 + sta display_chip_line.y + // [1820] phi display_chip_line::x#16 = display_chip_line::x#7 [phi:display_print_chip::@7->display_chip_line#3] -- register_copy + jsr display_chip_line + // display_print_chip::@8 + // display_chip_end(x, y++, w) + // [1400] display_chip_end::x#0 = display_print_chip::x#10 + // [1401] display_chip_end::w#0 = display_print_chip::w#10 -- vbum1=vbum2 + lda w + sta display_chip_end.w + // [1402] call display_chip_end + jsr display_chip_end + // display_print_chip::@return // } - // [2036] return + // [1403] return rts .segment Data - .label info_status = display_info_rom.info_status + x: .byte 0 + w: .byte 0 } .segment Code - // rom_get_release + // display_vera_led /** - * @brief Calculate the correct ROM release number. - * The 2's complement is taken if bit 7 is set of the release number. + * @brief Print VERA led above the VERA chip. * - * @param release The raw release number. - * @return unsigned char The release potentially taken 2's complement. + * @param c Led color */ -// __mem() char rom_get_release(__mem() char release) -rom_get_release: { - .label rom_get_release__0 = $c2 - .label rom_get_release__2 = $60 - // release & 0x80 - // [2038] rom_get_release::$0 = rom_get_release::release#3 & $80 -- vbuz1=vbum2_band_vbuc1 - lda #$80 - and release - sta.z rom_get_release__0 - // if(release & 0x80) - // [2039] if(0==rom_get_release::$0) goto rom_get_release::@1 -- 0_eq_vbuz1_then_la1 - beq __b1 - // rom_get_release::@2 - // ~release - // [2040] rom_get_release::$2 = ~ rom_get_release::release#3 -- vbuz1=_bnot_vbum2 - lda release - eor #$ff - sta.z rom_get_release__2 - // release = ~release + 1 - // [2041] rom_get_release::release#0 = rom_get_release::$2 + 1 -- vbum1=vbuz2_plus_1 - inc - sta release - // [2042] phi from rom_get_release rom_get_release::@2 to rom_get_release::@1 [phi:rom_get_release/rom_get_release::@2->rom_get_release::@1] - // [2042] phi rom_get_release::return#0 = rom_get_release::release#3 [phi:rom_get_release/rom_get_release::@2->rom_get_release::@1#0] -- register_copy - // rom_get_release::@1 - __b1: - // rom_get_release::@return +// void display_vera_led(__mem() char c) +display_vera_led: { + // display_chip_led(CHIP_VERA_X+1, CHIP_VERA_Y, CHIP_VERA_W, c, BLUE) + // [1405] display_chip_led::tc#1 = display_vera_led::c#2 -- vbum1=vbum2 + lda c + sta display_chip_led.tc + // [1406] call display_chip_led + // [1802] phi from display_vera_led to display_chip_led [phi:display_vera_led->display_chip_led] + // [1802] phi display_chip_led::w#7 = 8 [phi:display_vera_led->display_chip_led#0] -- vbum1=vbuc1 + lda #8 + sta display_chip_led.w + // [1802] phi display_chip_led::x#7 = 9+1 [phi:display_vera_led->display_chip_led#1] -- vbum1=vbuc1 + lda #9+1 + sta display_chip_led.x + // [1802] phi display_chip_led::tc#3 = display_chip_led::tc#1 [phi:display_vera_led->display_chip_led#2] -- register_copy + jsr display_chip_led + // display_vera_led::@1 + // display_info_led(INFO_X-2, INFO_Y+1, c, BLUE) + // [1407] display_info_led::tc#1 = display_vera_led::c#2 -- vbum1=vbum2 + lda c + sta display_info_led.tc + // [1408] call display_info_led + // [1444] phi from display_vera_led::@1 to display_info_led [phi:display_vera_led::@1->display_info_led] + // [1444] phi display_info_led::y#4 = $11+1 [phi:display_vera_led::@1->display_info_led#0] -- vbum1=vbuc1 + lda #$11+1 + sta display_info_led.y + // [1444] phi display_info_led::x#4 = 4-2 [phi:display_vera_led::@1->display_info_led#1] -- vbum1=vbuc1 + lda #4-2 + sta display_info_led.x + // [1444] phi display_info_led::tc#4 = display_info_led::tc#1 [phi:display_vera_led::@1->display_info_led#2] -- register_copy + jsr display_info_led + // display_vera_led::@return // } - // [2043] return + // [1409] return rts .segment Data - return: .byte 0 - .label release = return + c: .byte 0 } .segment Code - // rom_get_prefix -/** - * @brief Determine the prefix of the ROM release number. - * If the version is 0xFF or bit 7 of the version is set, then the release is a preview. - * - * @param rom_chip The ROM chip to calculate the release. - * @param release The release potentially taken 2's complement. - * @return unsigned char 'r' if the release is official, 'p' if the release is inofficial of 0xFF. - */ -// __mem() char rom_get_prefix(__mem() char release) -rom_get_prefix: { - .label rom_get_prefix__2 = $c2 - // if(release == 0xFF) - // [2045] if(rom_get_prefix::release#2!=$ff) goto rom_get_prefix::@1 -- vbum1_neq_vbuc1_then_la1 - lda #$ff - cmp release - bne __b3 - // [2046] phi from rom_get_prefix to rom_get_prefix::@3 [phi:rom_get_prefix->rom_get_prefix::@3] - // rom_get_prefix::@3 - // [2047] phi from rom_get_prefix::@3 to rom_get_prefix::@1 [phi:rom_get_prefix::@3->rom_get_prefix::@1] - // [2047] phi rom_get_prefix::prefix#4 = 'p' [phi:rom_get_prefix::@3->rom_get_prefix::@1#0] -- vbum1=vbuc1 - lda #'p' - sta prefix - jmp __b1 - // [2047] phi from rom_get_prefix to rom_get_prefix::@1 [phi:rom_get_prefix->rom_get_prefix::@1] - __b3: - // [2047] phi rom_get_prefix::prefix#4 = 'r' [phi:rom_get_prefix->rom_get_prefix::@1#0] -- vbum1=vbuc1 - lda #'r' - sta prefix - // rom_get_prefix::@1 + // strcat +// Concatenates the C string pointed by source into the array pointed by destination, including the terminating null character (and stopping at that point). +// char * strcat(char *destination, __zp($59) char *source) +strcat: { + .label strcat__0 = $5f + .label dst = $5f + .label src = $59 + .label source = $59 + // strlen(destination) + // [1411] call strlen + // [1788] phi from strcat to strlen [phi:strcat->strlen] + // [1788] phi strlen::str#8 = display_chip_rom::rom [phi:strcat->strlen#0] -- pbuz1=pbuc1 + lda #display_chip_rom.rom + sta.z strlen.str+1 + jsr strlen + // strlen(destination) + // [1412] strlen::return#0 = strlen::len#2 + // strcat::@4 + // [1413] strcat::$0 = strlen::return#0 -- vwuz1=vwum2 + lda strlen.return + sta.z strcat__0 + lda strlen.return+1 + sta.z strcat__0+1 + // char* dst = destination + strlen(destination) + // [1414] strcat::dst#0 = display_chip_rom::rom + strcat::$0 -- pbuz1=pbuc1_plus_vwuz1 + lda.z dst + clc + adc #display_chip_rom.rom + sta.z dst+1 + // [1415] phi from strcat::@2 strcat::@4 to strcat::@1 [phi:strcat::@2/strcat::@4->strcat::@1] + // [1415] phi strcat::dst#2 = strcat::dst#1 [phi:strcat::@2/strcat::@4->strcat::@1#0] -- register_copy + // [1415] phi strcat::src#2 = strcat::src#1 [phi:strcat::@2/strcat::@4->strcat::@1#1] -- register_copy + // strcat::@1 __b1: - // release & 0x80 - // [2048] rom_get_prefix::$2 = rom_get_prefix::release#2 & $80 -- vbuz1=vbum2_band_vbuc1 - lda #$80 - and release - sta.z rom_get_prefix__2 - // if(release & 0x80) - // [2049] if(0==rom_get_prefix::$2) goto rom_get_prefix::@4 -- 0_eq_vbuz1_then_la1 - beq __b2 - // [2051] phi from rom_get_prefix::@1 to rom_get_prefix::@2 [phi:rom_get_prefix::@1->rom_get_prefix::@2] - // [2051] phi rom_get_prefix::return#0 = 'p' [phi:rom_get_prefix::@1->rom_get_prefix::@2#0] -- vbum1=vbuc1 - lda #'p' - sta return - rts - // [2050] phi from rom_get_prefix::@1 to rom_get_prefix::@4 [phi:rom_get_prefix::@1->rom_get_prefix::@4] - // rom_get_prefix::@4 - // [2051] phi from rom_get_prefix::@4 to rom_get_prefix::@2 [phi:rom_get_prefix::@4->rom_get_prefix::@2] - // [2051] phi rom_get_prefix::return#0 = rom_get_prefix::prefix#4 [phi:rom_get_prefix::@4->rom_get_prefix::@2#0] -- register_copy - // rom_get_prefix::@2 - __b2: - // rom_get_prefix::@return + // while(*src) + // [1416] if(0!=*strcat::src#2) goto strcat::@2 -- 0_neq__deref_pbuz1_then_la1 + ldy #0 + lda (src),y + cmp #0 + bne __b2 + // strcat::@3 + // *dst = 0 + // [1417] *strcat::dst#2 = 0 -- _deref_pbuz1=vbuc1 + tya + tay + sta (dst),y + // strcat::@return // } - // [2052] return + // [1418] return rts - .segment Data - return: .byte 0 - release: .byte 0 - // If the release is 0xFF, then the release is a preview. - // If bit 7 of the release is set, then the release is a preview. - .label prefix = return + // strcat::@2 + __b2: + // *dst++ = *src++ + // [1419] *strcat::dst#2 = *strcat::src#2 -- _deref_pbuz1=_deref_pbuz2 + ldy #0 + lda (src),y + sta (dst),y + // *dst++ = *src++; + // [1420] strcat::dst#1 = ++ strcat::dst#2 -- pbuz1=_inc_pbuz1 + inc.z dst + bne !+ + inc.z dst+1 + !: + // [1421] strcat::src#1 = ++ strcat::src#2 -- pbuz1=_inc_pbuz1 + inc.z src + bne !+ + inc.z src+1 + !: + jmp __b1 } -.segment Code - // rom_get_version_text -// void rom_get_version_text(__zp($45) char *release_info, __mem() char prefix, __mem() char release, __zp($6c) char *github) -rom_get_version_text: { - .label release_info = $45 - .label github = $6c - // sprintf(release_info, "%c%u %s", prefix, release, github) - // [2054] snprintf_init::s#10 = rom_get_version_text::release_info#2 - // [2055] call snprintf_init - // [1205] phi from rom_get_version_text to snprintf_init [phi:rom_get_version_text->snprintf_init] - // [1205] phi snprintf_init::s#31 = snprintf_init::s#10 [phi:rom_get_version_text->snprintf_init#0] -- register_copy - jsr snprintf_init - // rom_get_version_text::@1 - // sprintf(release_info, "%c%u %s", prefix, release, github) - // [2056] stackpush(char) = rom_get_version_text::prefix#2 -- _stackpushbyte_=vbum1 - lda prefix - pha - // [2057] callexecute snputc -- call_vprc1 - jsr snputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // [2059] printf_uchar::uvalue#13 = rom_get_version_text::release#2 -- vbum1=vbum2 - lda release - sta printf_uchar.uvalue - // [2060] call printf_uchar - // [1346] phi from rom_get_version_text::@1 to printf_uchar [phi:rom_get_version_text::@1->printf_uchar] - // [1346] phi printf_uchar::format_zero_padding#18 = 0 [phi:rom_get_version_text::@1->printf_uchar#0] -- vbum1=vbuc1 - lda #0 - sta printf_uchar.format_zero_padding - // [1346] phi printf_uchar::format_min_length#18 = 0 [phi:rom_get_version_text::@1->printf_uchar#1] -- vbum1=vbuc1 - sta printf_uchar.format_min_length - // [1346] phi printf_uchar::putc#18 = &snputc [phi:rom_get_version_text::@1->printf_uchar#2] -- pprz1=pprc1 - lda #snputc - sta.z printf_uchar.putc+1 - // [1346] phi printf_uchar::format_radix#18 = DECIMAL [phi:rom_get_version_text::@1->printf_uchar#3] -- vbum1=vbuc1 - lda #DECIMAL - sta printf_uchar.format_radix - // [1346] phi printf_uchar::uvalue#18 = printf_uchar::uvalue#13 [phi:rom_get_version_text::@1->printf_uchar#4] -- register_copy - jsr printf_uchar - // [2061] phi from rom_get_version_text::@1 to rom_get_version_text::@2 [phi:rom_get_version_text::@1->rom_get_version_text::@2] - // rom_get_version_text::@2 - // sprintf(release_info, "%c%u %s", prefix, release, github) - // [2062] call printf_str - // [1210] phi from rom_get_version_text::@2 to printf_str [phi:rom_get_version_text::@2->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:rom_get_version_text::@2->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s4 [phi:rom_get_version_text::@2->printf_str#1] -- pbuz1=pbuc1 - lda #s4 - sta.z printf_str.s+1 - jsr printf_str - // rom_get_version_text::@3 - // sprintf(release_info, "%c%u %s", prefix, release, github) - // [2063] printf_string::str#16 = rom_get_version_text::github#2 -- pbuz1=pbuz2 - lda.z github - sta.z printf_string.str - lda.z github+1 - sta.z printf_string.str+1 - // [2064] call printf_string - // [1219] phi from rom_get_version_text::@3 to printf_string [phi:rom_get_version_text::@3->printf_string] - // [1219] phi printf_string::putc#26 = &snputc [phi:rom_get_version_text::@3->printf_string#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#16 [phi:rom_get_version_text::@3->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 0 [phi:rom_get_version_text::@3->printf_string#2] -- vbum1=vbuc1 - lda #0 - sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = 0 [phi:rom_get_version_text::@3->printf_string#3] -- vbum1=vbuc1 - sta printf_string.format_min_length - jsr printf_string - // rom_get_version_text::@4 - // sprintf(release_info, "%c%u %s", prefix, release, github) - // [2065] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 - lda #0 - pha - // [2066] callexecute snputc -- call_vprc1 - jsr snputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // rom_get_version_text::@return - // } - // [2068] return - rts - .segment Data - prefix: .byte 0 - release: .byte 0 -} -.segment Code - // rom_get_github_commit_id + // display_rom_led /** - * @brief Copy the github commit_id only if the commit_id contains hexadecimal characters. + * @brief Print ROM led above the ROM chip. * - * @param commit_id The target commit_id. - * @param from The source ptr in ROM or RAM. + * @param chip ROM chip number (0 is main rom chip of CX16) + * @param c Led color */ -// void rom_get_github_commit_id(__zp($47) char *commit_id, __zp($3f) char *from) -rom_get_github_commit_id: { - .label commit_id = $47 - .label from = $3f - // [2070] phi from rom_get_github_commit_id to rom_get_github_commit_id::@2 [phi:rom_get_github_commit_id->rom_get_github_commit_id::@2] - // [2070] phi rom_get_github_commit_id::commit_id_ok#2 = true [phi:rom_get_github_commit_id->rom_get_github_commit_id::@2#0] -- vbom1=vboc1 - lda #1 - sta commit_id_ok - // [2070] phi rom_get_github_commit_id::c#2 = 0 [phi:rom_get_github_commit_id->rom_get_github_commit_id::@2#1] -- vbum1=vbuc1 - lda #0 - sta c - // rom_get_github_commit_id::@2 - __b2: - // for(unsigned char c=0; c<7; c++) - // [2071] if(rom_get_github_commit_id::c#2<7) goto rom_get_github_commit_id::@3 -- vbum1_lt_vbuc1_then_la1 +// void display_rom_led(__mem() char chip, __mem() char c) +display_rom_led: { + .label display_rom_led__0 = $38 + .label display_rom_led__7 = $38 + .label display_rom_led__8 = $38 + // chip*6 + // [1423] display_rom_led::$7 = display_rom_led::chip#2 << 1 -- vbuz1=vbum2_rol_1 + lda chip + asl + sta.z display_rom_led__7 + // [1424] display_rom_led::$8 = display_rom_led::$7 + display_rom_led::chip#2 -- vbuz1=vbuz1_plus_vbum2 + lda chip + clc + adc.z display_rom_led__8 + sta.z display_rom_led__8 + // CHIP_ROM_X+chip*6 + // [1425] display_rom_led::$0 = display_rom_led::$8 << 1 -- vbuz1=vbuz1_rol_1 + asl.z display_rom_led__0 + // display_chip_led(CHIP_ROM_X+chip*6+1, CHIP_ROM_Y, CHIP_ROM_W, c, BLUE) + // [1426] display_chip_led::x#3 = display_rom_led::$0 + $14+1 -- vbum1=vbuz2_plus_vbuc1 + lda #$14+1 + clc + adc.z display_rom_led__0 + sta display_chip_led.x + // [1427] display_chip_led::tc#2 = display_rom_led::c#2 -- vbum1=vbum2 lda c - cmp #7 - bcc __b3 - // rom_get_github_commit_id::@4 - // if(commit_id_ok) - // [2072] if(rom_get_github_commit_id::commit_id_ok#2) goto rom_get_github_commit_id::@1 -- vbom1_then_la1 - lda commit_id_ok - cmp #0 - bne __b1 - // rom_get_github_commit_id::@6 - // *commit_id = '\0' - // [2073] *rom_get_github_commit_id::commit_id#6 = '@' -- _deref_pbuz1=vbuc1 - lda #'@' - ldy #0 - sta (commit_id),y - // rom_get_github_commit_id::@return + sta display_chip_led.tc + // [1428] call display_chip_led + // [1802] phi from display_rom_led to display_chip_led [phi:display_rom_led->display_chip_led] + // [1802] phi display_chip_led::w#7 = 3 [phi:display_rom_led->display_chip_led#0] -- vbum1=vbuc1 + lda #3 + sta display_chip_led.w + // [1802] phi display_chip_led::x#7 = display_chip_led::x#3 [phi:display_rom_led->display_chip_led#1] -- register_copy + // [1802] phi display_chip_led::tc#3 = display_chip_led::tc#2 [phi:display_rom_led->display_chip_led#2] -- register_copy + jsr display_chip_led + // display_rom_led::@1 + // display_info_led(INFO_X-2, INFO_Y+chip+2, c, BLUE) + // [1429] display_info_led::y#2 = display_rom_led::chip#2 + $11+2 -- vbum1=vbum2_plus_vbuc1 + lda #$11+2 + clc + adc chip + sta display_info_led.y + // [1430] display_info_led::tc#2 = display_rom_led::c#2 -- vbum1=vbum2 + lda c + sta display_info_led.tc + // [1431] call display_info_led + // [1444] phi from display_rom_led::@1 to display_info_led [phi:display_rom_led::@1->display_info_led] + // [1444] phi display_info_led::y#4 = display_info_led::y#2 [phi:display_rom_led::@1->display_info_led#0] -- register_copy + // [1444] phi display_info_led::x#4 = 4-2 [phi:display_rom_led::@1->display_info_led#1] -- vbum1=vbuc1 + lda #4-2 + sta display_info_led.x + // [1444] phi display_info_led::tc#4 = display_info_led::tc#2 [phi:display_rom_led::@1->display_info_led#2] -- register_copy + jsr display_info_led + // display_rom_led::@return // } - // [2074] return + // [1432] return rts - // rom_get_github_commit_id::@1 - __b1: - // strncpy(commit_id, from, 7) - // [2075] strncpy::dst#2 = rom_get_github_commit_id::commit_id#6 - // [2076] strncpy::src#2 = rom_get_github_commit_id::from#6 - // [2077] call strncpy - // [3002] phi from rom_get_github_commit_id::@1 to strncpy [phi:rom_get_github_commit_id::@1->strncpy] - // [3002] phi strncpy::dst#8 = strncpy::dst#2 [phi:rom_get_github_commit_id::@1->strncpy#0] -- register_copy - // [3002] phi strncpy::src#6 = strncpy::src#2 [phi:rom_get_github_commit_id::@1->strncpy#1] -- register_copy - // [3002] phi strncpy::n#3 = 7 [phi:rom_get_github_commit_id::@1->strncpy#2] -- vwum1=vbuc1 - lda #<7 - sta strncpy.n - lda #>7 - sta strncpy.n+1 - jsr strncpy - rts - // rom_get_github_commit_id::@3 - __b3: - // unsigned char ch = from[c] - // [2078] rom_get_github_commit_id::ch#0 = rom_get_github_commit_id::from#6[rom_get_github_commit_id::c#2] -- vbum1=pbuz2_derefidx_vbum3 - ldy c - lda (from),y - sta ch - // if(!(ch >= 48 && ch <= 48+9 || ch >= 65 && ch <= 65+26)) - // [2079] if(rom_get_github_commit_id::ch#0<$30) goto rom_get_github_commit_id::@7 -- vbum1_lt_vbuc1_then_la1 - cmp #$30 - bcc __b7 - // rom_get_github_commit_id::@8 - // [2080] if(rom_get_github_commit_id::ch#0<$30+9+1) goto rom_get_github_commit_id::@5 -- vbum1_lt_vbuc1_then_la1 - cmp #$30+9+1 - bcc __b5 - // rom_get_github_commit_id::@7 - __b7: - // [2081] if(rom_get_github_commit_id::ch#0<$41) goto rom_get_github_commit_id::@5 -- vbum1_lt_vbuc1_then_la1 - lda ch - cmp #$41 - bcc __b4 - // rom_get_github_commit_id::@9 - // [2082] if(rom_get_github_commit_id::ch#0<$41+$1a+1) goto rom_get_github_commit_id::@10 -- vbum1_lt_vbuc1_then_la1 - cmp #$41+$1a+1 - bcc __b5 - // [2084] phi from rom_get_github_commit_id::@7 rom_get_github_commit_id::@9 to rom_get_github_commit_id::@5 [phi:rom_get_github_commit_id::@7/rom_get_github_commit_id::@9->rom_get_github_commit_id::@5] - __b4: - // [2084] phi rom_get_github_commit_id::commit_id_ok#4 = false [phi:rom_get_github_commit_id::@7/rom_get_github_commit_id::@9->rom_get_github_commit_id::@5#0] -- vbom1=vboc1 - lda #0 - sta commit_id_ok - // [2083] phi from rom_get_github_commit_id::@9 to rom_get_github_commit_id::@10 [phi:rom_get_github_commit_id::@9->rom_get_github_commit_id::@10] - // rom_get_github_commit_id::@10 - // [2084] phi from rom_get_github_commit_id::@10 rom_get_github_commit_id::@8 to rom_get_github_commit_id::@5 [phi:rom_get_github_commit_id::@10/rom_get_github_commit_id::@8->rom_get_github_commit_id::@5] - // [2084] phi rom_get_github_commit_id::commit_id_ok#4 = rom_get_github_commit_id::commit_id_ok#2 [phi:rom_get_github_commit_id::@10/rom_get_github_commit_id::@8->rom_get_github_commit_id::@5#0] -- register_copy - // rom_get_github_commit_id::@5 - __b5: - // for(unsigned char c=0; c<7; c++) - // [2085] rom_get_github_commit_id::c#1 = ++ rom_get_github_commit_id::c#2 -- vbum1=_inc_vbum1 - inc c - // [2070] phi from rom_get_github_commit_id::@5 to rom_get_github_commit_id::@2 [phi:rom_get_github_commit_id::@5->rom_get_github_commit_id::@2] - // [2070] phi rom_get_github_commit_id::commit_id_ok#2 = rom_get_github_commit_id::commit_id_ok#4 [phi:rom_get_github_commit_id::@5->rom_get_github_commit_id::@2#0] -- register_copy - // [2070] phi rom_get_github_commit_id::c#2 = rom_get_github_commit_id::c#1 [phi:rom_get_github_commit_id::@5->rom_get_github_commit_id::@2#1] -- register_copy - jmp __b2 .segment Data - ch: .byte 0 + chip: .byte 0 c: .byte 0 - commit_id_ok: .byte 0 } .segment Code // printf_uint // Print an unsigned int using a specific format -// void printf_uint(__zp($3b) void (*putc)(char), __mem() unsigned int uvalue, __mem() char format_min_length, char format_justify_left, char format_sign_always, __mem() char format_zero_padding, char format_upper_case, __mem() char format_radix) +// void printf_uint(__zp($49) void (*putc)(char), __mem() unsigned int uvalue, __mem() char format_min_length, char format_justify_left, char format_sign_always, __mem() char format_zero_padding, char format_upper_case, __mem() char format_radix) printf_uint: { - .label putc = $3b + .label putc = $49 // printf_uint::@1 // printf_buffer.sign = format.sign_always?'+':0 - // [2087] *((char *)&printf_buffer) = 0 -- _deref_pbuc1=vbuc2 + // [1434] *((char *)&printf_buffer) = 0 -- _deref_pbuc1=vbuc2 // Handle any sign lda #0 sta printf_buffer // utoa(uvalue, printf_buffer.digits, format.radix) - // [2088] utoa::value#1 = printf_uint::uvalue#10 - // [2089] utoa::radix#0 = printf_uint::format_radix#10 - // [2090] call utoa + // [1435] utoa::value#1 = printf_uint::uvalue#4 + // [1436] utoa::radix#0 = printf_uint::format_radix#4 + // [1437] call utoa // Format number into buffer jsr utoa // printf_uint::@2 // printf_number_buffer(putc, printf_buffer, format) - // [2091] printf_number_buffer::putc#1 = printf_uint::putc#10 - // [2092] printf_number_buffer::buffer_sign#1 = *((char *)&printf_buffer) -- vbum1=_deref_pbuc1 + // [1438] printf_number_buffer::putc#1 = printf_uint::putc#4 + // [1439] printf_number_buffer::buffer_sign#1 = *((char *)&printf_buffer) -- vbum1=_deref_pbuc1 lda printf_buffer sta printf_number_buffer.buffer_sign - // [2093] printf_number_buffer::format_min_length#1 = printf_uint::format_min_length#10 - // [2094] printf_number_buffer::format_zero_padding#1 = printf_uint::format_zero_padding#10 - // [2095] call printf_number_buffer + // [1440] printf_number_buffer::format_min_length#1 = printf_uint::format_min_length#4 + // [1441] printf_number_buffer::format_zero_padding#1 = printf_uint::format_zero_padding#4 + // [1442] call printf_number_buffer // Print using format - // [2706] phi from printf_uint::@2 to printf_number_buffer [phi:printf_uint::@2->printf_number_buffer] - // [2706] phi printf_number_buffer::putc#10 = printf_number_buffer::putc#1 [phi:printf_uint::@2->printf_number_buffer#0] -- register_copy - // [2706] phi printf_number_buffer::buffer_sign#10 = printf_number_buffer::buffer_sign#1 [phi:printf_uint::@2->printf_number_buffer#1] -- register_copy - // [2706] phi printf_number_buffer::format_zero_padding#10 = printf_number_buffer::format_zero_padding#1 [phi:printf_uint::@2->printf_number_buffer#2] -- register_copy - // [2706] phi printf_number_buffer::format_min_length#3 = printf_number_buffer::format_min_length#1 [phi:printf_uint::@2->printf_number_buffer#3] -- register_copy + // [1539] phi from printf_uint::@2 to printf_number_buffer [phi:printf_uint::@2->printf_number_buffer] + // [1539] phi printf_number_buffer::putc#10 = printf_number_buffer::putc#1 [phi:printf_uint::@2->printf_number_buffer#0] -- register_copy + // [1539] phi printf_number_buffer::buffer_sign#10 = printf_number_buffer::buffer_sign#1 [phi:printf_uint::@2->printf_number_buffer#1] -- register_copy + // [1539] phi printf_number_buffer::format_zero_padding#10 = printf_number_buffer::format_zero_padding#1 [phi:printf_uint::@2->printf_number_buffer#2] -- register_copy + // [1539] phi printf_number_buffer::format_min_length#3 = printf_number_buffer::format_min_length#1 [phi:printf_uint::@2->printf_number_buffer#3] -- register_copy jsr printf_number_buffer // printf_uint::@return // } - // [2096] return + // [1443] return rts .segment Data - .label uvalue = smc_detect.return + uvalue: .word 0 format_radix: .byte 0 .label format_min_length = printf_uchar.format_min_length .label format_zero_padding = printf_uchar.format_zero_padding } .segment Code - // screenlayer -// --- layer management in VERA --- -// void screenlayer(char layer, __mem() char mapbase, __mem() char config) -screenlayer: { - .label screenlayer__0 = $5d - .label screenlayer__1 = $5c - .label screenlayer__2 = $ba - .label screenlayer__5 = $b5 - .label screenlayer__6 = $b5 - .label screenlayer__7 = $b4 - .label screenlayer__8 = $b4 - .label screenlayer__9 = $b2 - .label screenlayer__10 = $b2 - .label screenlayer__11 = $b2 - .label screenlayer__12 = $b3 - .label screenlayer__13 = $b3 - .label screenlayer__14 = $b3 - .label screenlayer__16 = $b4 - .label screenlayer__17 = $ab - .label screenlayer__18 = $b2 - .label screenlayer__19 = $b3 - .label y = $7f - // __mem char vera_dc_hscale_temp = *VERA_DC_HSCALE - // [2097] screenlayer::vera_dc_hscale_temp#0 = *VERA_DC_HSCALE -- vbum1=_deref_pbuc1 - lda VERA_DC_HSCALE - sta vera_dc_hscale_temp - // __mem char vera_dc_vscale_temp = *VERA_DC_VSCALE - // [2098] screenlayer::vera_dc_vscale_temp#0 = *VERA_DC_VSCALE -- vbum1=_deref_pbuc1 - lda VERA_DC_VSCALE - sta vera_dc_vscale_temp - // __conio.layer = 0 - // [2099] *((char *)&__conio+2) = 0 -- _deref_pbuc1=vbuc2 - lda #0 - sta __conio+2 - // mapbase >> 7 - // [2100] screenlayer::$0 = screenlayer::mapbase#0 >> 7 -- vbuz1=vbum2_ror_7 - lda mapbase - rol - rol - and #1 - sta.z screenlayer__0 - // __conio.mapbase_bank = mapbase >> 7 - // [2101] *((char *)&__conio+5) = screenlayer::$0 -- _deref_pbuc1=vbuz1 - sta __conio+5 - // (mapbase)<<1 - // [2102] screenlayer::$1 = screenlayer::mapbase#0 << 1 -- vbuz1=vbum2_rol_1 - lda mapbase - asl - sta.z screenlayer__1 - // MAKEWORD((mapbase)<<1,0) - // [2103] screenlayer::$2 = screenlayer::$1 w= 0 -- vwuz1=vbuz2_word_vbuc1 + // display_info_led +/** + * @brief Print the colored led of an info line in the info frame. + * + * @param x Start X + * @param y Start Y + * @param tc Fore color + * @param bc Back color + */ +// void display_info_led(__mem() char x, __mem() char y, __mem() char tc, char bc) +display_info_led: { + // textcolor(tc) + // [1445] textcolor::color#13 = display_info_led::tc#4 -- vbum1=vbum2 + lda tc + sta textcolor.color + // [1446] call textcolor + // [439] phi from display_info_led to textcolor [phi:display_info_led->textcolor] + // [439] phi textcolor::color#21 = textcolor::color#13 [phi:display_info_led->textcolor#0] -- register_copy + jsr textcolor + // [1447] phi from display_info_led to display_info_led::@1 [phi:display_info_led->display_info_led::@1] + // display_info_led::@1 + // bgcolor(bc) + // [1448] call bgcolor + // [444] phi from display_info_led::@1 to bgcolor [phi:display_info_led::@1->bgcolor] + // [444] phi bgcolor::color#15 = BLUE [phi:display_info_led::@1->bgcolor#0] -- vbum1=vbuc1 + lda #BLUE + sta bgcolor.color + jsr bgcolor + // display_info_led::@2 + // cputcxy(x, y, VERA_CHR_UR) + // [1449] cputcxy::x#13 = display_info_led::x#4 + // [1450] cputcxy::y#13 = display_info_led::y#4 + // [1451] call cputcxy + // [1346] phi from display_info_led::@2 to cputcxy [phi:display_info_led::@2->cputcxy] + // [1346] phi cputcxy::c#15 = $7c [phi:display_info_led::@2->cputcxy#0] -- vbum1=vbuc1 + lda #$7c + sta cputcxy.c + // [1346] phi cputcxy::y#15 = cputcxy::y#13 [phi:display_info_led::@2->cputcxy#1] -- register_copy + // [1346] phi cputcxy::x#15 = cputcxy::x#13 [phi:display_info_led::@2->cputcxy#2] -- register_copy + jsr cputcxy + // [1452] phi from display_info_led::@2 to display_info_led::@3 [phi:display_info_led::@2->display_info_led::@3] + // display_info_led::@3 + // textcolor(WHITE) + // [1453] call textcolor + // [439] phi from display_info_led::@3 to textcolor [phi:display_info_led::@3->textcolor] + // [439] phi textcolor::color#21 = WHITE [phi:display_info_led::@3->textcolor#0] -- vbum1=vbuc1 + lda #WHITE + sta textcolor.color + jsr textcolor + // display_info_led::@return + // } + // [1454] return + rts + .segment Data + .label tc = display_smc_led.c + .label y = cputcxy.y + .label x = cputcxy.x +} +.segment CodeVera + // vera_detect +vera_detect: { + // spi_get_jedec() + // [1456] call spi_get_jedec + // This conditional compilation ensures that only the detection interpretation happens if it is switched on. + // [1911] phi from vera_detect to spi_get_jedec [phi:vera_detect->spi_get_jedec] + jsr spi_get_jedec + // vera_detect::@return + // } + // [1457] return + rts +} + // vera_read +// __mem() unsigned long vera_read(__mem() char info_status) +vera_read: { + .const bank_set_brom1_bank = 0 + .label fp = $7b + // We start for VERA from 0x1:0xA000. + .label vera_bram_ptr = $65 + .label vera_action_text = $5b + // vera_read::bank_set_bram1 + // BRAM = bank + // [1459] BRAM = 1 -- vbuz1=vbuc1 + lda #1 + sta.z BRAM + // vera_read::@16 + // if(info_status == STATUS_READING) + // [1460] if(vera_read::info_status#12==STATUS_READING) goto vera_read::@1 -- vbum1_eq_vbuc1_then_la1 + lda #STATUS_READING + cmp info_status + beq __b1 + // [1462] phi from vera_read::@16 to vera_read::@2 [phi:vera_read::@16->vera_read::@2] + // [1462] phi vera_read::vera_bram_bank#14 = 0 [phi:vera_read::@16->vera_read::@2#0] -- vbum1=vbuc1 lda #0 - ldy.z screenlayer__1 - sty.z screenlayer__2+1 - sta.z screenlayer__2 - // __conio.mapbase_offset = MAKEWORD((mapbase)<<1,0) - // [2104] *((unsigned int *)&__conio+3) = screenlayer::$2 -- _deref_pwuc1=vwuz1 - sta __conio+3 - tya - sta __conio+3+1 - // config & VERA_LAYER_WIDTH_MASK - // [2105] screenlayer::$7 = screenlayer::config#0 & VERA_LAYER_WIDTH_MASK -- vbuz1=vbum2_band_vbuc1 - lda #VERA_LAYER_WIDTH_MASK - and config - sta.z screenlayer__7 - // (config & VERA_LAYER_WIDTH_MASK) >> 4 - // [2106] screenlayer::$8 = screenlayer::$7 >> 4 -- vbuz1=vbuz1_ror_4 - lda.z screenlayer__8 - lsr - lsr - lsr - lsr - sta.z screenlayer__8 - // __conio.mapwidth = VERA_LAYER_DIM[ (config & VERA_LAYER_WIDTH_MASK) >> 4] - // [2107] *((char *)&__conio+8) = screenlayer::VERA_LAYER_DIM[screenlayer::$8] -- _deref_pbuc1=pbuc2_derefidx_vbuz1 - tay - lda VERA_LAYER_DIM,y - sta __conio+8 - // config & VERA_LAYER_HEIGHT_MASK - // [2108] screenlayer::$5 = screenlayer::config#0 & VERA_LAYER_HEIGHT_MASK -- vbuz1=vbum2_band_vbuc1 - lda #VERA_LAYER_HEIGHT_MASK - and config - sta.z screenlayer__5 - // (config & VERA_LAYER_HEIGHT_MASK) >> 6 - // [2109] screenlayer::$6 = screenlayer::$5 >> 6 -- vbuz1=vbuz1_ror_6 - lda.z screenlayer__6 - rol - rol - rol - and #3 - sta.z screenlayer__6 - // __conio.mapheight = VERA_LAYER_DIM[ (config & VERA_LAYER_HEIGHT_MASK) >> 6] - // [2110] *((char *)&__conio+9) = screenlayer::VERA_LAYER_DIM[screenlayer::$6] -- _deref_pbuc1=pbuc2_derefidx_vbuz1 - tay - lda VERA_LAYER_DIM,y - sta __conio+9 - // __conio.rowskip = VERA_LAYER_SKIP[(config & VERA_LAYER_WIDTH_MASK)>>4] - // [2111] screenlayer::$16 = screenlayer::$8 << 1 -- vbuz1=vbuz1_rol_1 - asl.z screenlayer__16 - // [2112] *((unsigned int *)&__conio+$a) = screenlayer::VERA_LAYER_SKIP[screenlayer::$16] -- _deref_pwuc1=pwuc2_derefidx_vbuz1 - // __conio.rowshift = ((config & VERA_LAYER_WIDTH_MASK)>>4)+6; - ldy.z screenlayer__16 - lda VERA_LAYER_SKIP,y - sta __conio+$a - lda VERA_LAYER_SKIP+1,y - sta __conio+$a+1 - // vera_dc_hscale_temp == 0x80 - // [2113] screenlayer::$9 = screenlayer::vera_dc_hscale_temp#0 == $80 -- vboz1=vbum2_eq_vbuc1 - lda vera_dc_hscale_temp - eor #$80 - beq !+ + sta vera_bram_bank + // [1462] phi vera_read::vera_action_text#10 = vera_read::vera_action_text#2 [phi:vera_read::@16->vera_read::@2#1] -- pbuz1=pbuc1 + lda #vera_action_text_2 + sta.z vera_action_text+1 + jmp __b2 + // [1461] phi from vera_read::@16 to vera_read::@1 [phi:vera_read::@16->vera_read::@1] + // vera_read::@1 + __b1: + // [1462] phi from vera_read::@1 to vera_read::@2 [phi:vera_read::@1->vera_read::@2] + // [1462] phi vera_read::vera_bram_bank#14 = 1 [phi:vera_read::@1->vera_read::@2#0] -- vbum1=vbuc1 lda #1 - !: - eor #1 - sta.z screenlayer__9 - // 40 << (char)(vera_dc_hscale_temp == 0x80) - // [2114] screenlayer::$18 = (char)screenlayer::$9 - // [2115] screenlayer::$10 = $28 << screenlayer::$18 -- vbuz1=vbuc1_rol_vbuz1 - lda #$28 - ldy.z screenlayer__10 - cpy #0 - beq !e+ - !: - asl - dey - bne !- - !e: - sta.z screenlayer__10 - // (40 << (char)(vera_dc_hscale_temp == 0x80))-1 - // [2116] screenlayer::$11 = screenlayer::$10 - 1 -- vbuz1=vbuz1_minus_1 - dec.z screenlayer__11 - // __conio.width = (40 << (char)(vera_dc_hscale_temp == 0x80))-1 - // [2117] *((char *)&__conio+6) = screenlayer::$11 -- _deref_pbuc1=vbuz1 - lda.z screenlayer__11 - sta __conio+6 - // vera_dc_vscale_temp == 0x80 - // [2118] screenlayer::$12 = screenlayer::vera_dc_vscale_temp#0 == $80 -- vboz1=vbum2_eq_vbuc1 - lda vera_dc_vscale_temp - eor #$80 - beq !+ - lda #1 - !: - eor #1 - sta.z screenlayer__12 - // 30 << (char)(vera_dc_vscale_temp == 0x80) - // [2119] screenlayer::$19 = (char)screenlayer::$12 - // [2120] screenlayer::$13 = $1e << screenlayer::$19 -- vbuz1=vbuc1_rol_vbuz1 - lda #$1e - ldy.z screenlayer__13 - cpy #0 - beq !e+ - !: - asl - dey - bne !- - !e: - sta.z screenlayer__13 - // (30 << (char)(vera_dc_vscale_temp == 0x80))-1 - // [2121] screenlayer::$14 = screenlayer::$13 - 1 -- vbuz1=vbuz1_minus_1 - dec.z screenlayer__14 - // __conio.height = (30 << (char)(vera_dc_vscale_temp == 0x80))-1 - // [2122] *((char *)&__conio+7) = screenlayer::$14 -- _deref_pbuc1=vbuz1 - lda.z screenlayer__14 - sta __conio+7 - // unsigned int mapbase_offset = __conio.mapbase_offset - // [2123] screenlayer::mapbase_offset#0 = *((unsigned int *)&__conio+3) -- vwum1=_deref_pwuc1 - lda __conio+3 - sta mapbase_offset - lda __conio+3+1 - sta mapbase_offset+1 - // [2124] phi from screenlayer to screenlayer::@1 [phi:screenlayer->screenlayer::@1] - // [2124] phi screenlayer::mapbase_offset#2 = screenlayer::mapbase_offset#0 [phi:screenlayer->screenlayer::@1#0] -- register_copy - // [2124] phi screenlayer::y#2 = 0 [phi:screenlayer->screenlayer::@1#1] -- vbuz1=vbuc1 - lda #0 - sta.z y - // screenlayer::@1 - __b1: - // for(register char y=0; y<=__conio.height; y++) - // [2125] if(screenlayer::y#2<=*((char *)&__conio+7)) goto screenlayer::@2 -- vbuz1_le__deref_pbuc1_then_la1 - lda __conio+7 - cmp.z y - bcs __b2 - // screenlayer::@return - // } - // [2126] return - rts - // screenlayer::@2 + sta vera_bram_bank + // [1462] phi vera_read::vera_action_text#10 = vera_read::vera_action_text#1 [phi:vera_read::@1->vera_read::@2#1] -- pbuz1=pbuc1 + lda #vera_action_text_1 + sta.z vera_action_text+1 + // vera_read::@2 __b2: - // __conio.offsets[y] = mapbase_offset - // [2127] screenlayer::$17 = screenlayer::y#2 << 1 -- vbuz1=vbuz2_rol_1 - lda.z y - asl - sta.z screenlayer__17 - // [2128] ((unsigned int *)&__conio+$15)[screenlayer::$17] = screenlayer::mapbase_offset#2 -- pwuc1_derefidx_vbuz1=vwum2 - tay - lda mapbase_offset - sta __conio+$15,y - lda mapbase_offset+1 - sta __conio+$15+1,y - // mapbase_offset += __conio.rowskip - // [2129] screenlayer::mapbase_offset#1 = screenlayer::mapbase_offset#2 + *((unsigned int *)&__conio+$a) -- vwum1=vwum1_plus__deref_pwuc1 - clc - lda mapbase_offset - adc __conio+$a - sta mapbase_offset - lda mapbase_offset+1 - adc __conio+$a+1 - sta mapbase_offset+1 - // for(register char y=0; y<=__conio.height; y++) - // [2130] screenlayer::y#1 = ++ screenlayer::y#2 -- vbuz1=_inc_vbuz1 - inc.z y - // [2124] phi from screenlayer::@2 to screenlayer::@1 [phi:screenlayer::@2->screenlayer::@1] - // [2124] phi screenlayer::mapbase_offset#2 = screenlayer::mapbase_offset#1 [phi:screenlayer::@2->screenlayer::@1#0] -- register_copy - // [2124] phi screenlayer::y#2 = screenlayer::y#1 [phi:screenlayer::@2->screenlayer::@1#1] -- register_copy - jmp __b1 - .segment Data - VERA_LAYER_DIM: .byte $1f, $3f, $7f, $ff - VERA_LAYER_SKIP: .word $40, $80, $100, $200 - mapbase: .byte 0 - config: .byte 0 - vera_dc_hscale_temp: .byte 0 - vera_dc_vscale_temp: .byte 0 - mapbase_offset: .word 0 -} -.segment Code - // cscroll -// Scroll the entire screen if the cursor is beyond the last line -cscroll: { - // if(__conio.cursor_y>__conio.height) - // [2131] if(*((char *)&__conio+1)<=*((char *)&__conio+7)) goto cscroll::@return -- _deref_pbuc1_le__deref_pbuc2_then_la1 - lda __conio+7 - cmp __conio+1 - bcs __breturn - // cscroll::@1 - // if(__conio.scroll[__conio.layer]) - // [2132] if(0!=((char *)&__conio+$f)[*((char *)&__conio+2)]) goto cscroll::@4 -- 0_neq_pbuc1_derefidx_(_deref_pbuc2)_then_la1 - ldy __conio+2 - lda __conio+$f,y - cmp #0 - bne __b4 - // cscroll::@2 - // if(__conio.cursor_y>__conio.height) - // [2133] if(*((char *)&__conio+1)<=*((char *)&__conio+7)) goto cscroll::@return -- _deref_pbuc1_le__deref_pbuc2_then_la1 - lda __conio+7 - cmp __conio+1 - bcs __breturn - // [2134] phi from cscroll::@2 to cscroll::@3 [phi:cscroll::@2->cscroll::@3] - // cscroll::@3 - // gotoxy(0,0) - // [2135] call gotoxy - // [802] phi from cscroll::@3 to gotoxy [phi:cscroll::@3->gotoxy] - // [802] phi gotoxy::y#37 = 0 [phi:cscroll::@3->gotoxy#0] -- vbum1=vbuc1 - lda #0 + // vera_read::bank_set_brom1 + // BROM = bank + // [1463] BROM = vera_read::bank_set_brom1_bank#0 -- vbuz1=vbuc1 + lda #bank_set_brom1_bank + sta.z BROM + // [1464] phi from vera_read::bank_set_brom1 to vera_read::@17 [phi:vera_read::bank_set_brom1->vera_read::@17] + // vera_read::@17 + // display_action_text("Opening VERA.BIN from SD card ...") + // [1465] call display_action_text + // [845] phi from vera_read::@17 to display_action_text [phi:vera_read::@17->display_action_text] + // [845] phi display_action_text::info_text#17 = vera_read::info_text [phi:vera_read::@17->display_action_text#0] -- pbuz1=pbuc1 + lda #info_text + sta.z display_action_text.info_text+1 + jsr display_action_text + // [1466] phi from vera_read::@17 to vera_read::@19 [phi:vera_read::@17->vera_read::@19] + // vera_read::@19 + // FILE *fp = fopen("VERA.BIN", "r") + // [1467] call fopen + jsr fopen + // [1468] fopen::return#3 = fopen::return#2 + // vera_read::@20 + // [1469] vera_read::fp#0 = fopen::return#3 -- pssz1=pssz2 + lda.z fopen.return + sta.z fp + lda.z fopen.return+1 + sta.z fp+1 + // if (fp) + // [1470] if((struct $2 *)0==vera_read::fp#0) goto vera_read::@3 -- pssc1_eq_pssz1_then_la1 + lda.z fp + cmp #<0 + bne !+ + lda.z fp+1 + cmp #>0 + beq __b4 + !: + // [1471] phi from vera_read::@20 to vera_read::@4 [phi:vera_read::@20->vera_read::@4] + // vera_read::@4 + // gotoxy(x, y) + // [1472] call gotoxy + // [457] phi from vera_read::@4 to gotoxy [phi:vera_read::@4->gotoxy] + // [457] phi gotoxy::y#26 = PROGRESS_Y [phi:vera_read::@4->gotoxy#0] -- vbum1=vbuc1 + lda #PROGRESS_Y sta gotoxy.y - // [802] phi gotoxy::x#37 = 0 [phi:cscroll::@3->gotoxy#1] -- vbum1=vbuc1 + // [457] phi gotoxy::x#26 = PROGRESS_X [phi:vera_read::@4->gotoxy#1] -- vbum1=vbuc1 + lda #PROGRESS_X sta gotoxy.x jsr gotoxy - // cscroll::@return - __breturn: - // } - // [2136] return + // [1473] phi from vera_read::@4 to vera_read::@5 [phi:vera_read::@4->vera_read::@5] + // [1473] phi vera_read::y#11 = PROGRESS_Y [phi:vera_read::@4->vera_read::@5#0] -- vbum1=vbuc1 + lda #PROGRESS_Y + sta y + // [1473] phi vera_read::progress_row_current#10 = 0 [phi:vera_read::@4->vera_read::@5#1] -- vwum1=vwuc1 + lda #<0 + sta progress_row_current + sta progress_row_current+1 + // [1473] phi vera_read::vera_bram_ptr#13 = (char *)$a000 [phi:vera_read::@4->vera_read::@5#2] -- pbuz1=pbuc1 + lda #<$a000 + sta.z vera_bram_ptr + lda #>$a000 + sta.z vera_bram_ptr+1 + // [1473] phi vera_read::vera_bram_bank#10 = vera_read::vera_bram_bank#14 [phi:vera_read::@4->vera_read::@5#3] -- register_copy + // [1473] phi vera_read::vera_file_size#11 = 0 [phi:vera_read::@4->vera_read::@5#4] -- vdum1=vduc1 + lda #<0 + sta vera_file_size + sta vera_file_size+1 + lda #<0>>$10 + sta vera_file_size+2 + lda #>0>>$10 + sta vera_file_size+3 + // vera_read::@5 + __b5: + // while (vera_file_size < vera_size) + // [1474] if(vera_read::vera_file_size#11vera_size>>$10 + bcc __b6 + bne !+ + lda vera_file_size+2 + cmp #>$10 + bcc __b6 + bne !+ + lda vera_file_size+1 + cmp #>vera_size + bcc __b6 + bne !+ + lda vera_file_size + cmp #vera_read::@3] + // [1477] phi __stdio_filecount#26 = __stdio_filecount#2 [phi:vera_read::@9->vera_read::@3#0] -- register_copy + // [1477] phi vera_read::return#0 = vera_read::vera_file_size#11 [phi:vera_read::@9->vera_read::@3#1] -- register_copy rts - // [2137] phi from cscroll::@1 to cscroll::@4 [phi:cscroll::@1->cscroll::@4] - // cscroll::@4 + // [1477] phi from vera_read::@20 to vera_read::@3 [phi:vera_read::@20->vera_read::@3] __b4: - // insertup(1) - // [2138] call insertup - jsr insertup - // cscroll::@5 - // gotoxy( 0, __conio.height) - // [2139] gotoxy::y#3 = *((char *)&__conio+7) -- vbum1=_deref_pbuc1 - lda __conio+7 - sta gotoxy.y - // [2140] call gotoxy - // [802] phi from cscroll::@5 to gotoxy [phi:cscroll::@5->gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#3 [phi:cscroll::@5->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = 0 [phi:cscroll::@5->gotoxy#1] -- vbum1=vbuc1 - lda #0 - sta gotoxy.x - jsr gotoxy - // [2141] phi from cscroll::@5 to cscroll::@6 [phi:cscroll::@5->cscroll::@6] - // cscroll::@6 - // clearline() - // [2142] call clearline - jsr clearline - rts -} - // cx16_k_screen_set_mode -/** - * @brief Sets the screen mode. - * - * @return cx16_k_screen_mode_error_t Contains 1 if there is an error. - */ -// char cx16_k_screen_set_mode(__mem() volatile char mode) -cx16_k_screen_set_mode: { - // cx16_k_screen_mode_error_t error = 0 - // [2143] cx16_k_screen_set_mode::error = 0 -- vbum1=vbuc1 - lda #0 - sta error - // asm - // asm { clc ldamode jsrCX16_SCREEN_MODE rolerror } - clc - lda mode - jsr CX16_SCREEN_MODE - rol error - // cx16_k_screen_set_mode::@return + // [1477] phi __stdio_filecount#26 = __stdio_filecount#1 [phi:vera_read::@20->vera_read::@3#0] -- register_copy + // [1477] phi vera_read::return#0 = 0 [phi:vera_read::@20->vera_read::@3#1] -- vdum1=vduc1 + lda #<0 + sta return + sta return+1 + lda #<0>>$10 + sta return+2 + lda #>0>>$10 + sta return+3 + // vera_read::@3 + // vera_read::@return // } - // [2145] return + // [1478] return rts - .segment Data - mode: .byte 0 - error: .byte 0 -} -.segment Code - // display_frame -/** - * @brief Draw a rectangle or a line given the coordinates. - * Draw a line horizontal from a given xy position and a given length. - * The line should calculate the matching characters to draw and glue them. - * So it first needs to peek the characters at the given position. - * And then calculate the resulting characters to draw. - * - * @param x0 Left up X position, counting from 0. - * @param y0 Left up Y position, counting from 0, - * @param x1 Right down X position, counting from 0. - * @param y1 Right down Y position, counting from 0. - */ -// void display_frame(char x0, char y0, __mem() char x1, __mem() char y1) -display_frame: { - // unsigned char w = x1 - x0 - // [2147] display_frame::w#0 = display_frame::x1#16 - display_frame::x#0 -- vbum1=vbum2_minus_vbum3 - lda x1 - sec - sbc x - sta w - // unsigned char h = y1 - y0 - // [2148] display_frame::h#0 = display_frame::y1#16 - display_frame::y#0 -- vbum1=vbum2_minus_vbum3 - lda y1 - sec - sbc y - sta h - // unsigned char mask = display_frame_maskxy(x, y) - // [2149] display_frame_maskxy::x#0 = display_frame::x#0 -- vbum1=vbum2 - lda x - sta display_frame_maskxy.x - // [2150] display_frame_maskxy::y#0 = display_frame::y#0 -- vbum1=vbum2 - lda y - sta display_frame_maskxy.y - // [2151] call display_frame_maskxy - // [3076] phi from display_frame to display_frame_maskxy [phi:display_frame->display_frame_maskxy] - // [3076] phi display_frame_maskxy::cpeekcxy1_y#0 = display_frame_maskxy::y#0 [phi:display_frame->display_frame_maskxy#0] -- register_copy - // [3076] phi display_frame_maskxy::cpeekcxy1_x#0 = display_frame_maskxy::x#0 [phi:display_frame->display_frame_maskxy#1] -- register_copy - jsr display_frame_maskxy - // unsigned char mask = display_frame_maskxy(x, y) - // [2152] display_frame_maskxy::return#13 = display_frame_maskxy::return#12 - // display_frame::@13 - // [2153] display_frame::mask#0 = display_frame_maskxy::return#13 - // mask |= 0b0110 - // [2154] display_frame::mask#1 = display_frame::mask#0 | 6 -- vbum1=vbum1_bor_vbuc1 - lda #6 - ora mask - sta mask - // unsigned char c = display_frame_char(mask) - // [2155] display_frame_char::mask#0 = display_frame::mask#1 - // [2156] call display_frame_char - // Add a corner. - // [3102] phi from display_frame::@13 to display_frame_char [phi:display_frame::@13->display_frame_char] - // [3102] phi display_frame_char::mask#10 = display_frame_char::mask#0 [phi:display_frame::@13->display_frame_char#0] -- register_copy - jsr display_frame_char - // unsigned char c = display_frame_char(mask) - // [2157] display_frame_char::return#13 = display_frame_char::return#12 - // display_frame::@14 - // [2158] display_frame::c#0 = display_frame_char::return#13 - // cputcxy(x, y, c) - // [2159] cputcxy::x#2 = display_frame::x#0 -- vbum1=vbum2 - lda x - sta cputcxy.x - // [2160] cputcxy::y#2 = display_frame::y#0 -- vbum1=vbum2 + // vera_read::@6 + __b6: + // if(info_status == STATUS_CHECKING) + // [1479] if(vera_read::info_status#12!=STATUS_CHECKING) goto vera_read::@23 -- vbum1_neq_vbuc1_then_la1 + lda #STATUS_CHECKING + cmp info_status + bne __b7 + // [1481] phi from vera_read::@6 to vera_read::@7 [phi:vera_read::@6->vera_read::@7] + // [1481] phi vera_read::vera_bram_ptr#10 = (char *) 1024 [phi:vera_read::@6->vera_read::@7#0] -- pbuz1=pbuc1 + lda #<$400 + sta.z vera_bram_ptr + lda #>$400 + sta.z vera_bram_ptr+1 + // [1480] phi from vera_read::@6 to vera_read::@23 [phi:vera_read::@6->vera_read::@23] + // vera_read::@23 + // [1481] phi from vera_read::@23 to vera_read::@7 [phi:vera_read::@23->vera_read::@7] + // [1481] phi vera_read::vera_bram_ptr#10 = vera_read::vera_bram_ptr#13 [phi:vera_read::@23->vera_read::@7#0] -- register_copy + // vera_read::@7 + __b7: + // display_action_text_reading(vera_action_text, "VERA.BIN", vera_file_size, vera_size, vera_bram_bank, vera_bram_ptr) + // [1482] display_action_text_reading::action#0 = vera_read::vera_action_text#10 -- pbuz1=pbuz2 + lda.z vera_action_text + sta.z display_action_text_reading.action + lda.z vera_action_text+1 + sta.z display_action_text_reading.action+1 + // [1483] display_action_text_reading::bytes#0 = vera_read::vera_file_size#11 -- vdum1=vdum2 + lda vera_file_size + sta display_action_text_reading.bytes + lda vera_file_size+1 + sta display_action_text_reading.bytes+1 + lda vera_file_size+2 + sta display_action_text_reading.bytes+2 + lda vera_file_size+3 + sta display_action_text_reading.bytes+3 + // [1484] display_action_text_reading::bram_bank#0 = vera_read::vera_bram_bank#10 -- vbum1=vbum2 + lda vera_bram_bank + sta display_action_text_reading.bram_bank + // [1485] display_action_text_reading::bram_ptr#0 = vera_read::vera_bram_ptr#10 -- pbuz1=pbuz2 + lda.z vera_bram_ptr + sta.z display_action_text_reading.bram_ptr + lda.z vera_bram_ptr+1 + sta.z display_action_text_reading.bram_ptr+1 + // [1486] call display_action_text_reading + // [2034] phi from vera_read::@7 to display_action_text_reading [phi:vera_read::@7->display_action_text_reading] + jsr display_action_text_reading + // vera_read::bank_set_bram2 + // BRAM = bank + // [1487] BRAM = vera_read::vera_bram_bank#10 -- vbuz1=vbum2 + lda vera_bram_bank + sta.z BRAM + // vera_read::@18 + // unsigned int vera_package_read = fgets(vera_bram_ptr, VERA_PROGRESS_CELL, fp) + // [1488] fgets::ptr#2 = vera_read::vera_bram_ptr#10 -- pbuz1=pbuz2 + lda.z vera_bram_ptr + sta.z fgets.ptr + lda.z vera_bram_ptr+1 + sta.z fgets.ptr+1 + // [1489] fgets::stream#0 = vera_read::fp#0 -- pssz1=pssz2 + lda.z fp + sta.z fgets.stream + lda.z fp+1 + sta.z fgets.stream+1 + // [1490] call fgets + jsr fgets + // [1491] fgets::return#5 = fgets::return#1 + // vera_read::@21 + // [1492] vera_read::vera_package_read#0 = fgets::return#5 -- vwum1=vwum2 + lda fgets.return + sta vera_package_read + lda fgets.return+1 + sta vera_package_read+1 + // if (!vera_package_read) + // [1493] if(0!=vera_read::vera_package_read#0) goto vera_read::@8 -- 0_neq_vwum1_then_la1 + lda vera_package_read + ora vera_package_read+1 + bne __b8 + jmp __b9 + // vera_read::@8 + __b8: + // if (progress_row_current == VERA_PROGRESS_ROW) + // [1494] if(vera_read::progress_row_current#10!=VERA_PROGRESS_ROW) goto vera_read::@10 -- vwum1_neq_vwuc1_then_la1 + lda progress_row_current+1 + cmp #>VERA_PROGRESS_ROW + bne __b10 + lda progress_row_current + cmp #cputcxy] - // [2293] phi cputcxy::c#17 = cputcxy::c#2 [phi:display_frame::@14->cputcxy#0] -- register_copy - // [2293] phi cputcxy::y#17 = cputcxy::y#2 [phi:display_frame::@14->cputcxy#1] -- register_copy - // [2293] phi cputcxy::x#17 = cputcxy::x#2 [phi:display_frame::@14->cputcxy#2] -- register_copy - jsr cputcxy - // display_frame::@15 - // if(w>=2) - // [2163] if(display_frame::w#0<2) goto display_frame::@36 -- vbum1_lt_vbuc1_then_la1 - lda w - cmp #2 - bcs !__b36+ - jmp __b36 - !__b36: - // display_frame::@2 - // x++; - // [2164] display_frame::x#1 = ++ display_frame::x#0 -- vbum1=_inc_vbum2 - lda x - inc - sta x_1 - // [2165] phi from display_frame::@2 display_frame::@21 to display_frame::@4 [phi:display_frame::@2/display_frame::@21->display_frame::@4] - // [2165] phi display_frame::x#10 = display_frame::x#1 [phi:display_frame::@2/display_frame::@21->display_frame::@4#0] -- register_copy - // display_frame::@4 - __b4: - // while(x < x1) - // [2166] if(display_frame::x#10gotoxy] + // [457] phi gotoxy::y#26 = gotoxy::y#6 [phi:vera_read::@13->gotoxy#0] -- register_copy + // [457] phi gotoxy::x#26 = PROGRESS_X [phi:vera_read::@13->gotoxy#1] -- vbum1=vbuc1 + lda #PROGRESS_X + sta gotoxy.x + jsr gotoxy + // [1498] phi from vera_read::@13 to vera_read::@10 [phi:vera_read::@13->vera_read::@10] + // [1498] phi vera_read::y#22 = vera_read::y#1 [phi:vera_read::@13->vera_read::@10#0] -- register_copy + // [1498] phi vera_read::progress_row_current#4 = 0 [phi:vera_read::@13->vera_read::@10#1] -- vwum1=vbuc1 + lda #<0 + sta progress_row_current + sta progress_row_current+1 + // [1498] phi from vera_read::@8 to vera_read::@10 [phi:vera_read::@8->vera_read::@10] + // [1498] phi vera_read::y#22 = vera_read::y#11 [phi:vera_read::@8->vera_read::@10#0] -- register_copy + // [1498] phi vera_read::progress_row_current#4 = vera_read::progress_row_current#10 [phi:vera_read::@8->vera_read::@10#1] -- register_copy + // vera_read::@10 + __b10: + // if(info_status == STATUS_READING) + // [1499] if(vera_read::info_status#12!=STATUS_READING) goto vera_read::@11 -- vbum1_neq_vbuc1_then_la1 + lda #STATUS_READING + cmp info_status + bne __b11 + // vera_read::@14 + // cputc('.') + // [1500] stackpush(char) = '.' -- _stackpushbyte_=vbuc1 + lda #'.' + pha + // [1501] callexecute cputc -- call_vprc1 + jsr cputc + // sideeffect stackpullpadding(1) -- _stackpullpadding_1 + pla + // vera_read::@11 + __b11: + // vera_bram_ptr += vera_package_read + // [1503] vera_read::vera_bram_ptr#2 = vera_read::vera_bram_ptr#10 + vera_read::vera_package_read#0 -- pbuz1=pbuz1_plus_vwum2 + clc + lda.z vera_bram_ptr + adc vera_package_read + sta.z vera_bram_ptr + lda.z vera_bram_ptr+1 + adc vera_package_read+1 + sta.z vera_bram_ptr+1 + // vera_file_size += vera_package_read + // [1504] vera_read::vera_file_size#1 = vera_read::vera_file_size#11 + vera_read::vera_package_read#0 -- vdum1=vdum1_plus_vwum2 + lda vera_file_size + clc + adc vera_package_read + sta vera_file_size + lda vera_file_size+1 + adc vera_package_read+1 + sta vera_file_size+1 + lda vera_file_size+2 + adc #0 + sta vera_file_size+2 + lda vera_file_size+3 + adc #0 + sta vera_file_size+3 + // progress_row_current += vera_package_read + // [1505] vera_read::progress_row_current#15 = vera_read::progress_row_current#4 + vera_read::vera_package_read#0 -- vwum1=vwum1_plus_vwum2 + clc + lda progress_row_current + adc vera_package_read + sta progress_row_current + lda progress_row_current+1 + adc vera_package_read+1 + sta progress_row_current+1 + // if (vera_bram_ptr == (bram_ptr_t)BRAM_HIGH) + // [1506] if(vera_read::vera_bram_ptr#2!=(char *)$c000) goto vera_read::@12 -- pbuz1_neq_pbuc1_then_la1 + lda.z vera_bram_ptr+1 + cmp #>$c000 + bne __b12 + lda.z vera_bram_ptr + cmp #<$c000 + bne __b12 + // vera_read::@15 + // vera_bram_bank++; + // [1507] vera_read::vera_bram_bank#2 = ++ vera_read::vera_bram_bank#10 -- vbum1=_inc_vbum1 + inc vera_bram_bank + // [1508] phi from vera_read::@15 to vera_read::@12 [phi:vera_read::@15->vera_read::@12] + // [1508] phi vera_read::vera_bram_bank#13 = vera_read::vera_bram_bank#2 [phi:vera_read::@15->vera_read::@12#0] -- register_copy + // [1508] phi vera_read::vera_bram_ptr#8 = (char *)$a000 [phi:vera_read::@15->vera_read::@12#1] -- pbuz1=pbuc1 + lda #<$a000 + sta.z vera_bram_ptr + lda #>$a000 + sta.z vera_bram_ptr+1 + // [1508] phi from vera_read::@11 to vera_read::@12 [phi:vera_read::@11->vera_read::@12] + // [1508] phi vera_read::vera_bram_bank#13 = vera_read::vera_bram_bank#10 [phi:vera_read::@11->vera_read::@12#0] -- register_copy + // [1508] phi vera_read::vera_bram_ptr#8 = vera_read::vera_bram_ptr#2 [phi:vera_read::@11->vera_read::@12#1] -- register_copy + // vera_read::@12 + __b12: + // if (vera_bram_ptr == (bram_ptr_t)RAM_HIGH) + // [1509] if(vera_read::vera_bram_ptr#8!=(char *)$9800) goto vera_read::@22 -- pbuz1_neq_pbuc1_then_la1 + lda.z vera_bram_ptr+1 + cmp #>$9800 + beq !__b5+ jmp __b5 !__b5: - // [2167] phi from display_frame::@36 display_frame::@4 to display_frame::@1 [phi:display_frame::@36/display_frame::@4->display_frame::@1] - // [2167] phi display_frame::x#24 = display_frame::x#30 [phi:display_frame::@36/display_frame::@4->display_frame::@1#0] -- register_copy - // display_frame::@1 - __b1: - // display_frame_maskxy(x, y) - // [2168] display_frame_maskxy::x#1 = display_frame::x#24 -- vbum1=vbum2 - lda x_1 - sta display_frame_maskxy.x - // [2169] display_frame_maskxy::y#1 = display_frame::y#0 -- vbum1=vbum2 - lda y - sta display_frame_maskxy.y - // [2170] call display_frame_maskxy - // [3076] phi from display_frame::@1 to display_frame_maskxy [phi:display_frame::@1->display_frame_maskxy] - // [3076] phi display_frame_maskxy::cpeekcxy1_y#0 = display_frame_maskxy::y#1 [phi:display_frame::@1->display_frame_maskxy#0] -- register_copy - // [3076] phi display_frame_maskxy::cpeekcxy1_x#0 = display_frame_maskxy::x#1 [phi:display_frame::@1->display_frame_maskxy#1] -- register_copy - jsr display_frame_maskxy - // display_frame_maskxy(x, y) - // [2171] display_frame_maskxy::return#14 = display_frame_maskxy::return#12 - // display_frame::@16 - // mask = display_frame_maskxy(x, y) - // [2172] display_frame::mask#2 = display_frame_maskxy::return#14 - // mask |= 0b0011 - // [2173] display_frame::mask#3 = display_frame::mask#2 | 3 -- vbum1=vbum1_bor_vbuc1 - lda #3 - ora mask - sta mask - // display_frame_char(mask) - // [2174] display_frame_char::mask#1 = display_frame::mask#3 - // [2175] call display_frame_char - // [3102] phi from display_frame::@16 to display_frame_char [phi:display_frame::@16->display_frame_char] - // [3102] phi display_frame_char::mask#10 = display_frame_char::mask#1 [phi:display_frame::@16->display_frame_char#0] -- register_copy - jsr display_frame_char - // display_frame_char(mask) - // [2176] display_frame_char::return#14 = display_frame_char::return#12 - // display_frame::@17 - // c = display_frame_char(mask) - // [2177] display_frame::c#1 = display_frame_char::return#14 - // cputcxy(x, y, c) - // [2178] cputcxy::x#3 = display_frame::x#24 -- vbum1=vbum2 - lda x_1 - sta cputcxy.x - // [2179] cputcxy::y#3 = display_frame::y#0 -- vbum1=vbum2 - lda y - sta cputcxy.y - // [2180] cputcxy::c#3 = display_frame::c#1 - // [2181] call cputcxy - // [2293] phi from display_frame::@17 to cputcxy [phi:display_frame::@17->cputcxy] - // [2293] phi cputcxy::c#17 = cputcxy::c#3 [phi:display_frame::@17->cputcxy#0] -- register_copy - // [2293] phi cputcxy::y#17 = cputcxy::y#3 [phi:display_frame::@17->cputcxy#1] -- register_copy - // [2293] phi cputcxy::x#17 = cputcxy::x#3 [phi:display_frame::@17->cputcxy#2] -- register_copy - jsr cputcxy - // display_frame::@18 - // if(h>=2) - // [2182] if(display_frame::h#0<2) goto display_frame::@return -- vbum1_lt_vbuc1_then_la1 - lda h - cmp #2 - bcc __breturn - // display_frame::@3 - // y++; - // [2183] display_frame::y#1 = ++ display_frame::y#0 -- vbum1=_inc_vbum2 - lda y - inc - sta y_1 - // [2184] phi from display_frame::@27 display_frame::@3 to display_frame::@6 [phi:display_frame::@27/display_frame::@3->display_frame::@6] - // [2184] phi display_frame::y#10 = display_frame::y#2 [phi:display_frame::@27/display_frame::@3->display_frame::@6#0] -- register_copy - // display_frame::@6 - __b6: - // while(y < y1) - // [2185] if(display_frame::y#10display_frame_maskxy] - // [3076] phi display_frame_maskxy::cpeekcxy1_y#0 = display_frame_maskxy::y#5 [phi:display_frame::@8->display_frame_maskxy#0] -- register_copy - // [3076] phi display_frame_maskxy::cpeekcxy1_x#0 = display_frame_maskxy::x#5 [phi:display_frame::@8->display_frame_maskxy#1] -- register_copy - jsr display_frame_maskxy - // display_frame_maskxy(x, y) - // [2189] display_frame_maskxy::return#18 = display_frame_maskxy::return#12 - // display_frame::@28 - // mask = display_frame_maskxy(x, y) - // [2190] display_frame::mask#10 = display_frame_maskxy::return#18 - // mask |= 0b1100 - // [2191] display_frame::mask#11 = display_frame::mask#10 | $c -- vbum1=vbum1_bor_vbuc1 - lda #$c - ora mask - sta mask - // display_frame_char(mask) - // [2192] display_frame_char::mask#5 = display_frame::mask#11 - // [2193] call display_frame_char - // [3102] phi from display_frame::@28 to display_frame_char [phi:display_frame::@28->display_frame_char] - // [3102] phi display_frame_char::mask#10 = display_frame_char::mask#5 [phi:display_frame::@28->display_frame_char#0] -- register_copy - jsr display_frame_char - // display_frame_char(mask) - // [2194] display_frame_char::return#18 = display_frame_char::return#12 - // display_frame::@29 - // c = display_frame_char(mask) - // [2195] display_frame::c#5 = display_frame_char::return#18 - // cputcxy(x, y, c) - // [2196] cputcxy::x#7 = display_frame::x#0 -- vbum1=vbum2 - lda x - sta cputcxy.x - // [2197] cputcxy::y#7 = display_frame::y#10 -- vbum1=vbum2 - lda y_1 - sta cputcxy.y - // [2198] cputcxy::c#7 = display_frame::c#5 - // [2199] call cputcxy - // [2293] phi from display_frame::@29 to cputcxy [phi:display_frame::@29->cputcxy] - // [2293] phi cputcxy::c#17 = cputcxy::c#7 [phi:display_frame::@29->cputcxy#0] -- register_copy - // [2293] phi cputcxy::y#17 = cputcxy::y#7 [phi:display_frame::@29->cputcxy#1] -- register_copy - // [2293] phi cputcxy::x#17 = cputcxy::x#7 [phi:display_frame::@29->cputcxy#2] -- register_copy - jsr cputcxy - // display_frame::@30 - // if(w>=2) - // [2200] if(display_frame::w#0<2) goto display_frame::@10 -- vbum1_lt_vbuc1_then_la1 - lda w - cmp #2 - bcc __b10 - // display_frame::@9 - // x++; - // [2201] display_frame::x#4 = ++ display_frame::x#0 -- vbum1=_inc_vbum1 - inc x - // [2202] phi from display_frame::@35 display_frame::@9 to display_frame::@11 [phi:display_frame::@35/display_frame::@9->display_frame::@11] - // [2202] phi display_frame::x#18 = display_frame::x#5 [phi:display_frame::@35/display_frame::@9->display_frame::@11#0] -- register_copy - // display_frame::@11 - __b11: - // while(x < x1) - // [2203] if(display_frame::x#18display_frame::@10] - // [2204] phi display_frame::x#15 = display_frame::x#18 [phi:display_frame::@11/display_frame::@30->display_frame::@10#0] -- register_copy - // display_frame::@10 - __b10: - // display_frame_maskxy(x, y) - // [2205] display_frame_maskxy::x#6 = display_frame::x#15 -- vbum1=vbum2 - lda x - sta display_frame_maskxy.x - // [2206] display_frame_maskxy::y#6 = display_frame::y#10 -- vbum1=vbum2 - lda y_1 - sta display_frame_maskxy.y - // [2207] call display_frame_maskxy - // [3076] phi from display_frame::@10 to display_frame_maskxy [phi:display_frame::@10->display_frame_maskxy] - // [3076] phi display_frame_maskxy::cpeekcxy1_y#0 = display_frame_maskxy::y#6 [phi:display_frame::@10->display_frame_maskxy#0] -- register_copy - // [3076] phi display_frame_maskxy::cpeekcxy1_x#0 = display_frame_maskxy::x#6 [phi:display_frame::@10->display_frame_maskxy#1] -- register_copy - jsr display_frame_maskxy - // display_frame_maskxy(x, y) - // [2208] display_frame_maskxy::return#19 = display_frame_maskxy::return#12 - // display_frame::@31 - // mask = display_frame_maskxy(x, y) - // [2209] display_frame::mask#12 = display_frame_maskxy::return#19 - // mask |= 0b1001 - // [2210] display_frame::mask#13 = display_frame::mask#12 | 9 -- vbum1=vbum1_bor_vbuc1 - lda #9 - ora mask - sta mask - // display_frame_char(mask) - // [2211] display_frame_char::mask#6 = display_frame::mask#13 - // [2212] call display_frame_char - // [3102] phi from display_frame::@31 to display_frame_char [phi:display_frame::@31->display_frame_char] - // [3102] phi display_frame_char::mask#10 = display_frame_char::mask#6 [phi:display_frame::@31->display_frame_char#0] -- register_copy - jsr display_frame_char - // display_frame_char(mask) - // [2213] display_frame_char::return#19 = display_frame_char::return#12 - // display_frame::@32 - // c = display_frame_char(mask) - // [2214] display_frame::c#6 = display_frame_char::return#19 - // cputcxy(x, y, c) - // [2215] cputcxy::x#8 = display_frame::x#15 -- vbum1=vbum2 - lda x - sta cputcxy.x - // [2216] cputcxy::y#8 = display_frame::y#10 -- vbum1=vbum2 - lda y_1 - sta cputcxy.y - // [2217] cputcxy::c#8 = display_frame::c#6 - // [2218] call cputcxy - // [2293] phi from display_frame::@32 to cputcxy [phi:display_frame::@32->cputcxy] - // [2293] phi cputcxy::c#17 = cputcxy::c#8 [phi:display_frame::@32->cputcxy#0] -- register_copy - // [2293] phi cputcxy::y#17 = cputcxy::y#8 [phi:display_frame::@32->cputcxy#1] -- register_copy - // [2293] phi cputcxy::x#17 = cputcxy::x#8 [phi:display_frame::@32->cputcxy#2] -- register_copy - jsr cputcxy - // display_frame::@return - __breturn: - // } - // [2219] return - rts - // display_frame::@12 - __b12: - // display_frame_maskxy(x, y) - // [2220] display_frame_maskxy::x#7 = display_frame::x#18 -- vbum1=vbum2 - lda x - sta display_frame_maskxy.x - // [2221] display_frame_maskxy::y#7 = display_frame::y#10 -- vbum1=vbum2 - lda y_1 - sta display_frame_maskxy.y - // [2222] call display_frame_maskxy - // [3076] phi from display_frame::@12 to display_frame_maskxy [phi:display_frame::@12->display_frame_maskxy] - // [3076] phi display_frame_maskxy::cpeekcxy1_y#0 = display_frame_maskxy::y#7 [phi:display_frame::@12->display_frame_maskxy#0] -- register_copy - // [3076] phi display_frame_maskxy::cpeekcxy1_x#0 = display_frame_maskxy::x#7 [phi:display_frame::@12->display_frame_maskxy#1] -- register_copy - jsr display_frame_maskxy - // display_frame_maskxy(x, y) - // [2223] display_frame_maskxy::return#20 = display_frame_maskxy::return#12 - // display_frame::@33 - // mask = display_frame_maskxy(x, y) - // [2224] display_frame::mask#14 = display_frame_maskxy::return#20 - // mask |= 0b0101 - // [2225] display_frame::mask#15 = display_frame::mask#14 | 5 -- vbum1=vbum1_bor_vbuc1 - lda #5 - ora mask - sta mask - // display_frame_char(mask) - // [2226] display_frame_char::mask#7 = display_frame::mask#15 - // [2227] call display_frame_char - // [3102] phi from display_frame::@33 to display_frame_char [phi:display_frame::@33->display_frame_char] - // [3102] phi display_frame_char::mask#10 = display_frame_char::mask#7 [phi:display_frame::@33->display_frame_char#0] -- register_copy - jsr display_frame_char - // display_frame_char(mask) - // [2228] display_frame_char::return#20 = display_frame_char::return#12 - // display_frame::@34 - // c = display_frame_char(mask) - // [2229] display_frame::c#7 = display_frame_char::return#20 - // cputcxy(x, y, c) - // [2230] cputcxy::x#9 = display_frame::x#18 -- vbum1=vbum2 - lda x - sta cputcxy.x - // [2231] cputcxy::y#9 = display_frame::y#10 -- vbum1=vbum2 - lda y_1 - sta cputcxy.y - // [2232] cputcxy::c#9 = display_frame::c#7 - // [2233] call cputcxy - // [2293] phi from display_frame::@34 to cputcxy [phi:display_frame::@34->cputcxy] - // [2293] phi cputcxy::c#17 = cputcxy::c#9 [phi:display_frame::@34->cputcxy#0] -- register_copy - // [2293] phi cputcxy::y#17 = cputcxy::y#9 [phi:display_frame::@34->cputcxy#1] -- register_copy - // [2293] phi cputcxy::x#17 = cputcxy::x#9 [phi:display_frame::@34->cputcxy#2] -- register_copy - jsr cputcxy - // display_frame::@35 - // x++; - // [2234] display_frame::x#5 = ++ display_frame::x#18 -- vbum1=_inc_vbum1 - inc x - jmp __b11 - // display_frame::@7 - __b7: - // display_frame_maskxy(x0, y) - // [2235] display_frame_maskxy::x#3 = display_frame::x#0 -- vbum1=vbum2 - lda x - sta display_frame_maskxy.x - // [2236] display_frame_maskxy::y#3 = display_frame::y#10 -- vbum1=vbum2 - lda y_1 - sta display_frame_maskxy.y - // [2237] call display_frame_maskxy - // [3076] phi from display_frame::@7 to display_frame_maskxy [phi:display_frame::@7->display_frame_maskxy] - // [3076] phi display_frame_maskxy::cpeekcxy1_y#0 = display_frame_maskxy::y#3 [phi:display_frame::@7->display_frame_maskxy#0] -- register_copy - // [3076] phi display_frame_maskxy::cpeekcxy1_x#0 = display_frame_maskxy::x#3 [phi:display_frame::@7->display_frame_maskxy#1] -- register_copy - jsr display_frame_maskxy - // display_frame_maskxy(x0, y) - // [2238] display_frame_maskxy::return#16 = display_frame_maskxy::return#12 - // display_frame::@22 - // mask = display_frame_maskxy(x0, y) - // [2239] display_frame::mask#6 = display_frame_maskxy::return#16 - // mask |= 0b1010 - // [2240] display_frame::mask#7 = display_frame::mask#6 | $a -- vbum1=vbum1_bor_vbuc1 - lda #$a - ora mask - sta mask - // display_frame_char(mask) - // [2241] display_frame_char::mask#3 = display_frame::mask#7 - // [2242] call display_frame_char - // [3102] phi from display_frame::@22 to display_frame_char [phi:display_frame::@22->display_frame_char] - // [3102] phi display_frame_char::mask#10 = display_frame_char::mask#3 [phi:display_frame::@22->display_frame_char#0] -- register_copy - jsr display_frame_char - // display_frame_char(mask) - // [2243] display_frame_char::return#16 = display_frame_char::return#12 - // display_frame::@23 - // c = display_frame_char(mask) - // [2244] display_frame::c#3 = display_frame_char::return#16 - // cputcxy(x0, y, c) - // [2245] cputcxy::x#5 = display_frame::x#0 -- vbum1=vbum2 - lda x - sta cputcxy.x - // [2246] cputcxy::y#5 = display_frame::y#10 -- vbum1=vbum2 - lda y_1 - sta cputcxy.y - // [2247] cputcxy::c#5 = display_frame::c#3 - // [2248] call cputcxy - // [2293] phi from display_frame::@23 to cputcxy [phi:display_frame::@23->cputcxy] - // [2293] phi cputcxy::c#17 = cputcxy::c#5 [phi:display_frame::@23->cputcxy#0] -- register_copy - // [2293] phi cputcxy::y#17 = cputcxy::y#5 [phi:display_frame::@23->cputcxy#1] -- register_copy - // [2293] phi cputcxy::x#17 = cputcxy::x#5 [phi:display_frame::@23->cputcxy#2] -- register_copy - jsr cputcxy - // display_frame::@24 - // display_frame_maskxy(x1, y) - // [2249] display_frame_maskxy::x#4 = display_frame::x1#16 -- vbum1=vbum2 - lda x1 - sta display_frame_maskxy.x - // [2250] display_frame_maskxy::y#4 = display_frame::y#10 -- vbum1=vbum2 - lda y_1 - sta display_frame_maskxy.y - // [2251] call display_frame_maskxy - // [3076] phi from display_frame::@24 to display_frame_maskxy [phi:display_frame::@24->display_frame_maskxy] - // [3076] phi display_frame_maskxy::cpeekcxy1_y#0 = display_frame_maskxy::y#4 [phi:display_frame::@24->display_frame_maskxy#0] -- register_copy - // [3076] phi display_frame_maskxy::cpeekcxy1_x#0 = display_frame_maskxy::x#4 [phi:display_frame::@24->display_frame_maskxy#1] -- register_copy - jsr display_frame_maskxy - // display_frame_maskxy(x1, y) - // [2252] display_frame_maskxy::return#17 = display_frame_maskxy::return#12 - // display_frame::@25 - // mask = display_frame_maskxy(x1, y) - // [2253] display_frame::mask#8 = display_frame_maskxy::return#17 - // mask |= 0b1010 - // [2254] display_frame::mask#9 = display_frame::mask#8 | $a -- vbum1=vbum1_bor_vbuc1 - lda #$a - ora mask - sta mask - // display_frame_char(mask) - // [2255] display_frame_char::mask#4 = display_frame::mask#9 - // [2256] call display_frame_char - // [3102] phi from display_frame::@25 to display_frame_char [phi:display_frame::@25->display_frame_char] - // [3102] phi display_frame_char::mask#10 = display_frame_char::mask#4 [phi:display_frame::@25->display_frame_char#0] -- register_copy - jsr display_frame_char - // display_frame_char(mask) - // [2257] display_frame_char::return#17 = display_frame_char::return#12 - // display_frame::@26 - // c = display_frame_char(mask) - // [2258] display_frame::c#4 = display_frame_char::return#17 - // cputcxy(x1, y, c) - // [2259] cputcxy::x#6 = display_frame::x1#16 -- vbum1=vbum2 - lda x1 - sta cputcxy.x - // [2260] cputcxy::y#6 = display_frame::y#10 -- vbum1=vbum2 - lda y_1 - sta cputcxy.y - // [2261] cputcxy::c#6 = display_frame::c#4 - // [2262] call cputcxy - // [2293] phi from display_frame::@26 to cputcxy [phi:display_frame::@26->cputcxy] - // [2293] phi cputcxy::c#17 = cputcxy::c#6 [phi:display_frame::@26->cputcxy#0] -- register_copy - // [2293] phi cputcxy::y#17 = cputcxy::y#6 [phi:display_frame::@26->cputcxy#1] -- register_copy - // [2293] phi cputcxy::x#17 = cputcxy::x#6 [phi:display_frame::@26->cputcxy#2] -- register_copy - jsr cputcxy - // display_frame::@27 - // y++; - // [2263] display_frame::y#2 = ++ display_frame::y#10 -- vbum1=_inc_vbum1 - inc y_1 - jmp __b6 - // display_frame::@5 - __b5: - // display_frame_maskxy(x, y) - // [2264] display_frame_maskxy::x#2 = display_frame::x#10 -- vbum1=vbum2 - lda x_1 - sta display_frame_maskxy.x - // [2265] display_frame_maskxy::y#2 = display_frame::y#0 -- vbum1=vbum2 - lda y - sta display_frame_maskxy.y - // [2266] call display_frame_maskxy - // [3076] phi from display_frame::@5 to display_frame_maskxy [phi:display_frame::@5->display_frame_maskxy] - // [3076] phi display_frame_maskxy::cpeekcxy1_y#0 = display_frame_maskxy::y#2 [phi:display_frame::@5->display_frame_maskxy#0] -- register_copy - // [3076] phi display_frame_maskxy::cpeekcxy1_x#0 = display_frame_maskxy::x#2 [phi:display_frame::@5->display_frame_maskxy#1] -- register_copy - jsr display_frame_maskxy - // display_frame_maskxy(x, y) - // [2267] display_frame_maskxy::return#15 = display_frame_maskxy::return#12 - // display_frame::@19 - // mask = display_frame_maskxy(x, y) - // [2268] display_frame::mask#4 = display_frame_maskxy::return#15 - // mask |= 0b0101 - // [2269] display_frame::mask#5 = display_frame::mask#4 | 5 -- vbum1=vbum1_bor_vbuc1 - lda #5 - ora mask - sta mask - // display_frame_char(mask) - // [2270] display_frame_char::mask#2 = display_frame::mask#5 - // [2271] call display_frame_char - // [3102] phi from display_frame::@19 to display_frame_char [phi:display_frame::@19->display_frame_char] - // [3102] phi display_frame_char::mask#10 = display_frame_char::mask#2 [phi:display_frame::@19->display_frame_char#0] -- register_copy - jsr display_frame_char - // display_frame_char(mask) - // [2272] display_frame_char::return#15 = display_frame_char::return#12 - // display_frame::@20 - // c = display_frame_char(mask) - // [2273] display_frame::c#2 = display_frame_char::return#15 - // cputcxy(x, y, c) - // [2274] cputcxy::x#4 = display_frame::x#10 -- vbum1=vbum2 - lda x_1 - sta cputcxy.x - // [2275] cputcxy::y#4 = display_frame::y#0 -- vbum1=vbum2 - lda y - sta cputcxy.y - // [2276] cputcxy::c#4 = display_frame::c#2 - // [2277] call cputcxy - // [2293] phi from display_frame::@20 to cputcxy [phi:display_frame::@20->cputcxy] - // [2293] phi cputcxy::c#17 = cputcxy::c#4 [phi:display_frame::@20->cputcxy#0] -- register_copy - // [2293] phi cputcxy::y#17 = cputcxy::y#4 [phi:display_frame::@20->cputcxy#1] -- register_copy - // [2293] phi cputcxy::x#17 = cputcxy::x#4 [phi:display_frame::@20->cputcxy#2] -- register_copy - jsr cputcxy - // display_frame::@21 - // x++; - // [2278] display_frame::x#2 = ++ display_frame::x#10 -- vbum1=_inc_vbum1 - inc x_1 - jmp __b4 - // display_frame::@36 - __b36: - // [2279] display_frame::x#30 = display_frame::x#0 -- vbum1=vbum2 - lda x - sta x_1 - jmp __b1 - .segment Data - w: .byte 0 - h: .byte 0 - x: .byte 0 + lda.z vera_bram_ptr + cmp #<$9800 + beq !__b5+ + jmp __b5 + !__b5: + // [1473] phi from vera_read::@12 to vera_read::@5 [phi:vera_read::@12->vera_read::@5] + // [1473] phi vera_read::y#11 = vera_read::y#22 [phi:vera_read::@12->vera_read::@5#0] -- register_copy + // [1473] phi vera_read::progress_row_current#10 = vera_read::progress_row_current#15 [phi:vera_read::@12->vera_read::@5#1] -- register_copy + // [1473] phi vera_read::vera_bram_ptr#13 = (char *)$a000 [phi:vera_read::@12->vera_read::@5#2] -- pbuz1=pbuc1 + lda #<$a000 + sta.z vera_bram_ptr + lda #>$a000 + sta.z vera_bram_ptr+1 + // [1473] phi vera_read::vera_bram_bank#10 = 1 [phi:vera_read::@12->vera_read::@5#3] -- vbum1=vbuc1 + lda #1 + sta vera_bram_bank + // [1473] phi vera_read::vera_file_size#11 = vera_read::vera_file_size#1 [phi:vera_read::@12->vera_read::@5#4] -- register_copy + jmp __b5 + // [1510] phi from vera_read::@12 to vera_read::@22 [phi:vera_read::@12->vera_read::@22] + // vera_read::@22 + // [1473] phi from vera_read::@22 to vera_read::@5 [phi:vera_read::@22->vera_read::@5] + // [1473] phi vera_read::y#11 = vera_read::y#22 [phi:vera_read::@22->vera_read::@5#0] -- register_copy + // [1473] phi vera_read::progress_row_current#10 = vera_read::progress_row_current#15 [phi:vera_read::@22->vera_read::@5#1] -- register_copy + // [1473] phi vera_read::vera_bram_ptr#13 = vera_read::vera_bram_ptr#8 [phi:vera_read::@22->vera_read::@5#2] -- register_copy + // [1473] phi vera_read::vera_bram_bank#10 = vera_read::vera_bram_bank#13 [phi:vera_read::@22->vera_read::@5#3] -- register_copy + // [1473] phi vera_read::vera_file_size#11 = vera_read::vera_file_size#1 [phi:vera_read::@22->vera_read::@5#4] -- register_copy + .segment DataVera + info_text: .text "Opening VERA.BIN from SD card ..." + .byte 0 + path: .text "VERA.BIN" + .byte 0 + vera_action_text_1: .text "Reading" + .byte 0 + vera_action_text_2: .text "Checking" + .byte 0 + return: .dword 0 + vera_package_read: .word 0 y: .byte 0 - .label mask = display_frame_maskxy.return - .label c = cputcxy.c - x_1: .byte 0 - y_1: .byte 0 - x1: .byte 0 - y1: .byte 0 + .label vera_file_size = return + vera_bram_bank: .byte 0 + progress_row_current: .word 0 + info_status: .byte 0 } .segment Code - // cputs -// Output a NUL-terminated string at the current cursor position -// void cputs(__zp($38) const char *s) -cputs: { - .label s = $38 - // [2281] phi from cputs cputs::@2 to cputs::@1 [phi:cputs/cputs::@2->cputs::@1] - // [2281] phi cputs::s#2 = cputs::s#1 [phi:cputs/cputs::@2->cputs::@1#0] -- register_copy - // cputs::@1 - __b1: - // while(c=*s++) - // [2282] cputs::c#1 = *cputs::s#2 -- vbum1=_deref_pbuz2 - ldy #0 - lda (s),y - sta c - // [2283] cputs::s#0 = ++ cputs::s#2 -- pbuz1=_inc_pbuz1 - inc.z s - bne !+ - inc.z s+1 - !: - // [2284] if(0!=cputs::c#1) goto cputs::@2 -- 0_neq_vbum1_then_la1 - lda c - bne __b2 - // cputs::@return + // uctoa +// Converts unsigned number value to a string representing it in RADIX format. +// If the leading digits are zero they are not included in the string. +// - value : The number to be converted to RADIX +// - buffer : receives the string representing the number and zero-termination. +// - radix : The radix to convert the number to (from the enum RADIX) +// void uctoa(__mem() char value, __zp($40) char *buffer, __mem() char radix) +uctoa: { + .label uctoa__4 = $38 + .label buffer = $40 + .label digit_values = $2d + // if(radix==DECIMAL) + // [1511] if(uctoa::radix#0==DECIMAL) goto uctoa::@1 -- vbum1_eq_vbuc1_then_la1 + lda #DECIMAL + cmp radix + beq __b2 + // uctoa::@2 + // if(radix==HEXADECIMAL) + // [1512] if(uctoa::radix#0==HEXADECIMAL) goto uctoa::@1 -- vbum1_eq_vbuc1_then_la1 + lda #HEXADECIMAL + cmp radix + beq __b3 + // uctoa::@3 + // if(radix==OCTAL) + // [1513] if(uctoa::radix#0==OCTAL) goto uctoa::@1 -- vbum1_eq_vbuc1_then_la1 + lda #OCTAL + cmp radix + beq __b4 + // uctoa::@4 + // if(radix==BINARY) + // [1514] if(uctoa::radix#0==BINARY) goto uctoa::@1 -- vbum1_eq_vbuc1_then_la1 + lda #BINARY + cmp radix + beq __b5 + // uctoa::@5 + // *buffer++ = 'e' + // [1515] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS) = 'e' -- _deref_pbuc1=vbuc2 + // Unknown radix + lda #'e' + sta printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS + // *buffer++ = 'r' + // [1516] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+1) = 'r' -- _deref_pbuc1=vbuc2 + lda #'r' + sta printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+1 + // [1517] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+2) = 'r' -- _deref_pbuc1=vbuc2 + sta printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+2 + // *buffer = 0 + // [1518] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+3) = 0 -- _deref_pbuc1=vbuc2 + lda #0 + sta printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+3 + // uctoa::@return // } - // [2285] return + // [1519] return rts - // cputs::@2 + // [1520] phi from uctoa to uctoa::@1 [phi:uctoa->uctoa::@1] __b2: - // cputc(c) - // [2286] stackpush(char) = cputs::c#1 -- _stackpushbyte_=vbum1 - lda c - pha - // [2287] callexecute cputc -- call_vprc1 - jsr cputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla + // [1520] phi uctoa::digit_values#8 = RADIX_DECIMAL_VALUES_CHAR [phi:uctoa->uctoa::@1#0] -- pbuz1=pbuc1 + lda #RADIX_DECIMAL_VALUES_CHAR + sta.z digit_values+1 + // [1520] phi uctoa::max_digits#7 = 3 [phi:uctoa->uctoa::@1#1] -- vbum1=vbuc1 + lda #3 + sta max_digits jmp __b1 - .segment Data - c: .byte 0 -} -.segment Code - // wherex -// Return the x position of the cursor -wherex: { - // return __conio.cursor_x; - // [2289] wherex::return#0 = *((char *)&__conio) -- vbum1=_deref_pbuc1 - lda __conio - sta return - // wherex::@return - // } - // [2290] return + // [1520] phi from uctoa::@2 to uctoa::@1 [phi:uctoa::@2->uctoa::@1] + __b3: + // [1520] phi uctoa::digit_values#8 = RADIX_HEXADECIMAL_VALUES_CHAR [phi:uctoa::@2->uctoa::@1#0] -- pbuz1=pbuc1 + lda #RADIX_HEXADECIMAL_VALUES_CHAR + sta.z digit_values+1 + // [1520] phi uctoa::max_digits#7 = 2 [phi:uctoa::@2->uctoa::@1#1] -- vbum1=vbuc1 + lda #2 + sta max_digits + jmp __b1 + // [1520] phi from uctoa::@3 to uctoa::@1 [phi:uctoa::@3->uctoa::@1] + __b4: + // [1520] phi uctoa::digit_values#8 = RADIX_OCTAL_VALUES_CHAR [phi:uctoa::@3->uctoa::@1#0] -- pbuz1=pbuc1 + lda #RADIX_OCTAL_VALUES_CHAR + sta.z digit_values+1 + // [1520] phi uctoa::max_digits#7 = 3 [phi:uctoa::@3->uctoa::@1#1] -- vbum1=vbuc1 + lda #3 + sta max_digits + jmp __b1 + // [1520] phi from uctoa::@4 to uctoa::@1 [phi:uctoa::@4->uctoa::@1] + __b5: + // [1520] phi uctoa::digit_values#8 = RADIX_BINARY_VALUES_CHAR [phi:uctoa::@4->uctoa::@1#0] -- pbuz1=pbuc1 + lda #RADIX_BINARY_VALUES_CHAR + sta.z digit_values+1 + // [1520] phi uctoa::max_digits#7 = 8 [phi:uctoa::@4->uctoa::@1#1] -- vbum1=vbuc1 + lda #8 + sta max_digits + // uctoa::@1 + __b1: + // [1521] phi from uctoa::@1 to uctoa::@6 [phi:uctoa::@1->uctoa::@6] + // [1521] phi uctoa::buffer#11 = (char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS [phi:uctoa::@1->uctoa::@6#0] -- pbuz1=pbuc1 + lda #printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS + sta.z buffer+1 + // [1521] phi uctoa::started#2 = 0 [phi:uctoa::@1->uctoa::@6#1] -- vbum1=vbuc1 + lda #0 + sta started + // [1521] phi uctoa::value#2 = uctoa::value#1 [phi:uctoa::@1->uctoa::@6#2] -- register_copy + // [1521] phi uctoa::digit#2 = 0 [phi:uctoa::@1->uctoa::@6#3] -- vbum1=vbuc1 + sta digit + // uctoa::@6 + __b6: + // max_digits-1 + // [1522] uctoa::$4 = uctoa::max_digits#7 - 1 -- vbuz1=vbum2_minus_1 + ldx max_digits + dex + stx.z uctoa__4 + // for( char digit=0; digit= digit_value) + // [1528] if(0!=uctoa::started#2) goto uctoa::@10 -- 0_neq_vbum1_then_la1 + lda started + bne __b10 + // uctoa::@12 + // [1529] if(uctoa::value#2>=uctoa::digit_value#0) goto uctoa::@10 -- vbum1_ge_vbum2_then_la1 + lda value + cmp digit_value + bcs __b10 + // [1530] phi from uctoa::@12 to uctoa::@9 [phi:uctoa::@12->uctoa::@9] + // [1530] phi uctoa::buffer#14 = uctoa::buffer#11 [phi:uctoa::@12->uctoa::@9#0] -- register_copy + // [1530] phi uctoa::started#4 = uctoa::started#2 [phi:uctoa::@12->uctoa::@9#1] -- register_copy + // [1530] phi uctoa::value#6 = uctoa::value#2 [phi:uctoa::@12->uctoa::@9#2] -- register_copy + // uctoa::@9 + __b9: + // for( char digit=0; digituctoa::@6] + // [1521] phi uctoa::buffer#11 = uctoa::buffer#14 [phi:uctoa::@9->uctoa::@6#0] -- register_copy + // [1521] phi uctoa::started#2 = uctoa::started#4 [phi:uctoa::@9->uctoa::@6#1] -- register_copy + // [1521] phi uctoa::value#2 = uctoa::value#6 [phi:uctoa::@9->uctoa::@6#2] -- register_copy + // [1521] phi uctoa::digit#2 = uctoa::digit#1 [phi:uctoa::@9->uctoa::@6#3] -- register_copy + jmp __b6 + // uctoa::@10 + __b10: + // uctoa_append(buffer++, value, digit_value) + // [1532] uctoa_append::buffer#0 = uctoa::buffer#11 -- pbuz1=pbuz2 + lda.z buffer + sta.z uctoa_append.buffer + lda.z buffer+1 + sta.z uctoa_append.buffer+1 + // [1533] uctoa_append::value#0 = uctoa::value#2 + // [1534] uctoa_append::sub#0 = uctoa::digit_value#0 + // [1535] call uctoa_append + // [2109] phi from uctoa::@10 to uctoa_append [phi:uctoa::@10->uctoa_append] + jsr uctoa_append + // uctoa_append(buffer++, value, digit_value) + // [1536] uctoa_append::return#0 = uctoa_append::value#2 + // uctoa::@11 + // value = uctoa_append(buffer++, value, digit_value) + // [1537] uctoa::value#0 = uctoa_append::return#0 + // value = uctoa_append(buffer++, value, digit_value); + // [1538] uctoa::buffer#4 = ++ uctoa::buffer#11 -- pbuz1=_inc_pbuz1 + inc.z buffer + bne !+ + inc.z buffer+1 + !: + // [1530] phi from uctoa::@11 to uctoa::@9 [phi:uctoa::@11->uctoa::@9] + // [1530] phi uctoa::buffer#14 = uctoa::buffer#4 [phi:uctoa::@11->uctoa::@9#0] -- register_copy + // [1530] phi uctoa::started#4 = 1 [phi:uctoa::@11->uctoa::@9#1] -- vbum1=vbuc1 + lda #1 + sta started + // [1530] phi uctoa::value#6 = uctoa::value#0 [phi:uctoa::@11->uctoa::@9#2] -- register_copy + jmp __b9 .segment Data - return: .byte 0 - return_1: .byte 0 - return_2: .byte 0 - return_3: .byte 0 - return_4: .byte 0 + digit_value: .byte 0 + digit: .byte 0 + .label value = printf_uchar.uvalue + .label radix = printf_uchar.format_radix + started: .byte 0 + max_digits: .byte 0 } .segment Code - // wherey -// Return the y position of the cursor -wherey: { - // return __conio.cursor_y; - // [2291] wherey::return#0 = *((char *)&__conio+1) -- vbum1=_deref_pbuc1 - lda __conio+1 - sta return - // wherey::@return + // printf_number_buffer +// Print the contents of the number buffer using a specific format. +// This handles minimum length, zero-filling, and left/right justification from the format +// void printf_number_buffer(__zp($49) void (*putc)(char), __mem() char buffer_sign, char *buffer_digits, __mem() char format_min_length, char format_justify_left, char format_sign_always, __mem() char format_zero_padding, char format_upper_case, char format_radix) +printf_number_buffer: { + .label printf_number_buffer__19 = $53 + .label putc = $49 + // if(format.min_length) + // [1540] if(0==printf_number_buffer::format_min_length#3) goto printf_number_buffer::@1 -- 0_eq_vbum1_then_la1 + lda format_min_length + beq __b5 + // [1541] phi from printf_number_buffer to printf_number_buffer::@5 [phi:printf_number_buffer->printf_number_buffer::@5] + // printf_number_buffer::@5 + // strlen(buffer.digits) + // [1542] call strlen + // [1788] phi from printf_number_buffer::@5 to strlen [phi:printf_number_buffer::@5->strlen] + // [1788] phi strlen::str#8 = (char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS [phi:printf_number_buffer::@5->strlen#0] -- pbuz1=pbuc1 + lda #printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS + sta.z strlen.str+1 + jsr strlen + // strlen(buffer.digits) + // [1543] strlen::return#3 = strlen::len#2 + // printf_number_buffer::@11 + // [1544] printf_number_buffer::$19 = strlen::return#3 -- vwuz1=vwum2 + lda strlen.return + sta.z printf_number_buffer__19 + lda strlen.return+1 + sta.z printf_number_buffer__19+1 + // signed char len = (signed char)strlen(buffer.digits) + // [1545] printf_number_buffer::len#0 = (signed char)printf_number_buffer::$19 -- vbsm1=_sbyte_vwuz2 + // There is a minimum length - work out the padding + lda.z printf_number_buffer__19 + sta len + // if(buffer.sign) + // [1546] if(0==printf_number_buffer::buffer_sign#10) goto printf_number_buffer::@10 -- 0_eq_vbum1_then_la1 + lda buffer_sign + beq __b10 + // printf_number_buffer::@6 + // len++; + // [1547] printf_number_buffer::len#1 = ++ printf_number_buffer::len#0 -- vbsm1=_inc_vbsm1 + inc len + // [1548] phi from printf_number_buffer::@11 printf_number_buffer::@6 to printf_number_buffer::@10 [phi:printf_number_buffer::@11/printf_number_buffer::@6->printf_number_buffer::@10] + // [1548] phi printf_number_buffer::len#2 = printf_number_buffer::len#0 [phi:printf_number_buffer::@11/printf_number_buffer::@6->printf_number_buffer::@10#0] -- register_copy + // printf_number_buffer::@10 + __b10: + // padding = (signed char)format.min_length - len + // [1549] printf_number_buffer::padding#1 = (signed char)printf_number_buffer::format_min_length#3 - printf_number_buffer::len#2 -- vbsm1=vbsm2_minus_vbsm1 + lda format_min_length + sec + sbc padding + sta padding + // if(padding<0) + // [1550] if(printf_number_buffer::padding#1>=0) goto printf_number_buffer::@15 -- vbsm1_ge_0_then_la1 + cmp #0 + bpl __b1 + // [1552] phi from printf_number_buffer printf_number_buffer::@10 to printf_number_buffer::@1 [phi:printf_number_buffer/printf_number_buffer::@10->printf_number_buffer::@1] + __b5: + // [1552] phi printf_number_buffer::padding#10 = 0 [phi:printf_number_buffer/printf_number_buffer::@10->printf_number_buffer::@1#0] -- vbsm1=vbsc1 + lda #0 + sta padding + // [1551] phi from printf_number_buffer::@10 to printf_number_buffer::@15 [phi:printf_number_buffer::@10->printf_number_buffer::@15] + // printf_number_buffer::@15 + // [1552] phi from printf_number_buffer::@15 to printf_number_buffer::@1 [phi:printf_number_buffer::@15->printf_number_buffer::@1] + // [1552] phi printf_number_buffer::padding#10 = printf_number_buffer::padding#1 [phi:printf_number_buffer::@15->printf_number_buffer::@1#0] -- register_copy + // printf_number_buffer::@1 + __b1: + // printf_number_buffer::@13 + // if(!format.justify_left && !format.zero_padding && padding) + // [1553] if(0!=printf_number_buffer::format_zero_padding#10) goto printf_number_buffer::@2 -- 0_neq_vbum1_then_la1 + lda format_zero_padding + bne __b2 + // printf_number_buffer::@12 + // [1554] if(0!=printf_number_buffer::padding#10) goto printf_number_buffer::@7 -- 0_neq_vbsm1_then_la1 + lda padding + cmp #0 + bne __b7 + jmp __b2 + // printf_number_buffer::@7 + __b7: + // printf_padding(putc, ' ',(char)padding) + // [1555] printf_padding::putc#0 = printf_number_buffer::putc#10 -- pprz1=pprz2 + lda.z putc + sta.z printf_padding.putc + lda.z putc+1 + sta.z printf_padding.putc+1 + // [1556] printf_padding::length#0 = (char)printf_number_buffer::padding#10 -- vbum1=vbum2 + lda padding + sta printf_padding.length + // [1557] call printf_padding + // [1794] phi from printf_number_buffer::@7 to printf_padding [phi:printf_number_buffer::@7->printf_padding] + // [1794] phi printf_padding::putc#7 = printf_padding::putc#0 [phi:printf_number_buffer::@7->printf_padding#0] -- register_copy + // [1794] phi printf_padding::pad#7 = ' ' [phi:printf_number_buffer::@7->printf_padding#1] -- vbum1=vbuc1 + lda #' ' + sta printf_padding.pad + // [1794] phi printf_padding::length#6 = printf_padding::length#0 [phi:printf_number_buffer::@7->printf_padding#2] -- register_copy + jsr printf_padding + // printf_number_buffer::@2 + __b2: + // if(buffer.sign) + // [1558] if(0==printf_number_buffer::buffer_sign#10) goto printf_number_buffer::@3 -- 0_eq_vbum1_then_la1 + lda buffer_sign + beq __b3 + // printf_number_buffer::@8 + // putc(buffer.sign) + // [1559] stackpush(char) = printf_number_buffer::buffer_sign#10 -- _stackpushbyte_=vbum1 + pha + // [1560] callexecute *printf_number_buffer::putc#10 -- call__deref_pprz1 + jsr icall13 + // sideeffect stackpullpadding(1) -- _stackpullpadding_1 + pla + // printf_number_buffer::@3 + __b3: + // if(format.zero_padding && padding) + // [1562] if(0==printf_number_buffer::format_zero_padding#10) goto printf_number_buffer::@4 -- 0_eq_vbum1_then_la1 + lda format_zero_padding + beq __b4 + // printf_number_buffer::@14 + // [1563] if(0!=printf_number_buffer::padding#10) goto printf_number_buffer::@9 -- 0_neq_vbsm1_then_la1 + lda padding + cmp #0 + bne __b9 + jmp __b4 + // printf_number_buffer::@9 + __b9: + // printf_padding(putc, '0',(char)padding) + // [1564] printf_padding::putc#1 = printf_number_buffer::putc#10 -- pprz1=pprz2 + lda.z putc + sta.z printf_padding.putc + lda.z putc+1 + sta.z printf_padding.putc+1 + // [1565] printf_padding::length#1 = (char)printf_number_buffer::padding#10 -- vbum1=vbum2 + lda padding + sta printf_padding.length + // [1566] call printf_padding + // [1794] phi from printf_number_buffer::@9 to printf_padding [phi:printf_number_buffer::@9->printf_padding] + // [1794] phi printf_padding::putc#7 = printf_padding::putc#1 [phi:printf_number_buffer::@9->printf_padding#0] -- register_copy + // [1794] phi printf_padding::pad#7 = '0' [phi:printf_number_buffer::@9->printf_padding#1] -- vbum1=vbuc1 + lda #'0' + sta printf_padding.pad + // [1794] phi printf_padding::length#6 = printf_padding::length#1 [phi:printf_number_buffer::@9->printf_padding#2] -- register_copy + jsr printf_padding + // printf_number_buffer::@4 + __b4: + // printf_str(putc, buffer.digits) + // [1567] printf_str::putc#0 = printf_number_buffer::putc#10 + // [1568] call printf_str + // [785] phi from printf_number_buffer::@4 to printf_str [phi:printf_number_buffer::@4->printf_str] + // [785] phi printf_str::putc#53 = printf_str::putc#0 [phi:printf_number_buffer::@4->printf_str#0] -- register_copy + // [785] phi printf_str::s#53 = (char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS [phi:printf_number_buffer::@4->printf_str#1] -- pbuz1=pbuc1 + lda #printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS + sta.z printf_str.s+1 + jsr printf_str + // printf_number_buffer::@return // } - // [2292] return + // [1569] return rts + // Outside Flow + icall13: + jmp (putc) .segment Data - return: .byte 0 - return_1: .byte 0 - return_2: .byte 0 - return_3: .byte 0 - return_4: .byte 0 + buffer_sign: .byte 0 + .label format_min_length = printf_uchar.format_min_length + .label format_zero_padding = printf_uchar.format_zero_padding + len: .byte 0 + .label padding = len } -.segment Code - // cputcxy -// Move cursor and output one character -// Same as "gotoxy (x, y); cputc (c);" -// void cputcxy(__mem() char x, __mem() char y, __mem() char c) -cputcxy: { +.segment CodeVera + // vera_verify +vera_verify: { + .label vera_verify__16 = $65 + .label vera_bram_ptr = $76 + // vera_verify::bank_set_bram1 + // BRAM = bank + // [1571] BRAM = 1 -- vbuz1=vbuc1 + lda #1 + sta.z BRAM + // vera_verify::@11 + // unsigned long vera_boundary = vera_file_size + // [1572] vera_verify::vera_boundary#0 = vera_file_size#1 -- vdum1=vdum2 + lda vera_file_size + sta vera_boundary + lda vera_file_size+1 + sta vera_boundary+1 + lda vera_file_size+2 + sta vera_boundary+2 + lda vera_file_size+3 + sta vera_boundary+3 + // [1573] spi_manufacturer#423 = spi_read::return#0 -- vbum1=vbum2 + lda spi_read.return + sta spi_manufacturer + // [1574] spi_memory_type#424 = spi_read::return#1 -- vbum1=vbum2 + lda spi_read.return_1 + sta spi_memory_type + // [1575] spi_memory_capacity#425 = spi_read::return#2 -- vbum1=vbum2 + lda spi_read.return_2 + sta spi_memory_capacity + // display_info_vera(STATUS_COMPARING, "Comparing VERA ...") + // [1576] call display_info_vera + // [653] phi from vera_verify::@11 to display_info_vera [phi:vera_verify::@11->display_info_vera] + // [653] phi display_info_vera::info_text#19 = vera_verify::info_text [phi:vera_verify::@11->display_info_vera#0] -- pbuz1=pbuc1 + lda #info_text + sta.z display_info_vera.info_text+1 + // [653] phi spi_memory_capacity#110 = spi_memory_capacity#425 [phi:vera_verify::@11->display_info_vera#1] -- register_copy + // [653] phi spi_memory_type#111 = spi_memory_type#424 [phi:vera_verify::@11->display_info_vera#2] -- register_copy + // [653] phi spi_manufacturer#100 = spi_manufacturer#423 [phi:vera_verify::@11->display_info_vera#3] -- register_copy + // [653] phi display_info_vera::info_status#19 = STATUS_COMPARING [phi:vera_verify::@11->display_info_vera#4] -- vbum1=vbuc1 + lda #STATUS_COMPARING + sta display_info_vera.info_status + jsr display_info_vera + // [1577] phi from vera_verify::@11 to vera_verify::@12 [phi:vera_verify::@11->vera_verify::@12] + // vera_verify::@12 // gotoxy(x, y) - // [2294] gotoxy::x#0 = cputcxy::x#17 -- vbum1=vbum2 - lda x + // [1578] call gotoxy + // [457] phi from vera_verify::@12 to gotoxy [phi:vera_verify::@12->gotoxy] + // [457] phi gotoxy::y#26 = PROGRESS_Y [phi:vera_verify::@12->gotoxy#0] -- vbum1=vbuc1 + lda #PROGRESS_Y + sta gotoxy.y + // [457] phi gotoxy::x#26 = PROGRESS_X [phi:vera_verify::@12->gotoxy#1] -- vbum1=vbuc1 + lda #PROGRESS_X sta gotoxy.x - // [2295] gotoxy::y#0 = cputcxy::y#17 -- vbum1=vbum2 + jsr gotoxy + // [1579] phi from vera_verify::@12 to vera_verify::@13 [phi:vera_verify::@12->vera_verify::@13] + // vera_verify::@13 + // spi_read_flash(0UL) + // [1580] call spi_read_flash + // [2116] phi from vera_verify::@13 to spi_read_flash [phi:vera_verify::@13->spi_read_flash] + jsr spi_read_flash + // [1581] phi from vera_verify::@13 to vera_verify::@1 [phi:vera_verify::@13->vera_verify::@1] + // [1581] phi vera_verify::y#3 = PROGRESS_Y [phi:vera_verify::@13->vera_verify::@1#0] -- vbum1=vbuc1 + lda #PROGRESS_Y + sta y + // [1581] phi vera_verify::progress_row_current#3 = 0 [phi:vera_verify::@13->vera_verify::@1#1] -- vwum1=vwuc1 + lda #<0 + sta progress_row_current + sta progress_row_current+1 + // [1581] phi vera_verify::vera_different_bytes#11 = 0 [phi:vera_verify::@13->vera_verify::@1#2] -- vdum1=vduc1 + sta vera_different_bytes + sta vera_different_bytes+1 + lda #<0>>$10 + sta vera_different_bytes+2 + lda #>0>>$10 + sta vera_different_bytes+3 + // [1581] phi vera_verify::vera_bram_ptr#10 = (char *)$a000 [phi:vera_verify::@13->vera_verify::@1#3] -- pbuz1=pbuc1 + lda #<$a000 + sta.z vera_bram_ptr + lda #>$a000 + sta.z vera_bram_ptr+1 + // [1581] phi vera_verify::vera_bram_bank#11 = 1 [phi:vera_verify::@13->vera_verify::@1#4] -- vbum1=vbuc1 + lda #1 + sta vera_bram_bank + // [1581] phi vera_verify::vera_address#11 = 0 [phi:vera_verify::@13->vera_verify::@1#5] -- vdum1=vduc1 + lda #<0 + sta vera_address + sta vera_address+1 + lda #<0>>$10 + sta vera_address+2 + lda #>0>>$10 + sta vera_address+3 + // vera_verify::@1 + __b1: + // while (vera_address < vera_boundary) + // [1582] if(vera_verify::vera_address#11vera_compare] + jsr vera_compare + // unsigned int equal_bytes = vera_compare(vera_bram_bank, (bram_ptr_t)vera_bram_ptr, VERA_PROGRESS_CELL) + // [1587] vera_compare::return#0 = vera_compare::equal_bytes#2 + // vera_verify::@14 + // [1588] vera_verify::equal_bytes#0 = vera_compare::return#0 + // if (progress_row_current == VERA_PROGRESS_ROW) + // [1589] if(vera_verify::progress_row_current#3!=VERA_PROGRESS_ROW) goto vera_verify::@3 -- vwum1_neq_vwuc1_then_la1 + lda progress_row_current+1 + cmp #>VERA_PROGRESS_ROW + bne __b3 + lda progress_row_current + cmp #gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#0 [phi:cputcxy->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = gotoxy::x#0 [phi:cputcxy->gotoxy#1] -- register_copy + // [1592] call gotoxy + // [457] phi from vera_verify::@8 to gotoxy [phi:vera_verify::@8->gotoxy] + // [457] phi gotoxy::y#26 = gotoxy::y#8 [phi:vera_verify::@8->gotoxy#0] -- register_copy + // [457] phi gotoxy::x#26 = PROGRESS_X [phi:vera_verify::@8->gotoxy#1] -- vbum1=vbuc1 + lda #PROGRESS_X + sta gotoxy.x jsr gotoxy - // cputcxy::@1 - // cputc(c) - // [2297] stackpush(char) = cputcxy::c#17 -- _stackpushbyte_=vbum1 - lda c + // [1593] phi from vera_verify::@8 to vera_verify::@3 [phi:vera_verify::@8->vera_verify::@3] + // [1593] phi vera_verify::y#10 = vera_verify::y#1 [phi:vera_verify::@8->vera_verify::@3#0] -- register_copy + // [1593] phi vera_verify::progress_row_current#4 = 0 [phi:vera_verify::@8->vera_verify::@3#1] -- vwum1=vbuc1 + lda #<0 + sta progress_row_current + sta progress_row_current+1 + // [1593] phi from vera_verify::@14 to vera_verify::@3 [phi:vera_verify::@14->vera_verify::@3] + // [1593] phi vera_verify::y#10 = vera_verify::y#3 [phi:vera_verify::@14->vera_verify::@3#0] -- register_copy + // [1593] phi vera_verify::progress_row_current#4 = vera_verify::progress_row_current#3 [phi:vera_verify::@14->vera_verify::@3#1] -- register_copy + // vera_verify::@3 + __b3: + // if (equal_bytes != VERA_PROGRESS_CELL) + // [1594] if(vera_verify::equal_bytes#0!=VERA_PROGRESS_CELL) goto vera_verify::@4 -- vwum1_neq_vbuc1_then_la1 + lda equal_bytes+1 + beq !__b4+ + jmp __b4 + !__b4: + lda equal_bytes + cmp #VERA_PROGRESS_CELL + beq !__b4+ + jmp __b4 + !__b4: + // vera_verify::@9 + // cputc('=') + // [1595] stackpush(char) = '=' -- _stackpushbyte_=vbuc1 + lda #'=' pha - // [2298] callexecute cputc -- call_vprc1 + // [1596] callexecute cputc -- call_vprc1 jsr cputc // sideeffect stackpullpadding(1) -- _stackpullpadding_1 pla - // cputcxy::@return - // } - // [2300] return - rts - .segment Data - x: .byte 0 - y: .byte 0 - c: .byte 0 -} -.segment Code - // display_smc_led -/** - * @brief Print SMC led above the SMC chip. - * - * @param c Led color - */ -// void display_smc_led(__mem() char c) -display_smc_led: { - // display_chip_led(CHIP_SMC_X+1, CHIP_SMC_Y, CHIP_SMC_W, c, BLUE) - // [2302] display_chip_led::tc#0 = display_smc_led::c#2 -- vbum1=vbum2 - lda c - sta display_chip_led.tc - // [2303] call display_chip_led - // [3117] phi from display_smc_led to display_chip_led [phi:display_smc_led->display_chip_led] - // [3117] phi display_chip_led::w#7 = 5 [phi:display_smc_led->display_chip_led#0] -- vbum1=vbuc1 - lda #5 - sta display_chip_led.w - // [3117] phi display_chip_led::x#7 = 1+1 [phi:display_smc_led->display_chip_led#1] -- vbum1=vbuc1 - lda #1+1 - sta display_chip_led.x - // [3117] phi display_chip_led::tc#3 = display_chip_led::tc#0 [phi:display_smc_led->display_chip_led#2] -- register_copy - jsr display_chip_led - // display_smc_led::@1 - // display_info_led(INFO_X-2, INFO_Y, c, BLUE) - // [2304] display_info_led::tc#0 = display_smc_led::c#2 - // [2305] call display_info_led - // [2380] phi from display_smc_led::@1 to display_info_led [phi:display_smc_led::@1->display_info_led] - // [2380] phi display_info_led::y#4 = $11 [phi:display_smc_led::@1->display_info_led#0] -- vbum1=vbuc1 - lda #$11 - sta display_info_led.y - // [2380] phi display_info_led::x#4 = 4-2 [phi:display_smc_led::@1->display_info_led#1] -- vbum1=vbuc1 - lda #4-2 - sta display_info_led.x - // [2380] phi display_info_led::tc#4 = display_info_led::tc#0 [phi:display_smc_led::@1->display_info_led#2] -- register_copy - jsr display_info_led - // display_smc_led::@return - // } - // [2306] return - rts - .segment Data - c: .byte 0 -} -.segment Code - // display_print_chip -/** - * @brief Print a full chip. - * - * @param x Start X - * @param y Start Y - * @param w Width - * @param text Vertical text to be displayed in the chip, starting from the top. - */ -// void display_print_chip(__mem() char x, char y, __mem() char w, __zp($72) char *text) -display_print_chip: { - .label y = 3+2+1+1+1+1+1+1+1+1 - .label text = $72 - .label text_1 = $66 - .label text_2 = $3d - .label text_3 = $69 - .label text_4 = $b0 - .label text_5 = $31 - .label text_6 = $4e - // display_chip_line(x, y++, w, *text++) - // [2308] display_chip_line::x#0 = display_print_chip::x#10 -- vbum1=vbum2 - lda x - sta display_chip_line.x - // [2309] display_chip_line::w#0 = display_print_chip::w#10 -- vbum1=vbum2 - lda w - sta display_chip_line.w - // [2310] display_chip_line::c#0 = *display_print_chip::text#11 -- vbum1=_deref_pbuz2 - ldy #0 - lda (text_2),y - sta display_chip_line.c - // [2311] call display_chip_line - // [3135] phi from display_print_chip to display_chip_line [phi:display_print_chip->display_chip_line] - // [3135] phi display_chip_line::c#15 = display_chip_line::c#0 [phi:display_print_chip->display_chip_line#0] -- register_copy - // [3135] phi display_chip_line::w#10 = display_chip_line::w#0 [phi:display_print_chip->display_chip_line#1] -- register_copy - // [3135] phi display_chip_line::y#16 = 3+2 [phi:display_print_chip->display_chip_line#2] -- vbum1=vbuc1 - lda #3+2 - sta display_chip_line.y - // [3135] phi display_chip_line::x#16 = display_chip_line::x#0 [phi:display_print_chip->display_chip_line#3] -- register_copy - jsr display_chip_line - // display_print_chip::@1 - // display_chip_line(x, y++, w, *text++); - // [2312] display_print_chip::text#0 = ++ display_print_chip::text#11 -- pbuz1=_inc_pbuz2 - clc - lda.z text_2 - adc #1 - sta.z text - lda.z text_2+1 - adc #0 - sta.z text+1 - // display_chip_line(x, y++, w, *text++) - // [2313] display_chip_line::x#1 = display_print_chip::x#10 -- vbum1=vbum2 - lda x - sta display_chip_line.x - // [2314] display_chip_line::w#1 = display_print_chip::w#10 -- vbum1=vbum2 - lda w - sta display_chip_line.w - // [2315] display_chip_line::c#1 = *display_print_chip::text#0 -- vbum1=_deref_pbuz2 - ldy #0 - lda (text),y - sta display_chip_line.c - // [2316] call display_chip_line - // [3135] phi from display_print_chip::@1 to display_chip_line [phi:display_print_chip::@1->display_chip_line] - // [3135] phi display_chip_line::c#15 = display_chip_line::c#1 [phi:display_print_chip::@1->display_chip_line#0] -- register_copy - // [3135] phi display_chip_line::w#10 = display_chip_line::w#1 [phi:display_print_chip::@1->display_chip_line#1] -- register_copy - // [3135] phi display_chip_line::y#16 = ++3+2 [phi:display_print_chip::@1->display_chip_line#2] -- vbum1=vbuc1 - lda #3+2+1 - sta display_chip_line.y - // [3135] phi display_chip_line::x#16 = display_chip_line::x#1 [phi:display_print_chip::@1->display_chip_line#3] -- register_copy - jsr display_chip_line - // display_print_chip::@2 - // display_chip_line(x, y++, w, *text++); - // [2317] display_print_chip::text#1 = ++ display_print_chip::text#0 -- pbuz1=_inc_pbuz2 + // vera_verify::@5 + __b5: + // vera_bram_ptr += VERA_PROGRESS_CELL + // [1598] vera_verify::vera_bram_ptr#1 = vera_verify::vera_bram_ptr#10 + VERA_PROGRESS_CELL -- pbuz1=pbuz1_plus_vbuc1 + lda #VERA_PROGRESS_CELL clc - lda.z text - adc #1 - sta.z text_1 - lda.z text+1 - adc #0 - sta.z text_1+1 - // display_chip_line(x, y++, w, *text++) - // [2318] display_chip_line::x#2 = display_print_chip::x#10 -- vbum1=vbum2 - lda x - sta display_chip_line.x - // [2319] display_chip_line::w#2 = display_print_chip::w#10 -- vbum1=vbum2 - lda w - sta display_chip_line.w - // [2320] display_chip_line::c#2 = *display_print_chip::text#1 -- vbum1=_deref_pbuz2 - ldy #0 - lda (text_1),y - sta display_chip_line.c - // [2321] call display_chip_line - // [3135] phi from display_print_chip::@2 to display_chip_line [phi:display_print_chip::@2->display_chip_line] - // [3135] phi display_chip_line::c#15 = display_chip_line::c#2 [phi:display_print_chip::@2->display_chip_line#0] -- register_copy - // [3135] phi display_chip_line::w#10 = display_chip_line::w#2 [phi:display_print_chip::@2->display_chip_line#1] -- register_copy - // [3135] phi display_chip_line::y#16 = ++++3+2 [phi:display_print_chip::@2->display_chip_line#2] -- vbum1=vbuc1 - lda #3+2+1+1 - sta display_chip_line.y - // [3135] phi display_chip_line::x#16 = display_chip_line::x#2 [phi:display_print_chip::@2->display_chip_line#3] -- register_copy - jsr display_chip_line - // display_print_chip::@3 - // display_chip_line(x, y++, w, *text++); - // [2322] display_print_chip::text#15 = ++ display_print_chip::text#1 -- pbuz1=_inc_pbuz2 + adc.z vera_bram_ptr + sta.z vera_bram_ptr + bcc !+ + inc.z vera_bram_ptr+1 + !: + // vera_address += VERA_PROGRESS_CELL + // [1599] vera_verify::vera_address#1 = vera_verify::vera_address#11 + VERA_PROGRESS_CELL -- vdum1=vdum1_plus_vbuc1 + lda vera_address clc - lda.z text_1 - adc #1 - sta.z text_3 - lda.z text_1+1 - adc #0 - sta.z text_3+1 - // display_chip_line(x, y++, w, *text++) - // [2323] display_chip_line::x#3 = display_print_chip::x#10 -- vbum1=vbum2 - lda x - sta display_chip_line.x - // [2324] display_chip_line::w#3 = display_print_chip::w#10 -- vbum1=vbum2 - lda w - sta display_chip_line.w - // [2325] display_chip_line::c#3 = *display_print_chip::text#15 -- vbum1=_deref_pbuz2 - ldy #0 - lda (text_3),y - sta display_chip_line.c - // [2326] call display_chip_line - // [3135] phi from display_print_chip::@3 to display_chip_line [phi:display_print_chip::@3->display_chip_line] - // [3135] phi display_chip_line::c#15 = display_chip_line::c#3 [phi:display_print_chip::@3->display_chip_line#0] -- register_copy - // [3135] phi display_chip_line::w#10 = display_chip_line::w#3 [phi:display_print_chip::@3->display_chip_line#1] -- register_copy - // [3135] phi display_chip_line::y#16 = ++++++3+2 [phi:display_print_chip::@3->display_chip_line#2] -- vbum1=vbuc1 - lda #3+2+1+1+1 - sta display_chip_line.y - // [3135] phi display_chip_line::x#16 = display_chip_line::x#3 [phi:display_print_chip::@3->display_chip_line#3] -- register_copy - jsr display_chip_line - // display_print_chip::@4 - // display_chip_line(x, y++, w, *text++); - // [2327] display_print_chip::text#16 = ++ display_print_chip::text#15 -- pbuz1=_inc_pbuz2 - clc - lda.z text_3 - adc #1 - sta.z text_4 - lda.z text_3+1 - adc #0 - sta.z text_4+1 - // display_chip_line(x, y++, w, *text++) - // [2328] display_chip_line::x#4 = display_print_chip::x#10 -- vbum1=vbum2 - lda x - sta display_chip_line.x - // [2329] display_chip_line::w#4 = display_print_chip::w#10 -- vbum1=vbum2 - lda w - sta display_chip_line.w - // [2330] display_chip_line::c#4 = *display_print_chip::text#16 -- vbum1=_deref_pbuz2 - ldy #0 - lda (text_4),y - sta display_chip_line.c - // [2331] call display_chip_line - // [3135] phi from display_print_chip::@4 to display_chip_line [phi:display_print_chip::@4->display_chip_line] - // [3135] phi display_chip_line::c#15 = display_chip_line::c#4 [phi:display_print_chip::@4->display_chip_line#0] -- register_copy - // [3135] phi display_chip_line::w#10 = display_chip_line::w#4 [phi:display_print_chip::@4->display_chip_line#1] -- register_copy - // [3135] phi display_chip_line::y#16 = ++++++++3+2 [phi:display_print_chip::@4->display_chip_line#2] -- vbum1=vbuc1 - lda #3+2+1+1+1+1 - sta display_chip_line.y - // [3135] phi display_chip_line::x#16 = display_chip_line::x#4 [phi:display_print_chip::@4->display_chip_line#3] -- register_copy - jsr display_chip_line - // display_print_chip::@5 - // display_chip_line(x, y++, w, *text++); - // [2332] display_print_chip::text#17 = ++ display_print_chip::text#16 -- pbuz1=_inc_pbuz2 - clc - lda.z text_4 - adc #1 - sta.z text_5 - lda.z text_4+1 - adc #0 - sta.z text_5+1 - // display_chip_line(x, y++, w, *text++) - // [2333] display_chip_line::x#5 = display_print_chip::x#10 -- vbum1=vbum2 - lda x - sta display_chip_line.x - // [2334] display_chip_line::w#5 = display_print_chip::w#10 -- vbum1=vbum2 - lda w - sta display_chip_line.w - // [2335] display_chip_line::c#5 = *display_print_chip::text#17 -- vbum1=_deref_pbuz2 - ldy #0 - lda (text_5),y - sta display_chip_line.c - // [2336] call display_chip_line - // [3135] phi from display_print_chip::@5 to display_chip_line [phi:display_print_chip::@5->display_chip_line] - // [3135] phi display_chip_line::c#15 = display_chip_line::c#5 [phi:display_print_chip::@5->display_chip_line#0] -- register_copy - // [3135] phi display_chip_line::w#10 = display_chip_line::w#5 [phi:display_print_chip::@5->display_chip_line#1] -- register_copy - // [3135] phi display_chip_line::y#16 = ++++++++++3+2 [phi:display_print_chip::@5->display_chip_line#2] -- vbum1=vbuc1 - lda #3+2+1+1+1+1+1 - sta display_chip_line.y - // [3135] phi display_chip_line::x#16 = display_chip_line::x#5 [phi:display_print_chip::@5->display_chip_line#3] -- register_copy - jsr display_chip_line - // display_print_chip::@6 - // display_chip_line(x, y++, w, *text++); - // [2337] display_print_chip::text#18 = ++ display_print_chip::text#17 -- pbuz1=_inc_pbuz2 - clc - lda.z text_5 - adc #1 - sta.z text_6 - lda.z text_5+1 - adc #0 - sta.z text_6+1 - // display_chip_line(x, y++, w, *text++) - // [2338] display_chip_line::x#6 = display_print_chip::x#10 -- vbum1=vbum2 - lda x - sta display_chip_line.x - // [2339] display_chip_line::w#6 = display_print_chip::w#10 -- vbum1=vbum2 - lda w - sta display_chip_line.w - // [2340] display_chip_line::c#6 = *display_print_chip::text#18 -- vbum1=_deref_pbuz2 - ldy #0 - lda (text_6),y - sta display_chip_line.c - // [2341] call display_chip_line - // [3135] phi from display_print_chip::@6 to display_chip_line [phi:display_print_chip::@6->display_chip_line] - // [3135] phi display_chip_line::c#15 = display_chip_line::c#6 [phi:display_print_chip::@6->display_chip_line#0] -- register_copy - // [3135] phi display_chip_line::w#10 = display_chip_line::w#6 [phi:display_print_chip::@6->display_chip_line#1] -- register_copy - // [3135] phi display_chip_line::y#16 = ++++++++++++3+2 [phi:display_print_chip::@6->display_chip_line#2] -- vbum1=vbuc1 - lda #3+2+1+1+1+1+1+1 - sta display_chip_line.y - // [3135] phi display_chip_line::x#16 = display_chip_line::x#6 [phi:display_print_chip::@6->display_chip_line#3] -- register_copy - jsr display_chip_line - // display_print_chip::@7 - // display_chip_line(x, y++, w, *text++); - // [2342] display_print_chip::text#19 = ++ display_print_chip::text#18 -- pbuz1=_inc_pbuz1 - inc.z text_6 + adc #VERA_PROGRESS_CELL + sta vera_address + bcc !+ + inc vera_address+1 bne !+ - inc.z text_6+1 - !: - // display_chip_line(x, y++, w, *text++) - // [2343] display_chip_line::x#7 = display_print_chip::x#10 -- vbum1=vbum2 - lda x - sta display_chip_line.x - // [2344] display_chip_line::w#7 = display_print_chip::w#10 -- vbum1=vbum2 - lda w - sta display_chip_line.w - // [2345] display_chip_line::c#7 = *display_print_chip::text#19 -- vbum1=_deref_pbuz2 - ldy #0 - lda (text_6),y - sta display_chip_line.c - // [2346] call display_chip_line - // [3135] phi from display_print_chip::@7 to display_chip_line [phi:display_print_chip::@7->display_chip_line] - // [3135] phi display_chip_line::c#15 = display_chip_line::c#7 [phi:display_print_chip::@7->display_chip_line#0] -- register_copy - // [3135] phi display_chip_line::w#10 = display_chip_line::w#7 [phi:display_print_chip::@7->display_chip_line#1] -- register_copy - // [3135] phi display_chip_line::y#16 = ++++++++++++++3+2 [phi:display_print_chip::@7->display_chip_line#2] -- vbum1=vbuc1 - lda #3+2+1+1+1+1+1+1+1 - sta display_chip_line.y - // [3135] phi display_chip_line::x#16 = display_chip_line::x#7 [phi:display_print_chip::@7->display_chip_line#3] -- register_copy - jsr display_chip_line - // display_print_chip::@8 - // display_chip_end(x, y++, w) - // [2347] display_chip_end::x#0 = display_print_chip::x#10 - // [2348] display_chip_end::w#0 = display_print_chip::w#10 -- vbum1=vbum2 - lda w - sta display_chip_end.w - // [2349] call display_chip_end - jsr display_chip_end - // display_print_chip::@return - // } - // [2350] return - rts - .segment Data - x: .byte 0 - w: .byte 0 -} -.segment Code - // display_vera_led -/** - * @brief Print VERA led above the VERA chip. - * - * @param c Led color - */ -// void display_vera_led(__mem() char c) -display_vera_led: { - // display_chip_led(CHIP_VERA_X+1, CHIP_VERA_Y, CHIP_VERA_W, c, BLUE) - // [2352] display_chip_led::tc#1 = display_vera_led::c#2 -- vbum1=vbum2 - lda c - sta display_chip_led.tc - // [2353] call display_chip_led - // [3117] phi from display_vera_led to display_chip_led [phi:display_vera_led->display_chip_led] - // [3117] phi display_chip_led::w#7 = 8 [phi:display_vera_led->display_chip_led#0] -- vbum1=vbuc1 - lda #8 - sta display_chip_led.w - // [3117] phi display_chip_led::x#7 = 9+1 [phi:display_vera_led->display_chip_led#1] -- vbum1=vbuc1 - lda #9+1 - sta display_chip_led.x - // [3117] phi display_chip_led::tc#3 = display_chip_led::tc#1 [phi:display_vera_led->display_chip_led#2] -- register_copy - jsr display_chip_led - // display_vera_led::@1 - // display_info_led(INFO_X-2, INFO_Y+1, c, BLUE) - // [2354] display_info_led::tc#1 = display_vera_led::c#2 -- vbum1=vbum2 - lda c - sta display_info_led.tc - // [2355] call display_info_led - // [2380] phi from display_vera_led::@1 to display_info_led [phi:display_vera_led::@1->display_info_led] - // [2380] phi display_info_led::y#4 = $11+1 [phi:display_vera_led::@1->display_info_led#0] -- vbum1=vbuc1 - lda #$11+1 - sta display_info_led.y - // [2380] phi display_info_led::x#4 = 4-2 [phi:display_vera_led::@1->display_info_led#1] -- vbum1=vbuc1 - lda #4-2 - sta display_info_led.x - // [2380] phi display_info_led::tc#4 = display_info_led::tc#1 [phi:display_vera_led::@1->display_info_led#2] -- register_copy - jsr display_info_led - // display_vera_led::@return - // } - // [2356] return - rts - .segment Data - c: .byte 0 -} -.segment Code - // strcat -// Concatenates the C string pointed by source into the array pointed by destination, including the terminating null character (and stopping at that point). -// char * strcat(char *destination, __zp($38) char *source) -strcat: { - .label strcat__0 = $79 - .label dst = $79 - .label src = $38 - .label source = $38 - // strlen(destination) - // [2358] call strlen - // [2611] phi from strcat to strlen [phi:strcat->strlen] - // [2611] phi strlen::str#8 = display_chip_rom::rom [phi:strcat->strlen#0] -- pbuz1=pbuc1 - lda #display_chip_rom.rom - sta.z strlen.str+1 - jsr strlen - // strlen(destination) - // [2359] strlen::return#0 = strlen::len#2 - // strcat::@4 - // [2360] strcat::$0 = strlen::return#0 -- vwuz1=vwum2 - lda strlen.return - sta.z strcat__0 - lda strlen.return+1 - sta.z strcat__0+1 - // char* dst = destination + strlen(destination) - // [2361] strcat::dst#0 = display_chip_rom::rom + strcat::$0 -- pbuz1=pbuc1_plus_vwuz1 - lda.z dst - clc - adc #display_chip_rom.rom - sta.z dst+1 - // [2362] phi from strcat::@2 strcat::@4 to strcat::@1 [phi:strcat::@2/strcat::@4->strcat::@1] - // [2362] phi strcat::dst#2 = strcat::dst#1 [phi:strcat::@2/strcat::@4->strcat::@1#0] -- register_copy - // [2362] phi strcat::src#2 = strcat::src#1 [phi:strcat::@2/strcat::@4->strcat::@1#1] -- register_copy - // strcat::@1 - __b1: - // while(*src) - // [2363] if(0!=*strcat::src#2) goto strcat::@2 -- 0_neq__deref_pbuz1_then_la1 - ldy #0 - lda (src),y - cmp #0 - bne __b2 - // strcat::@3 - // *dst = 0 - // [2364] *strcat::dst#2 = 0 -- _deref_pbuz1=vbuc1 - tya - tay - sta (dst),y - // strcat::@return - // } - // [2365] return - rts - // strcat::@2 - __b2: - // *dst++ = *src++ - // [2366] *strcat::dst#2 = *strcat::src#2 -- _deref_pbuz1=_deref_pbuz2 - ldy #0 - lda (src),y - sta (dst),y - // *dst++ = *src++; - // [2367] strcat::dst#1 = ++ strcat::dst#2 -- pbuz1=_inc_pbuz1 - inc.z dst + inc vera_address+2 bne !+ - inc.z dst+1 + inc vera_address+3 !: - // [2368] strcat::src#1 = ++ strcat::src#2 -- pbuz1=_inc_pbuz1 - inc.z src - bne !+ - inc.z src+1 + // progress_row_current += VERA_PROGRESS_CELL + // [1600] vera_verify::progress_row_current#11 = vera_verify::progress_row_current#4 + VERA_PROGRESS_CELL -- vwum1=vwum1_plus_vbuc1 + lda #VERA_PROGRESS_CELL + clc + adc progress_row_current + sta progress_row_current + bcc !+ + inc progress_row_current+1 !: - jmp __b1 -} - // display_rom_led -/** - * @brief Print ROM led above the ROM chip. - * - * @param chip ROM chip number (0 is main rom chip of CX16) - * @param c Led color - */ -// void display_rom_led(__mem() char chip, __mem() char c) -display_rom_led: { - .label display_rom_led__0 = $60 - .label display_rom_led__7 = $60 - .label display_rom_led__8 = $60 - // chip*6 - // [2370] display_rom_led::$7 = display_rom_led::chip#2 << 1 -- vbuz1=vbum2_rol_1 - lda chip - asl - sta.z display_rom_led__7 - // [2371] display_rom_led::$8 = display_rom_led::$7 + display_rom_led::chip#2 -- vbuz1=vbuz1_plus_vbum2 - lda chip + // if (vera_bram_ptr == BRAM_HIGH) + // [1601] if(vera_verify::vera_bram_ptr#1!=$c000) goto vera_verify::@6 -- pbuz1_neq_vwuc1_then_la1 + lda.z vera_bram_ptr+1 + cmp #>$c000 + bne __b6 + lda.z vera_bram_ptr + cmp #<$c000 + bne __b6 + // vera_verify::@10 + // vera_bram_bank++; + // [1602] vera_verify::vera_bram_bank#1 = ++ vera_verify::vera_bram_bank#11 -- vbum1=_inc_vbum1 + inc vera_bram_bank + // [1603] phi from vera_verify::@10 to vera_verify::@6 [phi:vera_verify::@10->vera_verify::@6] + // [1603] phi vera_verify::vera_bram_bank#25 = vera_verify::vera_bram_bank#1 [phi:vera_verify::@10->vera_verify::@6#0] -- register_copy + // [1603] phi vera_verify::vera_bram_ptr#6 = (char *)$a000 [phi:vera_verify::@10->vera_verify::@6#1] -- pbuz1=pbuc1 + lda #<$a000 + sta.z vera_bram_ptr + lda #>$a000 + sta.z vera_bram_ptr+1 + // [1603] phi from vera_verify::@5 to vera_verify::@6 [phi:vera_verify::@5->vera_verify::@6] + // [1603] phi vera_verify::vera_bram_bank#25 = vera_verify::vera_bram_bank#11 [phi:vera_verify::@5->vera_verify::@6#0] -- register_copy + // [1603] phi vera_verify::vera_bram_ptr#6 = vera_verify::vera_bram_ptr#1 [phi:vera_verify::@5->vera_verify::@6#1] -- register_copy + // vera_verify::@6 + __b6: + // if (vera_bram_ptr == RAM_HIGH) + // [1604] if(vera_verify::vera_bram_ptr#6!=$9800) goto vera_verify::@24 -- pbuz1_neq_vwuc1_then_la1 + lda.z vera_bram_ptr+1 + cmp #>$9800 + bne __b7 + lda.z vera_bram_ptr + cmp #<$9800 + bne __b7 + // [1606] phi from vera_verify::@6 to vera_verify::@7 [phi:vera_verify::@6->vera_verify::@7] + // [1606] phi vera_verify::vera_bram_ptr#11 = (char *)$a000 [phi:vera_verify::@6->vera_verify::@7#0] -- pbuz1=pbuc1 + lda #<$a000 + sta.z vera_bram_ptr + lda #>$a000 + sta.z vera_bram_ptr+1 + // [1606] phi vera_verify::vera_bram_bank#10 = 1 [phi:vera_verify::@6->vera_verify::@7#1] -- vbum1=vbuc1 + lda #1 + sta vera_bram_bank + // [1605] phi from vera_verify::@6 to vera_verify::@24 [phi:vera_verify::@6->vera_verify::@24] + // vera_verify::@24 + // [1606] phi from vera_verify::@24 to vera_verify::@7 [phi:vera_verify::@24->vera_verify::@7] + // [1606] phi vera_verify::vera_bram_ptr#11 = vera_verify::vera_bram_ptr#6 [phi:vera_verify::@24->vera_verify::@7#0] -- register_copy + // [1606] phi vera_verify::vera_bram_bank#10 = vera_verify::vera_bram_bank#25 [phi:vera_verify::@24->vera_verify::@7#1] -- register_copy + // vera_verify::@7 + __b7: + // VERA_PROGRESS_CELL - equal_bytes + // [1607] vera_verify::$16 = VERA_PROGRESS_CELL - vera_verify::equal_bytes#0 -- vwuz1=vwuc1_minus_vwum2 + sec + lda #VERA_PROGRESS_CELL + sbc equal_bytes+1 + sta.z vera_verify__16+1 + // vera_different_bytes += (VERA_PROGRESS_CELL - equal_bytes) + // [1608] vera_verify::vera_different_bytes#1 = vera_verify::vera_different_bytes#11 + vera_verify::$16 -- vdum1=vdum1_plus_vwuz2 + lda vera_different_bytes clc - adc.z display_rom_led__8 - sta.z display_rom_led__8 - // CHIP_ROM_X+chip*6 - // [2372] display_rom_led::$0 = display_rom_led::$8 << 1 -- vbuz1=vbuz1_rol_1 - asl.z display_rom_led__0 - // display_chip_led(CHIP_ROM_X+chip*6+1, CHIP_ROM_Y, CHIP_ROM_W, c, BLUE) - // [2373] display_chip_led::x#3 = display_rom_led::$0 + $14+1 -- vbum1=vbuz2_plus_vbuc1 - lda #$14+1 - clc - adc.z display_rom_led__0 - sta display_chip_led.x - // [2374] display_chip_led::tc#2 = display_rom_led::c#2 -- vbum1=vbum2 - lda c - sta display_chip_led.tc - // [2375] call display_chip_led - // [3117] phi from display_rom_led to display_chip_led [phi:display_rom_led->display_chip_led] - // [3117] phi display_chip_led::w#7 = 3 [phi:display_rom_led->display_chip_led#0] -- vbum1=vbuc1 - lda #3 - sta display_chip_led.w - // [3117] phi display_chip_led::x#7 = display_chip_led::x#3 [phi:display_rom_led->display_chip_led#1] -- register_copy - // [3117] phi display_chip_led::tc#3 = display_chip_led::tc#2 [phi:display_rom_led->display_chip_led#2] -- register_copy - jsr display_chip_led - // display_rom_led::@1 - // display_info_led(INFO_X-2, INFO_Y+chip+2, c, BLUE) - // [2376] display_info_led::y#2 = display_rom_led::chip#2 + $11+2 -- vbum1=vbum2_plus_vbuc1 - lda #$11+2 - clc - adc chip - sta display_info_led.y - // [2377] display_info_led::tc#2 = display_rom_led::c#2 -- vbum1=vbum2 - lda c - sta display_info_led.tc - // [2378] call display_info_led - // [2380] phi from display_rom_led::@1 to display_info_led [phi:display_rom_led::@1->display_info_led] - // [2380] phi display_info_led::y#4 = display_info_led::y#2 [phi:display_rom_led::@1->display_info_led#0] -- register_copy - // [2380] phi display_info_led::x#4 = 4-2 [phi:display_rom_led::@1->display_info_led#1] -- vbum1=vbuc1 - lda #4-2 - sta display_info_led.x - // [2380] phi display_info_led::tc#4 = display_info_led::tc#2 [phi:display_rom_led::@1->display_info_led#2] -- register_copy - jsr display_info_led - // display_rom_led::@return - // } - // [2379] return - rts - .segment Data - chip: .byte 0 - c: .byte 0 + adc.z vera_verify__16 + sta vera_different_bytes + lda vera_different_bytes+1 + adc.z vera_verify__16+1 + sta vera_different_bytes+1 + lda vera_different_bytes+2 + adc #0 + sta vera_different_bytes+2 + lda vera_different_bytes+3 + adc #0 + sta vera_different_bytes+3 + // sprintf(info_text, "Comparing: %05x differences between RAM:%02x:%04p <-> ROM:%05x", vera_different_bytes, vera_bram_bank, vera_bram_ptr, vera_address) + // [1609] call snprintf_init + jsr snprintf_init + // [1610] phi from vera_verify::@7 to vera_verify::@15 [phi:vera_verify::@7->vera_verify::@15] + // vera_verify::@15 + // sprintf(info_text, "Comparing: %05x differences between RAM:%02x:%04p <-> ROM:%05x", vera_different_bytes, vera_bram_bank, vera_bram_ptr, vera_address) + // [1611] call printf_str + // [785] phi from vera_verify::@15 to printf_str [phi:vera_verify::@15->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:vera_verify::@15->printf_str#0] -- pprz1=pprc1 + lda #snputc + sta.z printf_str.putc+1 + // [785] phi printf_str::s#53 = vera_verify::s [phi:vera_verify::@15->printf_str#1] -- pbuz1=pbuc1 + lda #s + sta.z printf_str.s+1 + jsr printf_str + // vera_verify::@16 + // sprintf(info_text, "Comparing: %05x differences between RAM:%02x:%04p <-> ROM:%05x", vera_different_bytes, vera_bram_bank, vera_bram_ptr, vera_address) + // [1612] printf_ulong::uvalue#0 = vera_verify::vera_different_bytes#1 -- vdum1=vdum2 + lda vera_different_bytes + sta printf_ulong.uvalue + lda vera_different_bytes+1 + sta printf_ulong.uvalue+1 + lda vera_different_bytes+2 + sta printf_ulong.uvalue+2 + lda vera_different_bytes+3 + sta printf_ulong.uvalue+3 + // [1613] call printf_ulong + // [1633] phi from vera_verify::@16 to printf_ulong [phi:vera_verify::@16->printf_ulong] + // [1633] phi printf_ulong::format_zero_padding#10 = 1 [phi:vera_verify::@16->printf_ulong#0] -- vbum1=vbuc1 + lda #1 + sta printf_ulong.format_zero_padding + // [1633] phi printf_ulong::format_min_length#10 = 5 [phi:vera_verify::@16->printf_ulong#1] -- vbum1=vbuc1 + lda #5 + sta printf_ulong.format_min_length + // [1633] phi printf_ulong::format_radix#10 = HEXADECIMAL [phi:vera_verify::@16->printf_ulong#2] -- vbum1=vbuc1 + lda #HEXADECIMAL + sta printf_ulong.format_radix + // [1633] phi printf_ulong::uvalue#10 = printf_ulong::uvalue#0 [phi:vera_verify::@16->printf_ulong#3] -- register_copy + jsr printf_ulong + // [1614] phi from vera_verify::@16 to vera_verify::@17 [phi:vera_verify::@16->vera_verify::@17] + // vera_verify::@17 + // sprintf(info_text, "Comparing: %05x differences between RAM:%02x:%04p <-> ROM:%05x", vera_different_bytes, vera_bram_bank, vera_bram_ptr, vera_address) + // [1615] call printf_str + // [785] phi from vera_verify::@17 to printf_str [phi:vera_verify::@17->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:vera_verify::@17->printf_str#0] -- pprz1=pprc1 + lda #snputc + sta.z printf_str.putc+1 + // [785] phi printf_str::s#53 = vera_verify::s1 [phi:vera_verify::@17->printf_str#1] -- pbuz1=pbuc1 + lda #s1 + sta.z printf_str.s+1 + jsr printf_str + // vera_verify::@18 + // sprintf(info_text, "Comparing: %05x differences between RAM:%02x:%04p <-> ROM:%05x", vera_different_bytes, vera_bram_bank, vera_bram_ptr, vera_address) + // [1616] printf_uchar::uvalue#0 = vera_verify::vera_bram_bank#10 -- vbum1=vbum2 + lda vera_bram_bank + sta printf_uchar.uvalue + // [1617] call printf_uchar + // [834] phi from vera_verify::@18 to printf_uchar [phi:vera_verify::@18->printf_uchar] + // [834] phi printf_uchar::format_zero_padding#10 = 1 [phi:vera_verify::@18->printf_uchar#0] -- vbum1=vbuc1 + lda #1 + sta printf_uchar.format_zero_padding + // [834] phi printf_uchar::format_min_length#10 = 2 [phi:vera_verify::@18->printf_uchar#1] -- vbum1=vbuc1 + lda #2 + sta printf_uchar.format_min_length + // [834] phi printf_uchar::putc#10 = &snputc [phi:vera_verify::@18->printf_uchar#2] -- pprz1=pprc1 + lda #snputc + sta.z printf_uchar.putc+1 + // [834] phi printf_uchar::format_radix#10 = HEXADECIMAL [phi:vera_verify::@18->printf_uchar#3] -- vbum1=vbuc1 + lda #HEXADECIMAL + sta printf_uchar.format_radix + // [834] phi printf_uchar::uvalue#10 = printf_uchar::uvalue#0 [phi:vera_verify::@18->printf_uchar#4] -- register_copy + jsr printf_uchar + // [1618] phi from vera_verify::@18 to vera_verify::@19 [phi:vera_verify::@18->vera_verify::@19] + // vera_verify::@19 + // sprintf(info_text, "Comparing: %05x differences between RAM:%02x:%04p <-> ROM:%05x", vera_different_bytes, vera_bram_bank, vera_bram_ptr, vera_address) + // [1619] call printf_str + // [785] phi from vera_verify::@19 to printf_str [phi:vera_verify::@19->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:vera_verify::@19->printf_str#0] -- pprz1=pprc1 + lda #snputc + sta.z printf_str.putc+1 + // [785] phi printf_str::s#53 = s2 [phi:vera_verify::@19->printf_str#1] -- pbuz1=pbuc1 + lda #s2 + sta.z printf_str.s+1 + jsr printf_str + // vera_verify::@20 + // sprintf(info_text, "Comparing: %05x differences between RAM:%02x:%04p <-> ROM:%05x", vera_different_bytes, vera_bram_bank, vera_bram_ptr, vera_address) + // [1620] printf_uint::uvalue#0 = (unsigned int)vera_verify::vera_bram_ptr#11 -- vwum1=vwuz2 + lda.z vera_bram_ptr + sta printf_uint.uvalue + lda.z vera_bram_ptr+1 + sta printf_uint.uvalue+1 + // [1621] call printf_uint + // [1433] phi from vera_verify::@20 to printf_uint [phi:vera_verify::@20->printf_uint] + // [1433] phi printf_uint::format_zero_padding#4 = 1 [phi:vera_verify::@20->printf_uint#0] -- vbum1=vbuc1 + lda #1 + sta printf_uint.format_zero_padding + // [1433] phi printf_uint::format_min_length#4 = 4 [phi:vera_verify::@20->printf_uint#1] -- vbum1=vbuc1 + lda #4 + sta printf_uint.format_min_length + // [1433] phi printf_uint::putc#4 = &snputc [phi:vera_verify::@20->printf_uint#2] -- pprz1=pprc1 + lda #snputc + sta.z printf_uint.putc+1 + // [1433] phi printf_uint::format_radix#4 = HEXADECIMAL [phi:vera_verify::@20->printf_uint#3] -- vbum1=vbuc1 + lda #HEXADECIMAL + sta printf_uint.format_radix + // [1433] phi printf_uint::uvalue#4 = printf_uint::uvalue#0 [phi:vera_verify::@20->printf_uint#4] -- register_copy + jsr printf_uint + // [1622] phi from vera_verify::@20 to vera_verify::@21 [phi:vera_verify::@20->vera_verify::@21] + // vera_verify::@21 + // sprintf(info_text, "Comparing: %05x differences between RAM:%02x:%04p <-> ROM:%05x", vera_different_bytes, vera_bram_bank, vera_bram_ptr, vera_address) + // [1623] call printf_str + // [785] phi from vera_verify::@21 to printf_str [phi:vera_verify::@21->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:vera_verify::@21->printf_str#0] -- pprz1=pprc1 + lda #snputc + sta.z printf_str.putc+1 + // [785] phi printf_str::s#53 = vera_verify::s3 [phi:vera_verify::@21->printf_str#1] -- pbuz1=pbuc1 + lda #s3 + sta.z printf_str.s+1 + jsr printf_str + // vera_verify::@22 + // sprintf(info_text, "Comparing: %05x differences between RAM:%02x:%04p <-> ROM:%05x", vera_different_bytes, vera_bram_bank, vera_bram_ptr, vera_address) + // [1624] printf_ulong::uvalue#1 = vera_verify::vera_address#1 -- vdum1=vdum2 + lda vera_address + sta printf_ulong.uvalue + lda vera_address+1 + sta printf_ulong.uvalue+1 + lda vera_address+2 + sta printf_ulong.uvalue+2 + lda vera_address+3 + sta printf_ulong.uvalue+3 + // [1625] call printf_ulong + // [1633] phi from vera_verify::@22 to printf_ulong [phi:vera_verify::@22->printf_ulong] + // [1633] phi printf_ulong::format_zero_padding#10 = 1 [phi:vera_verify::@22->printf_ulong#0] -- vbum1=vbuc1 + lda #1 + sta printf_ulong.format_zero_padding + // [1633] phi printf_ulong::format_min_length#10 = 5 [phi:vera_verify::@22->printf_ulong#1] -- vbum1=vbuc1 + lda #5 + sta printf_ulong.format_min_length + // [1633] phi printf_ulong::format_radix#10 = HEXADECIMAL [phi:vera_verify::@22->printf_ulong#2] -- vbum1=vbuc1 + lda #HEXADECIMAL + sta printf_ulong.format_radix + // [1633] phi printf_ulong::uvalue#10 = printf_ulong::uvalue#1 [phi:vera_verify::@22->printf_ulong#3] -- register_copy + jsr printf_ulong + // vera_verify::@23 + // sprintf(info_text, "Comparing: %05x differences between RAM:%02x:%04p <-> ROM:%05x", vera_different_bytes, vera_bram_bank, vera_bram_ptr, vera_address) + // [1626] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 + lda #0 + pha + // [1627] callexecute snputc -- call_vprc1 + jsr snputc + // sideeffect stackpullpadding(1) -- _stackpullpadding_1 + pla + // display_action_text(info_text) + // [1629] call display_action_text + // [845] phi from vera_verify::@23 to display_action_text [phi:vera_verify::@23->display_action_text] + // [845] phi display_action_text::info_text#17 = info_text [phi:vera_verify::@23->display_action_text#0] -- pbuz1=pbuc1 + lda #<@info_text + sta.z display_action_text.info_text + lda #>@info_text + sta.z display_action_text.info_text+1 + jsr display_action_text + // [1581] phi from vera_verify::@23 to vera_verify::@1 [phi:vera_verify::@23->vera_verify::@1] + // [1581] phi vera_verify::y#3 = vera_verify::y#10 [phi:vera_verify::@23->vera_verify::@1#0] -- register_copy + // [1581] phi vera_verify::progress_row_current#3 = vera_verify::progress_row_current#11 [phi:vera_verify::@23->vera_verify::@1#1] -- register_copy + // [1581] phi vera_verify::vera_different_bytes#11 = vera_verify::vera_different_bytes#1 [phi:vera_verify::@23->vera_verify::@1#2] -- register_copy + // [1581] phi vera_verify::vera_bram_ptr#10 = vera_verify::vera_bram_ptr#11 [phi:vera_verify::@23->vera_verify::@1#3] -- register_copy + // [1581] phi vera_verify::vera_bram_bank#11 = vera_verify::vera_bram_bank#10 [phi:vera_verify::@23->vera_verify::@1#4] -- register_copy + // [1581] phi vera_verify::vera_address#11 = vera_verify::vera_address#1 [phi:vera_verify::@23->vera_verify::@1#5] -- register_copy + jmp __b1 + // vera_verify::@4 + __b4: + // cputc('*') + // [1630] stackpush(char) = '*' -- _stackpushbyte_=vbuc1 + lda #'*' + pha + // [1631] callexecute cputc -- call_vprc1 + jsr cputc + // sideeffect stackpullpadding(1) -- _stackpullpadding_1 + pla + jmp __b5 + .segment DataVera + info_text: .text "Comparing VERA ..." + .byte 0 + s: .text "Comparing: " + .byte 0 + s1: .text " differences between RAM:" + .byte 0 + s3: .text " <-> ROM:" + .byte 0 + vera_boundary: .dword 0 + .label equal_bytes = vera_compare.equal_bytes + y: .byte 0 + vera_address: .dword 0 + vera_bram_bank: .byte 0 + vera_different_bytes: .dword 0 + .label return = vera_different_bytes + progress_row_current: .word 0 } .segment Code - // display_info_led -/** - * @brief Print the colored led of an info line in the info frame. - * - * @param x Start X - * @param y Start Y - * @param tc Fore color - * @param bc Back color - */ -// void display_info_led(__mem() char x, __mem() char y, __mem() char tc, char bc) -display_info_led: { - // textcolor(tc) - // [2381] textcolor::color#13 = display_info_led::tc#4 -- vbum1=vbum2 - lda tc - sta textcolor.color - // [2382] call textcolor - // [784] phi from display_info_led to textcolor [phi:display_info_led->textcolor] - // [784] phi textcolor::color#23 = textcolor::color#13 [phi:display_info_led->textcolor#0] -- register_copy - jsr textcolor - // [2383] phi from display_info_led to display_info_led::@1 [phi:display_info_led->display_info_led::@1] - // display_info_led::@1 - // bgcolor(bc) - // [2384] call bgcolor - // [789] phi from display_info_led::@1 to bgcolor [phi:display_info_led::@1->bgcolor] - // [789] phi bgcolor::color#15 = BLUE [phi:display_info_led::@1->bgcolor#0] -- vbum1=vbuc1 - lda #BLUE - sta bgcolor.color - jsr bgcolor - // display_info_led::@2 - // cputcxy(x, y, VERA_CHR_UR) - // [2385] cputcxy::x#13 = display_info_led::x#4 - // [2386] cputcxy::y#13 = display_info_led::y#4 - // [2387] call cputcxy - // [2293] phi from display_info_led::@2 to cputcxy [phi:display_info_led::@2->cputcxy] - // [2293] phi cputcxy::c#17 = $7c [phi:display_info_led::@2->cputcxy#0] -- vbum1=vbuc1 - lda #$7c - sta cputcxy.c - // [2293] phi cputcxy::y#17 = cputcxy::y#13 [phi:display_info_led::@2->cputcxy#1] -- register_copy - // [2293] phi cputcxy::x#17 = cputcxy::x#13 [phi:display_info_led::@2->cputcxy#2] -- register_copy - jsr cputcxy - // [2388] phi from display_info_led::@2 to display_info_led::@3 [phi:display_info_led::@2->display_info_led::@3] - // display_info_led::@3 - // textcolor(WHITE) - // [2389] call textcolor - // [784] phi from display_info_led::@3 to textcolor [phi:display_info_led::@3->textcolor] - // [784] phi textcolor::color#23 = WHITE [phi:display_info_led::@3->textcolor#0] -- vbum1=vbuc1 - lda #WHITE - sta textcolor.color - jsr textcolor - // display_info_led::@return + // printf_ulong +// Print an unsigned int using a specific format +// void printf_ulong(void (*putc)(char), __mem() unsigned long uvalue, __mem() char format_min_length, char format_justify_left, char format_sign_always, __mem() char format_zero_padding, char format_upper_case, __mem() char format_radix) +printf_ulong: { + // printf_ulong::@1 + // printf_buffer.sign = format.sign_always?'+':0 + // [1634] *((char *)&printf_buffer) = 0 -- _deref_pbuc1=vbuc2 + // Handle any sign + lda #0 + sta printf_buffer + // ultoa(uvalue, printf_buffer.digits, format.radix) + // [1635] ultoa::value#1 = printf_ulong::uvalue#10 + // [1636] ultoa::radix#0 = printf_ulong::format_radix#10 + // [1637] call ultoa + // Format number into buffer + jsr ultoa + // printf_ulong::@2 + // printf_number_buffer(putc, printf_buffer, format) + // [1638] printf_number_buffer::buffer_sign#0 = *((char *)&printf_buffer) -- vbum1=_deref_pbuc1 + lda printf_buffer + sta printf_number_buffer.buffer_sign + // [1639] printf_number_buffer::format_min_length#0 = printf_ulong::format_min_length#10 + // [1640] printf_number_buffer::format_zero_padding#0 = printf_ulong::format_zero_padding#10 + // [1641] call printf_number_buffer + // Print using format + // [1539] phi from printf_ulong::@2 to printf_number_buffer [phi:printf_ulong::@2->printf_number_buffer] + // [1539] phi printf_number_buffer::putc#10 = &snputc [phi:printf_ulong::@2->printf_number_buffer#0] -- pprz1=pprc1 + lda #snputc + sta.z printf_number_buffer.putc+1 + // [1539] phi printf_number_buffer::buffer_sign#10 = printf_number_buffer::buffer_sign#0 [phi:printf_ulong::@2->printf_number_buffer#1] -- register_copy + // [1539] phi printf_number_buffer::format_zero_padding#10 = printf_number_buffer::format_zero_padding#0 [phi:printf_ulong::@2->printf_number_buffer#2] -- register_copy + // [1539] phi printf_number_buffer::format_min_length#3 = printf_number_buffer::format_min_length#0 [phi:printf_ulong::@2->printf_number_buffer#3] -- register_copy + jsr printf_number_buffer + // printf_ulong::@return // } - // [2390] return + // [1642] return rts .segment Data - .label tc = display_smc_led.c - .label y = cputcxy.y - .label x = cputcxy.x + uvalue: .dword 0 + format_radix: .byte 0 + .label format_min_length = printf_uchar.format_min_length + .label format_zero_padding = printf_uchar.format_zero_padding } .segment CodeVera - // vera_detect -vera_detect: { - // spi_get_jedec() - // [2392] call spi_get_jedec - // This conditional compilation ensures that only the detection interpretation happens if it is switched on. - // [3196] phi from vera_detect to spi_get_jedec [phi:vera_detect->spi_get_jedec] - jsr spi_get_jedec - // vera_detect::@return + // vera_erase +vera_erase: { + .label vera_erase__0 = $7f + // BYTE2(vera_file_size) + // [1643] vera_erase::$0 = byte2 vera_file_size#1 -- vbuz1=_byte2_vdum2 + lda vera_file_size+2 + sta.z vera_erase__0 + // unsigned char vera_total_64k_blocks = BYTE2(vera_file_size)+1 + // [1644] vera_erase::vera_total_64k_blocks#0 = vera_erase::$0 + 1 -- vbum1=vbuz2_plus_1 + inc + sta vera_total_64k_blocks + // [1645] phi from vera_erase to vera_erase::@1 [phi:vera_erase->vera_erase::@1] + // [1645] phi vera_erase::vera_current_64k_block#2 = 0 [phi:vera_erase->vera_erase::@1#0] -- vbum1=vbuc1 + lda #0 + sta vera_current_64k_block + // vera_erase::@1 + __b1: + // while(vera_current_64k_block < vera_total_64k_blocks) + // [1646] if(vera_erase::vera_current_64k_block#2vera_erase::@1] + // [1645] phi vera_erase::vera_current_64k_block#2 = vera_erase::vera_current_64k_block#1 [phi:vera_erase::@2->vera_erase::@1#0] -- register_copy + jmp __b1 + .segment DataVera + vera_total_64k_blocks: .byte 0 + vera_current_64k_block: .byte 0 } -.segment Code - // rom_unlock -/** - * @brief Unlock a byte location for flashing using the 22 bit address. - * This is a various purpose routine to unlock the ROM for flashing a byte. - * The 3rd byte can be variable, depending on the write sequence used, so this byte is a parameter into the routine. - * - * @param address The 3rd write to model the specific unlock sequence. - * @param unlock_code The 3rd write to model the specific unlock sequence. - */ -/* inline */ -// void rom_unlock(__mem() unsigned long address, __mem() char unlock_code) -rom_unlock: { - // unsigned long chip_address = address & ROM_CHIP_MASK - // [2395] rom_unlock::chip_address#0 = rom_unlock::address#5 & $380000 -- vdum1=vdum2_band_vduc1 - lda address - and #<$380000 - sta chip_address - lda address+1 - and #>$380000 - sta chip_address+1 - lda address+2 - and #<$380000>>$10 - sta chip_address+2 - lda address+3 - and #>$380000>>$10 - sta chip_address+3 - // rom_write_byte(chip_address + 0x05555, 0xAA) - // [2396] rom_write_byte::address#0 = rom_unlock::chip_address#0 + $5555 -- vdum1=vdum2_plus_vwuc1 - clc - lda chip_address - adc #<$5555 - sta rom_write_byte.address - lda chip_address+1 - adc #>$5555 - sta rom_write_byte.address+1 - lda chip_address+2 - adc #0 - sta rom_write_byte.address+2 - lda chip_address+3 - adc #0 - sta rom_write_byte.address+3 - // [2397] call rom_write_byte - // This is a very important operation... - // [3212] phi from rom_unlock to rom_write_byte [phi:rom_unlock->rom_write_byte] - // [3212] phi rom_write_byte::value#10 = $aa [phi:rom_unlock->rom_write_byte#0] -- vbum1=vbuc1 - lda #$aa - sta rom_write_byte.value - // [3212] phi rom_write_byte::address#4 = rom_write_byte::address#0 [phi:rom_unlock->rom_write_byte#1] -- register_copy - jsr rom_write_byte - // rom_unlock::@1 - // rom_write_byte(chip_address + 0x02AAA, 0x55) - // [2398] rom_write_byte::address#1 = rom_unlock::chip_address#0 + $2aaa -- vdum1=vdum2_plus_vwuc1 +.segment CodeVera + // vera_flash +vera_flash: { + .label vera_flash__18 = $68 + .label vera_bram_ptr = $61 + // display_action_progress("Flashing ... (-) equal, (+) flashed, (!) error.") + // [1650] call display_action_progress + // Now we compare the RAM with the actual ROM contents. + // [559] phi from vera_flash to display_action_progress [phi:vera_flash->display_action_progress] + // [559] phi display_action_progress::info_text#19 = vera_flash::info_text [phi:vera_flash->display_action_progress#0] -- pbuz1=pbuc1 + lda #info_text + sta.z display_action_progress.info_text+1 + jsr display_action_progress + // vera_flash::@14 + // [1651] spi_manufacturer#422 = spi_read::return#0 -- vbum1=vbum2 + lda spi_read.return + sta spi_manufacturer + // [1652] spi_memory_type#423 = spi_read::return#1 -- vbum1=vbum2 + lda spi_read.return_1 + sta spi_memory_type + // [1653] spi_memory_capacity#424 = spi_read::return#2 -- vbum1=vbum2 + lda spi_read.return_2 + sta spi_memory_capacity + // display_info_vera(STATUS_FLASHING, "Flashing ...") + // [1654] call display_info_vera + // [653] phi from vera_flash::@14 to display_info_vera [phi:vera_flash::@14->display_info_vera] + // [653] phi display_info_vera::info_text#19 = vera_flash::info_text1 [phi:vera_flash::@14->display_info_vera#0] -- pbuz1=pbuc1 + lda #info_text1 + sta.z display_info_vera.info_text+1 + // [653] phi spi_memory_capacity#110 = spi_memory_capacity#424 [phi:vera_flash::@14->display_info_vera#1] -- register_copy + // [653] phi spi_memory_type#111 = spi_memory_type#423 [phi:vera_flash::@14->display_info_vera#2] -- register_copy + // [653] phi spi_manufacturer#100 = spi_manufacturer#422 [phi:vera_flash::@14->display_info_vera#3] -- register_copy + // [653] phi display_info_vera::info_status#19 = STATUS_FLASHING [phi:vera_flash::@14->display_info_vera#4] -- vbum1=vbuc1 + lda #STATUS_FLASHING + sta display_info_vera.info_status + jsr display_info_vera + // [1655] phi from vera_flash::@14 to vera_flash::@1 [phi:vera_flash::@14->vera_flash::@1] + // [1655] phi vera_flash::vera_bram_ptr#10 = (char *)$a000 [phi:vera_flash::@14->vera_flash::@1#0] -- pbuz1=pbuc1 + lda #<$a000 + sta.z vera_bram_ptr + lda #>$a000 + sta.z vera_bram_ptr+1 + // [1655] phi vera_flash::vera_bram_bank#11 = 1 [phi:vera_flash::@14->vera_flash::@1#1] -- vbum1=vbuc1 + lda #1 + sta vera_bram_bank + // [1655] phi vera_flash::y_sector#14 = PROGRESS_Y [phi:vera_flash::@14->vera_flash::@1#2] -- vbum1=vbuc1 + lda #PROGRESS_Y + sta y_sector + // [1655] phi vera_flash::x_sector#14 = PROGRESS_X [phi:vera_flash::@14->vera_flash::@1#3] -- vbum1=vbuc1 + lda #PROGRESS_X + sta x_sector + // [1655] phi vera_flash::return#2 = 0 [phi:vera_flash::@14->vera_flash::@1#4] -- vdum1=vduc1 + lda #<0 + sta return + sta return+1 + lda #<0>>$10 + sta return+2 + lda #>0>>$10 + sta return+3 + // [1655] phi from vera_flash::@11 to vera_flash::@1 [phi:vera_flash::@11->vera_flash::@1] + // [1655] phi vera_flash::vera_bram_ptr#10 = vera_flash::vera_bram_ptr#18 [phi:vera_flash::@11->vera_flash::@1#0] -- register_copy + // [1655] phi vera_flash::vera_bram_bank#11 = vera_flash::vera_bram_bank#14 [phi:vera_flash::@11->vera_flash::@1#1] -- register_copy + // [1655] phi vera_flash::y_sector#14 = vera_flash::y_sector#14 [phi:vera_flash::@11->vera_flash::@1#2] -- register_copy + // [1655] phi vera_flash::x_sector#14 = vera_flash::x_sector#1 [phi:vera_flash::@11->vera_flash::@1#3] -- register_copy + // [1655] phi vera_flash::return#2 = vera_flash::vera_address_page#12 [phi:vera_flash::@11->vera_flash::@1#4] -- register_copy + // vera_flash::@1 + __b1: + // while (vera_address_page < vera_file_size) + // [1656] if(vera_flash::return#2display_action_text_flashed] + jsr display_action_text_flashed + // [1659] phi from vera_flash::@3 to vera_flash::@16 [phi:vera_flash::@3->vera_flash::@16] + // vera_flash::@16 + // wait_moment(32) + // [1660] call wait_moment + // [794] phi from vera_flash::@16 to wait_moment [phi:vera_flash::@16->wait_moment] + // [794] phi wait_moment::w#10 = $20 [phi:vera_flash::@16->wait_moment#0] -- vbum1=vbuc1 + lda #$20 + sta wait_moment.w + jsr wait_moment + // vera_flash::@return + // } + // [1661] return + rts + // vera_flash::@2 + __b2: + // unsigned long vera_page_boundary = vera_address_page + VERA_PROGRESS_PAGE + // [1662] vera_flash::vera_page_boundary#0 = vera_flash::return#2 + VERA_PROGRESS_PAGE -- vdum1=vdum2_plus_vwuc1 + // {asm{.byte $db}} clc - lda chip_address - adc #<$2aaa - sta rom_write_byte.address - lda chip_address+1 - adc #>$2aaa - sta rom_write_byte.address+1 - lda chip_address+2 + lda return + adc #VERA_PROGRESS_PAGE + sta vera_page_boundary+1 + lda return+2 adc #0 - sta rom_write_byte.address+2 - lda chip_address+3 + sta vera_page_boundary+2 + lda return+3 adc #0 - sta rom_write_byte.address+3 - // [2399] call rom_write_byte - // [3212] phi from rom_unlock::@1 to rom_write_byte [phi:rom_unlock::@1->rom_write_byte] - // [3212] phi rom_write_byte::value#10 = $55 [phi:rom_unlock::@1->rom_write_byte#0] -- vbum1=vbuc1 - lda #$55 - sta rom_write_byte.value - // [3212] phi rom_write_byte::address#4 = rom_write_byte::address#1 [phi:rom_unlock::@1->rom_write_byte#1] -- register_copy - jsr rom_write_byte - // rom_unlock::@2 - // rom_write_byte(address, unlock_code) - // [2400] rom_write_byte::address#2 = rom_unlock::address#5 -- vdum1=vdum2 - lda address - sta rom_write_byte.address - lda address+1 - sta rom_write_byte.address+1 - lda address+2 - sta rom_write_byte.address+2 - lda address+3 - sta rom_write_byte.address+3 - // [2401] rom_write_byte::value#2 = rom_unlock::unlock_code#5 -- vbum1=vbum2 - lda unlock_code - sta rom_write_byte.value - // [2402] call rom_write_byte - // [3212] phi from rom_unlock::@2 to rom_write_byte [phi:rom_unlock::@2->rom_write_byte] - // [3212] phi rom_write_byte::value#10 = rom_write_byte::value#2 [phi:rom_unlock::@2->rom_write_byte#0] -- register_copy - // [3212] phi rom_write_byte::address#4 = rom_write_byte::address#2 [phi:rom_unlock::@2->rom_write_byte#1] -- register_copy - jsr rom_write_byte - // rom_unlock::@return - // } - // [2403] return - rts - .segment Data - chip_address: .dword 0 - address: .dword 0 - unlock_code: .byte 0 -} -.segment Code - // rom_read_byte -/** - * @brief Read a byte from the ROM using the 22 bit address. - * The lower 14 bits of the 22 bit ROM address are transformed into the **ptr_rom** 16 bit ROM address. - * The higher 8 bits of the 22 bit ROM address are transformed into the **bank_rom** 8 bit bank number. - * **bank_ptr* is used to set the bank using ZP $01. **ptr_rom** is used to read the byte. - * - * @param address The 22 bit ROM address. - * @return unsigned char The byte read from the ROM. - */ -// __mem() char rom_read_byte(__mem() unsigned long address) -rom_read_byte: { - .label rom_bank1_rom_read_byte__0 = $3a - .label rom_bank1_rom_read_byte__1 = $42 - .label rom_bank1_rom_read_byte__2 = $b6 - .label rom_ptr1_rom_read_byte__0 = $31 - .label rom_ptr1_rom_read_byte__2 = $31 - .label rom_ptr1_return = $31 - // rom_read_byte::rom_bank1 - // BYTE2(address) - // [2405] rom_read_byte::rom_bank1_$0 = byte2 rom_read_byte::address#2 -- vbuz1=_byte2_vdum2 - lda address+2 - sta.z rom_bank1_rom_read_byte__0 - // BYTE1(address) - // [2406] rom_read_byte::rom_bank1_$1 = byte1 rom_read_byte::address#2 -- vbuz1=_byte1_vdum2 - lda address+1 - sta.z rom_bank1_rom_read_byte__1 - // MAKEWORD(BYTE2(address),BYTE1(address)) - // [2407] rom_read_byte::rom_bank1_$2 = rom_read_byte::rom_bank1_$0 w= rom_read_byte::rom_bank1_$1 -- vwuz1=vbuz2_word_vbuz3 - lda.z rom_bank1_rom_read_byte__0 - sta.z rom_bank1_rom_read_byte__2+1 - lda.z rom_bank1_rom_read_byte__1 - sta.z rom_bank1_rom_read_byte__2 - // unsigned int bank_unshifted = MAKEWORD(BYTE2(address),BYTE1(address)) << 2 - // [2408] rom_read_byte::rom_bank1_bank_unshifted#0 = rom_read_byte::rom_bank1_$2 << 2 -- vwum1=vwuz2_rol_2 - asl - sta rom_bank1_bank_unshifted - lda.z rom_bank1_rom_read_byte__2+1 - rol - sta rom_bank1_bank_unshifted+1 - asl rom_bank1_bank_unshifted - rol rom_bank1_bank_unshifted+1 - // unsigned char bank = BYTE1(bank_unshifted) - // [2409] rom_read_byte::rom_bank1_return#0 = byte1 rom_read_byte::rom_bank1_bank_unshifted#0 -- vbum1=_byte1_vwum2 - lda rom_bank1_bank_unshifted+1 - sta rom_bank1_return - // rom_read_byte::rom_ptr1 - // (unsigned int)(address) & ROM_PTR_MASK - // [2410] rom_read_byte::rom_ptr1_$2 = (unsigned int)rom_read_byte::address#2 -- vwuz1=_word_vdum2 - lda address - sta.z rom_ptr1_rom_read_byte__2 - lda address+1 - sta.z rom_ptr1_rom_read_byte__2+1 - // [2411] rom_read_byte::rom_ptr1_$0 = rom_read_byte::rom_ptr1_$2 & $3fff -- vwuz1=vwuz1_band_vwuc1 - lda.z rom_ptr1_rom_read_byte__0 - and #<$3fff - sta.z rom_ptr1_rom_read_byte__0 - lda.z rom_ptr1_rom_read_byte__0+1 - and #>$3fff - sta.z rom_ptr1_rom_read_byte__0+1 - // ((unsigned int)(address) & ROM_PTR_MASK) + ROM_BASE - // [2412] rom_read_byte::rom_ptr1_return#0 = rom_read_byte::rom_ptr1_$0 + $c000 -- vwuz1=vwuz1_plus_vwuc1 - lda.z rom_ptr1_return + sta vera_page_boundary+3 + // cputcxy(x,y,'.') + // [1663] cputcxy::x#0 = vera_flash::x_sector#14 -- vbum1=vbum2 + lda x_sector + sta cputcxy.x + // [1664] cputcxy::y#0 = vera_flash::y_sector#14 -- vbum1=vbum2 + lda y_sector + sta cputcxy.y + // [1665] call cputcxy + // [1346] phi from vera_flash::@2 to cputcxy [phi:vera_flash::@2->cputcxy] + // [1346] phi cputcxy::c#15 = '.' [phi:vera_flash::@2->cputcxy#0] -- vbum1=vbuc1 + lda #'.' + sta cputcxy.c + // [1346] phi cputcxy::y#15 = cputcxy::y#0 [phi:vera_flash::@2->cputcxy#1] -- register_copy + // [1346] phi cputcxy::x#15 = cputcxy::x#0 [phi:vera_flash::@2->cputcxy#2] -- register_copy + jsr cputcxy + // vera_flash::@15 + // cputc('.') + // [1666] stackpush(char) = '.' -- _stackpushbyte_=vbuc1 + lda #'.' + pha + // [1667] callexecute cputc -- call_vprc1 + jsr cputc + // sideeffect stackpullpadding(1) -- _stackpullpadding_1 + pla + // vera_flash::bank_set_bram1 + // BRAM = bank + // [1669] BRAM = vera_flash::vera_bram_bank#11 -- vbuz1=vbum2 + lda vera_bram_bank + sta.z BRAM + // [1670] vera_flash::vera_address#13 = vera_flash::return#2 -- vdum1=vdum2 + lda return + sta vera_address + lda return+1 + sta vera_address+1 + lda return+2 + sta vera_address+2 + lda return+3 + sta vera_address+3 + // [1671] phi from vera_flash::@17 vera_flash::bank_set_bram1 to vera_flash::@5 [phi:vera_flash::@17/vera_flash::bank_set_bram1->vera_flash::@5] + // [1671] phi vera_flash::vera_address_page#12 = vera_flash::vera_address_page#1 [phi:vera_flash::@17/vera_flash::bank_set_bram1->vera_flash::@5#0] -- register_copy + // [1671] phi vera_flash::vera_bram_ptr#13 = vera_flash::vera_bram_ptr#1 [phi:vera_flash::@17/vera_flash::bank_set_bram1->vera_flash::@5#1] -- register_copy + // [1671] phi vera_flash::vera_address#10 = vera_flash::vera_address#1 [phi:vera_flash::@17/vera_flash::bank_set_bram1->vera_flash::@5#2] -- register_copy + // vera_flash::@5 + __b5: + // while (vera_address < vera_page_boundary) + // [1672] if(vera_flash::vera_address#10$c000 + bne __b10 + lda.z vera_bram_ptr + cmp #<$c000 + bne __b10 + // vera_flash::@12 + // vera_bram_bank++; + // [1674] vera_flash::vera_bram_bank#1 = ++ vera_flash::vera_bram_bank#11 -- vbum1=_inc_vbum1 + inc vera_bram_bank + // [1675] phi from vera_flash::@12 to vera_flash::@10 [phi:vera_flash::@12->vera_flash::@10] + // [1675] phi vera_flash::vera_bram_bank#21 = vera_flash::vera_bram_bank#1 [phi:vera_flash::@12->vera_flash::@10#0] -- register_copy + // [1675] phi vera_flash::vera_bram_ptr#7 = (char *)$a000 [phi:vera_flash::@12->vera_flash::@10#1] -- pbuz1=pbuc1 + lda #<$a000 + sta.z vera_bram_ptr + lda #>$a000 + sta.z vera_bram_ptr+1 + // [1675] phi from vera_flash::@4 to vera_flash::@10 [phi:vera_flash::@4->vera_flash::@10] + // [1675] phi vera_flash::vera_bram_bank#21 = vera_flash::vera_bram_bank#11 [phi:vera_flash::@4->vera_flash::@10#0] -- register_copy + // [1675] phi vera_flash::vera_bram_ptr#7 = vera_flash::vera_bram_ptr#13 [phi:vera_flash::@4->vera_flash::@10#1] -- register_copy + // vera_flash::@10 + __b10: + // if (vera_bram_ptr == RAM_HIGH) + // [1676] if(vera_flash::vera_bram_ptr#7!=$9800) goto vera_flash::@18 -- pbuz1_neq_vwuc1_then_la1 + lda.z vera_bram_ptr+1 + cmp #>$9800 + bne __b11 + lda.z vera_bram_ptr + cmp #<$9800 + bne __b11 + // [1678] phi from vera_flash::@10 to vera_flash::@11 [phi:vera_flash::@10->vera_flash::@11] + // [1678] phi vera_flash::vera_bram_ptr#18 = (char *)$a000 [phi:vera_flash::@10->vera_flash::@11#0] -- pbuz1=pbuc1 + lda #<$a000 + sta.z vera_bram_ptr + lda #>$a000 + sta.z vera_bram_ptr+1 + // [1678] phi vera_flash::vera_bram_bank#14 = 1 [phi:vera_flash::@10->vera_flash::@11#1] -- vbum1=vbuc1 + lda #1 + sta vera_bram_bank + // [1677] phi from vera_flash::@10 to vera_flash::@18 [phi:vera_flash::@10->vera_flash::@18] + // vera_flash::@18 + // [1678] phi from vera_flash::@18 to vera_flash::@11 [phi:vera_flash::@18->vera_flash::@11] + // [1678] phi vera_flash::vera_bram_ptr#18 = vera_flash::vera_bram_ptr#7 [phi:vera_flash::@18->vera_flash::@11#0] -- register_copy + // [1678] phi vera_flash::vera_bram_bank#14 = vera_flash::vera_bram_bank#21 [phi:vera_flash::@18->vera_flash::@11#1] -- register_copy + // vera_flash::@11 + __b11: + // x_sector += 2 + // [1679] vera_flash::x_sector#1 = vera_flash::x_sector#14 + 2 -- vbum1=vbum1_plus_2 + lda x_sector clc - adc #<$c000 - sta.z rom_ptr1_return - lda.z rom_ptr1_return+1 - adc #>$c000 - sta.z rom_ptr1_return+1 - // rom_read_byte::bank_set_brom1 - // BROM = bank - // [2413] BROM = rom_read_byte::rom_bank1_return#0 -- vbuz1=vbum2 - lda rom_bank1_return - sta.z BROM - // rom_read_byte::@1 - // return *ptr_rom; - // [2414] rom_read_byte::return#0 = *((char *)rom_read_byte::rom_ptr1_return#0) -- vbum1=_deref_pbuz2 - ldy #0 - lda (rom_ptr1_return),y - sta return - // rom_read_byte::@return - // } - // [2415] return - rts - .segment Data - rom_bank1_bank_unshifted: .word 0 - rom_bank1_return: .byte 0 - return: .byte 0 - address: .dword 0 -} -.segment Code - // fopen -/** - * @brief Load a file to banked ram located between address 0xA000 and 0xBFFF incrementing the banks. - * - * @param channel Input channel. - * @param device Input device. - * @param secondary Secondary channel. - * @param filename Name of the file to be loaded. - * @return - * - 0x0000: Something is wrong! Kernal Error Code (https://commodore.ca/manuals/pdfs/commodore_error_messages.pdf) - * - other: OK! The last pointer between 0xA000 and 0xBFFF is returned. Note that the last pointer is indicating the first free byte. - */ -// __zp($3d) struct $2 * fopen(__zp($5a) const char *path, const char *mode) -fopen: { - .label fopen__4 = $3a - .label fopen__9 = $42 - .label fopen__11 = $43 - .label fopen__15 = $61 - .label fopen__16 = $50 - .label fopen__26 = $45 - .label fopen__28 = $4e - .label fopen__30 = $3d - .label cbm_k_setnam1_filename = $c5 - .label cbm_k_setnam1_fopen__0 = $4a - .label stream = $3d - .label pathtoken = $5a - .label pathtoken_1 = $7b - .label path = $5a - .label return = $3d - // unsigned char sp = __stdio_filecount - // [2417] fopen::sp#0 = __stdio_filecount#27 -- vbum1=vbum2 - lda __stdio_filecount - sta sp - // (unsigned int)sp | 0x8000 - // [2418] fopen::$30 = (unsigned int)fopen::sp#0 -- vwuz1=_word_vbum2 - sta.z fopen__30 - lda #0 - sta.z fopen__30+1 - // [2419] fopen::stream#0 = fopen::$30 | $8000 -- vwuz1=vwuz1_bor_vwuc1 - lda.z stream - ora #<$8000 - sta.z stream - lda.z stream+1 - ora #>$8000 - sta.z stream+1 - // char pathpos = sp * __STDIO_FILECOUNT - // [2420] fopen::pathpos#0 = fopen::sp#0 << 1 -- vbum1=vbum2_rol_1 - lda sp - asl - sta pathpos - // __logical = 0 - // [2421] ((char *)&__stdio_file+$40)[fopen::sp#0] = 0 -- pbuc1_derefidx_vbum1=vbuc2 - lda #0 - ldy sp - sta __stdio_file+$40,y - // __device = 0 - // [2422] ((char *)&__stdio_file+$42)[fopen::sp#0] = 0 -- pbuc1_derefidx_vbum1=vbuc2 - sta __stdio_file+$42,y - // __channel = 0 - // [2423] ((char *)&__stdio_file+$44)[fopen::sp#0] = 0 -- pbuc1_derefidx_vbum1=vbuc2 - sta __stdio_file+$44,y - // [2424] fopen::pathtoken#22 = fopen::pathtoken#0 -- pbuz1=pbuz2 - lda.z pathtoken - sta.z pathtoken_1 - lda.z pathtoken+1 - sta.z pathtoken_1+1 - // [2425] fopen::pathpos#21 = fopen::pathpos#0 -- vbum1=vbum2 - lda pathpos - sta pathpos_1 - // [2426] phi from fopen to fopen::@8 [phi:fopen->fopen::@8] - // [2426] phi fopen::num#10 = 0 [phi:fopen->fopen::@8#0] -- vbum1=vbuc1 - lda #0 - sta num - // [2426] phi fopen::pathpos#10 = fopen::pathpos#21 [phi:fopen->fopen::@8#1] -- register_copy - // [2426] phi fopen::path#10 = fopen::pathtoken#0 [phi:fopen->fopen::@8#2] -- register_copy - // [2426] phi fopen::pathstep#10 = 0 [phi:fopen->fopen::@8#3] -- vbum1=vbuc1 - sta pathstep - // [2426] phi fopen::pathtoken#10 = fopen::pathtoken#22 [phi:fopen->fopen::@8#4] -- register_copy - // Iterate while path is not \0. - // [2426] phi from fopen::@22 to fopen::@8 [phi:fopen::@22->fopen::@8] - // [2426] phi fopen::num#10 = fopen::num#13 [phi:fopen::@22->fopen::@8#0] -- register_copy - // [2426] phi fopen::pathpos#10 = fopen::pathpos#7 [phi:fopen::@22->fopen::@8#1] -- register_copy - // [2426] phi fopen::path#10 = fopen::path#12 [phi:fopen::@22->fopen::@8#2] -- register_copy - // [2426] phi fopen::pathstep#10 = fopen::pathstep#11 [phi:fopen::@22->fopen::@8#3] -- register_copy - // [2426] phi fopen::pathtoken#10 = fopen::pathtoken#1 [phi:fopen::@22->fopen::@8#4] -- register_copy - // fopen::@8 + adc #2 + sta x_sector + // vera_address_page % VERA_PROGRESS_ROW + // [1680] vera_flash::$18 = vera_flash::vera_address_page#12 & VERA_PROGRESS_ROW-1 -- vduz1=vdum2_band_vduc1 + lda vera_address_page + and #VERA_PROGRESS_ROW-1 + sta.z vera_flash__18+1 + lda vera_address_page+2 + and #>$10 + sta.z vera_flash__18+2 + lda vera_address_page+3 + and #>VERA_PROGRESS_ROW-1>>$10 + sta.z vera_flash__18+3 + // if (!(vera_address_page % VERA_PROGRESS_ROW)) + // [1681] if(0!=vera_flash::$18) goto vera_flash::@1 -- 0_neq_vduz1_then_la1 + lda.z vera_flash__18 + ora.z vera_flash__18+1 + ora.z vera_flash__18+2 + ora.z vera_flash__18+3 + beq !__b1+ + jmp __b1 + !__b1: + // vera_flash::@13 + // y_sector++; + // [1682] vera_flash::y_sector#1 = ++ vera_flash::y_sector#14 -- vbum1=_inc_vbum1 + inc y_sector + // [1655] phi from vera_flash::@13 to vera_flash::@1 [phi:vera_flash::@13->vera_flash::@1] + // [1655] phi vera_flash::vera_bram_ptr#10 = vera_flash::vera_bram_ptr#18 [phi:vera_flash::@13->vera_flash::@1#0] -- register_copy + // [1655] phi vera_flash::vera_bram_bank#11 = vera_flash::vera_bram_bank#14 [phi:vera_flash::@13->vera_flash::@1#1] -- register_copy + // [1655] phi vera_flash::y_sector#14 = vera_flash::y_sector#1 [phi:vera_flash::@13->vera_flash::@1#2] -- register_copy + // [1655] phi vera_flash::x_sector#14 = PROGRESS_X [phi:vera_flash::@13->vera_flash::@1#3] -- vbum1=vbuc1 + lda #PROGRESS_X + sta x_sector + // [1655] phi vera_flash::return#2 = vera_flash::vera_address_page#12 [phi:vera_flash::@13->vera_flash::@1#4] -- register_copy + jmp __b1 + // vera_flash::@6 + __b6: + // display_action_text_flashing(VERA_PROGRESS_PAGE, "VERA", vera_bram_bank, vera_bram_ptr, vera_address) + // [1683] display_action_text_flashing::bram_bank#0 = vera_flash::vera_bram_bank#11 -- vbum1=vbum2 + lda vera_bram_bank + sta display_action_text_flashing.bram_bank + // [1684] display_action_text_flashing::bram_ptr#0 = vera_flash::vera_bram_ptr#13 -- pbuz1=pbuz2 + lda.z vera_bram_ptr + sta.z display_action_text_flashing.bram_ptr + lda.z vera_bram_ptr+1 + sta.z display_action_text_flashing.bram_ptr+1 + // [1685] display_action_text_flashing::address#0 = vera_flash::vera_address#10 -- vdum1=vdum2 + lda vera_address + sta display_action_text_flashing.address + lda vera_address+1 + sta display_action_text_flashing.address+1 + lda vera_address+2 + sta display_action_text_flashing.address+2 + lda vera_address+3 + sta display_action_text_flashing.address+3 + // [1686] call display_action_text_flashing + // [2188] phi from vera_flash::@6 to display_action_text_flashing [phi:vera_flash::@6->display_action_text_flashing] + jsr display_action_text_flashing + // [1687] phi from vera_flash::@6 to vera_flash::@7 [phi:vera_flash::@6->vera_flash::@7] + // [1687] phi vera_flash::i#2 = 0 [phi:vera_flash::@6->vera_flash::@7#0] -- vwum1=vwuc1 + lda #<0 + sta i + sta i+1 + // vera_flash::@7 + __b7: + // for(unsigned int i=0; i<=255; i++) + // [1688] if(vera_flash::i#2<=$ff) goto vera_flash::@8 -- vwum1_le_vbuc1_then_la1 + lda #$ff + cmp i + bcc !+ + lda i+1 + beq __b8 + !: + // vera_flash::@9 + // cputcxy(x,y,'+') + // [1689] cputcxy::x#1 = vera_flash::x_sector#14 -- vbum1=vbum2 + lda x_sector + sta cputcxy.x + // [1690] cputcxy::y#1 = vera_flash::y_sector#14 -- vbum1=vbum2 + lda y_sector + sta cputcxy.y + // [1691] call cputcxy + // [1346] phi from vera_flash::@9 to cputcxy [phi:vera_flash::@9->cputcxy] + // [1346] phi cputcxy::c#15 = '+' [phi:vera_flash::@9->cputcxy#0] -- vbum1=vbuc1 + lda #'+' + sta cputcxy.c + // [1346] phi cputcxy::y#15 = cputcxy::y#1 [phi:vera_flash::@9->cputcxy#1] -- register_copy + // [1346] phi cputcxy::x#15 = cputcxy::x#1 [phi:vera_flash::@9->cputcxy#2] -- register_copy + jsr cputcxy + // vera_flash::@17 + // cputc('+') + // [1692] stackpush(char) = '+' -- _stackpushbyte_=vbuc1 + lda #'+' + pha + // [1693] callexecute cputc -- call_vprc1 + jsr cputc + // sideeffect stackpullpadding(1) -- _stackpullpadding_1 + pla + // vera_bram_ptr += VERA_PROGRESS_PAGE + // [1695] vera_flash::vera_bram_ptr#1 = vera_flash::vera_bram_ptr#13 + VERA_PROGRESS_PAGE -- pbuz1=pbuz1_plus_vwuc1 + lda.z vera_bram_ptr + clc + adc #VERA_PROGRESS_PAGE + sta.z vera_bram_ptr+1 + // vera_address += VERA_PROGRESS_PAGE + // [1696] vera_flash::vera_address#1 = vera_flash::vera_address#10 + VERA_PROGRESS_PAGE -- vdum1=vdum1_plus_vwuc1 + clc + lda vera_address + adc #VERA_PROGRESS_PAGE + sta vera_address+1 + lda vera_address+2 + adc #0 + sta vera_address+2 + lda vera_address+3 + adc #0 + sta vera_address+3 + // vera_address_page += VERA_PROGRESS_PAGE + // [1697] vera_flash::vera_address_page#1 = vera_flash::vera_address_page#12 + VERA_PROGRESS_PAGE -- vdum1=vdum1_plus_vwuc1 + clc + lda vera_address_page + adc #VERA_PROGRESS_PAGE + sta vera_address_page+1 + lda vera_address_page+2 + adc #0 + sta vera_address_page+2 + lda vera_address_page+3 + adc #0 + sta vera_address_page+3 + jmp __b5 + // vera_flash::@8 __b8: - // if (*pathtoken == ',' || *pathtoken == '\0') - // [2427] if(*fopen::pathtoken#10==',') goto fopen::@9 -- _deref_pbuz1_eq_vbuc1_then_la1 - lda #',' - ldy #0 - cmp (pathtoken_1),y - bne !__b9+ - jmp __b9 - !__b9: - // fopen::@33 - // [2428] if(*fopen::pathtoken#10=='@') goto fopen::@9 -- _deref_pbuz1_eq_vbuc1_then_la1 - lda #'@' - cmp (pathtoken_1),y - bne !__b9+ - jmp __b9 - !__b9: - // fopen::@23 - // if (pathstep == 0) - // [2429] if(fopen::pathstep#10!=0) goto fopen::@10 -- vbum1_neq_0_then_la1 - lda pathstep - bne __b10 - // fopen::@24 - // __stdio_file.filename[pathpos] = *pathtoken - // [2430] ((char *)&__stdio_file)[fopen::pathpos#10] = *fopen::pathtoken#10 -- pbuc1_derefidx_vbum1=_deref_pbuz2 - lda (pathtoken_1),y - ldy pathpos_1 - sta __stdio_file,y - // pathpos++; - // [2431] fopen::pathpos#1 = ++ fopen::pathpos#10 -- vbum1=_inc_vbum1 - inc pathpos_1 - // [2432] phi from fopen::@12 fopen::@23 fopen::@24 to fopen::@10 [phi:fopen::@12/fopen::@23/fopen::@24->fopen::@10] - // [2432] phi fopen::num#13 = fopen::num#15 [phi:fopen::@12/fopen::@23/fopen::@24->fopen::@10#0] -- register_copy - // [2432] phi fopen::pathpos#7 = fopen::pathpos#10 [phi:fopen::@12/fopen::@23/fopen::@24->fopen::@10#1] -- register_copy - // [2432] phi fopen::path#12 = fopen::path#14 [phi:fopen::@12/fopen::@23/fopen::@24->fopen::@10#2] -- register_copy - // [2432] phi fopen::pathstep#11 = fopen::pathstep#1 [phi:fopen::@12/fopen::@23/fopen::@24->fopen::@10#3] -- register_copy - // fopen::@10 - __b10: - // pathtoken++; - // [2433] fopen::pathtoken#1 = ++ fopen::pathtoken#10 -- pbuz1=_inc_pbuz1 - inc.z pathtoken_1 + // for(unsigned int i=0; i<=255; i++) + // [1698] vera_flash::i#1 = ++ vera_flash::i#2 -- vwum1=_inc_vwum1 + inc i bne !+ - inc.z pathtoken_1+1 + inc i+1 !: - // fopen::@22 - // pathtoken - 1 - // [2434] fopen::$28 = fopen::pathtoken#1 - 1 -- pbuz1=pbuz2_minus_1 - lda.z pathtoken_1 - sec - sbc #1 - sta.z fopen__28 - lda.z pathtoken_1+1 - sbc #0 - sta.z fopen__28+1 - // while (*(pathtoken - 1)) - // [2435] if(0!=*fopen::$28) goto fopen::@8 -- 0_neq__deref_pbuz1_then_la1 - ldy #0 - lda (fopen__28),y - cmp #0 - bne __b8 - // fopen::@26 - // __status = 0 - // [2436] ((char *)&__stdio_file+$46)[fopen::sp#0] = 0 -- pbuc1_derefidx_vbum1=vbuc2 - tya - ldy sp - sta __stdio_file+$46,y - // if(!__logical) - // [2437] if(0!=((char *)&__stdio_file+$40)[fopen::sp#0]) goto fopen::@1 -- 0_neq_pbuc1_derefidx_vbum1_then_la1 - lda __stdio_file+$40,y - cmp #0 - bne __b1 - // fopen::@27 - // __stdio_filecount+1 - // [2438] fopen::$4 = __stdio_filecount#27 + 1 -- vbuz1=vbum2_plus_1 - lda __stdio_filecount - inc - sta.z fopen__4 - // __logical = __stdio_filecount+1 - // [2439] ((char *)&__stdio_file+$40)[fopen::sp#0] = fopen::$4 -- pbuc1_derefidx_vbum1=vbuz2 - sta __stdio_file+$40,y - // fopen::@1 + // [1687] phi from vera_flash::@8 to vera_flash::@7 [phi:vera_flash::@8->vera_flash::@7] + // [1687] phi vera_flash::i#2 = vera_flash::i#1 [phi:vera_flash::@8->vera_flash::@7#0] -- register_copy + jmp __b7 + .segment DataVera + info_text: .text "Flashing ... (-) equal, (+) flashed, (!) error." + .byte 0 + info_text1: .text "Flashing ..." + .byte 0 + chip: .text "VERA" + .byte 0 + vera_page_boundary: .dword 0 + // TODO: ERROR!!! + return: .dword 0 + i: .word 0 + vera_address: .dword 0 + .label vera_address_page = return + vera_bram_bank: .byte 0 + x_sector: .byte 0 + y_sector: .byte 0 +} +.segment Code + // display_info_roms +/** + * @brief Display all the ROM statuses. + * + * @param info_status The status. + * @param info_text The status text. + */ +// void display_info_roms(char info_status, char *info_text) +display_info_roms: { + .label info_text = 0 + // [1700] phi from display_info_roms to display_info_roms::@1 [phi:display_info_roms->display_info_roms::@1] + // [1700] phi display_info_roms::rom_chip#2 = 0 [phi:display_info_roms->display_info_roms::@1#0] -- vbum1=vbuc1 + lda #0 + sta rom_chip + // display_info_roms::@1 __b1: - // if(!__device) - // [2440] if(0!=((char *)&__stdio_file+$42)[fopen::sp#0]) goto fopen::@2 -- 0_neq_pbuc1_derefidx_vbum1_then_la1 - ldy sp - lda __stdio_file+$42,y - cmp #0 - bne __b2 - // fopen::@5 - // __device = 8 - // [2441] ((char *)&__stdio_file+$42)[fopen::sp#0] = 8 -- pbuc1_derefidx_vbum1=vbuc2 - lda #8 - sta __stdio_file+$42,y - // fopen::@2 + // for(unsigned char rom_chip=0; rom_chip<8; rom_chip++) + // [1701] if(display_info_roms::rom_chip#2<8) goto display_info_roms::@2 -- vbum1_lt_vbuc1_then_la1 + lda rom_chip + cmp #8 + bcc __b2 + // display_info_roms::@return + // } + // [1702] return + rts + // display_info_roms::@2 __b2: - // if(!__channel) - // [2442] if(0!=((char *)&__stdio_file+$44)[fopen::sp#0]) goto fopen::@3 -- 0_neq_pbuc1_derefidx_vbum1_then_la1 - ldy sp - lda __stdio_file+$44,y - cmp #0 - bne __b3 - // fopen::@6 - // __stdio_filecount+2 - // [2443] fopen::$9 = __stdio_filecount#27 + 2 -- vbuz1=vbum2_plus_2 - lda __stdio_filecount - clc - adc #2 - sta.z fopen__9 - // __channel = __stdio_filecount+2 - // [2444] ((char *)&__stdio_file+$44)[fopen::sp#0] = fopen::$9 -- pbuc1_derefidx_vbum1=vbuz2 - sta __stdio_file+$44,y - // fopen::@3 - __b3: - // __filename - // [2445] fopen::$11 = (char *)&__stdio_file + fopen::pathpos#0 -- pbuz1=pbuc1_plus_vbum2 - lda pathpos - clc - adc #<__stdio_file - sta.z fopen__11 - lda #>__stdio_file - adc #0 - sta.z fopen__11+1 - // cbm_k_setnam(__filename) - // [2446] fopen::cbm_k_setnam1_filename = fopen::$11 -- pbuz1=pbuz2 - lda.z fopen__11 - sta.z cbm_k_setnam1_filename - lda.z fopen__11+1 - sta.z cbm_k_setnam1_filename+1 - // fopen::cbm_k_setnam1 - // strlen(filename) - // [2447] strlen::str#4 = fopen::cbm_k_setnam1_filename -- pbuz1=pbuz2 - lda.z cbm_k_setnam1_filename - sta.z strlen.str - lda.z cbm_k_setnam1_filename+1 - sta.z strlen.str+1 - // [2448] call strlen - // [2611] phi from fopen::cbm_k_setnam1 to strlen [phi:fopen::cbm_k_setnam1->strlen] - // [2611] phi strlen::str#8 = strlen::str#4 [phi:fopen::cbm_k_setnam1->strlen#0] -- register_copy - jsr strlen - // strlen(filename) - // [2449] strlen::return#11 = strlen::len#2 - // fopen::@31 - // [2450] fopen::cbm_k_setnam1_$0 = strlen::return#11 -- vwuz1=vwum2 - lda strlen.return - sta.z cbm_k_setnam1_fopen__0 - lda strlen.return+1 - sta.z cbm_k_setnam1_fopen__0+1 - // char filename_len = (char)strlen(filename) - // [2451] fopen::cbm_k_setnam1_filename_len = (char)fopen::cbm_k_setnam1_$0 -- vbum1=_byte_vwuz2 - lda.z cbm_k_setnam1_fopen__0 - sta cbm_k_setnam1_filename_len - // asm - // asm { ldafilename_len ldxfilename ldyfilename+1 jsrCBM_SETNAM } - ldx cbm_k_setnam1_filename - ldy cbm_k_setnam1_filename+1 - jsr CBM_SETNAM - // fopen::@28 - // cbm_k_setlfs(__logical, __device, __channel) - // [2453] cbm_k_setlfs::channel = ((char *)&__stdio_file+$40)[fopen::sp#0] -- vbum1=pbuc1_derefidx_vbum2 - ldy sp - lda __stdio_file+$40,y - sta cbm_k_setlfs.channel - // [2454] cbm_k_setlfs::device = ((char *)&__stdio_file+$42)[fopen::sp#0] -- vbum1=pbuc1_derefidx_vbum2 - lda __stdio_file+$42,y - sta cbm_k_setlfs.device - // [2455] cbm_k_setlfs::command = ((char *)&__stdio_file+$44)[fopen::sp#0] -- vbum1=pbuc1_derefidx_vbum2 - lda __stdio_file+$44,y - sta cbm_k_setlfs.command - // [2456] call cbm_k_setlfs - jsr cbm_k_setlfs - // fopen::cbm_k_open1 - // asm - // asm { jsrCBM_OPEN } - jsr CBM_OPEN - // fopen::cbm_k_readst1 - // char status - // [2458] fopen::cbm_k_readst1_status = 0 -- vbum1=vbuc1 - lda #0 - sta cbm_k_readst1_status - // asm - // asm { jsrCBM_READST stastatus } - jsr CBM_READST - sta cbm_k_readst1_status - // return status; - // [2460] fopen::cbm_k_readst1_return#0 = fopen::cbm_k_readst1_status -- vbum1=vbum2 - sta cbm_k_readst1_return - // fopen::cbm_k_readst1_@return + // display_info_rom(rom_chip, info_status, info_text) + // [1703] display_info_rom::rom_chip#1 = display_info_roms::rom_chip#2 -- vbum1=vbum2 + lda rom_chip + sta display_info_rom.rom_chip + // [1704] call display_info_rom + // [1067] phi from display_info_roms::@2 to display_info_rom [phi:display_info_roms::@2->display_info_rom] + // [1067] phi display_info_rom::info_text#10 = display_info_roms::info_text#1 [phi:display_info_roms::@2->display_info_rom#0] -- pbuz1=pbuc1 + lda #info_text + sta.z display_info_rom.info_text+1 + // [1067] phi display_info_rom::rom_chip#10 = display_info_rom::rom_chip#1 [phi:display_info_roms::@2->display_info_rom#1] -- register_copy + // [1067] phi display_info_rom::info_status#10 = STATUS_ERROR [phi:display_info_roms::@2->display_info_rom#2] -- vbum1=vbuc1 + lda #STATUS_ERROR + sta display_info_rom.info_status + jsr display_info_rom + // display_info_roms::@3 + // for(unsigned char rom_chip=0; rom_chip<8; rom_chip++) + // [1705] display_info_roms::rom_chip#1 = ++ display_info_roms::rom_chip#2 -- vbum1=_inc_vbum1 + inc rom_chip + // [1700] phi from display_info_roms::@3 to display_info_roms::@1 [phi:display_info_roms::@3->display_info_roms::@1] + // [1700] phi display_info_roms::rom_chip#2 = display_info_roms::rom_chip#1 [phi:display_info_roms::@3->display_info_roms::@1#0] -- register_copy + jmp __b1 + .segment Data + rom_chip: .byte 0 +} +.segment CodeVera + // spi_deselect +spi_deselect: { + // *vera_reg_SPICtrl &= 0xfe + // [1706] *vera_reg_SPICtrl = *vera_reg_SPICtrl & $fe -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 + /* +.proc spi_deselect + lda Vera::Reg::SPICtrl + and #$fe + sta Vera::Reg::SPICtrl + jsr spi_read + rts +.endproc +*/ + lda #$fe + and vera_reg_SPICtrl + sta vera_reg_SPICtrl + // unsigned char value = spi_read() + // [1707] call spi_read + jsr spi_read + // spi_deselect::@return // } - // [2461] fopen::cbm_k_readst1_return#1 = fopen::cbm_k_readst1_return#0 - // fopen::@29 - // cbm_k_readst() - // [2462] fopen::$15 = fopen::cbm_k_readst1_return#1 -- vbuz1=vbum2 - sta.z fopen__15 - // __status = cbm_k_readst() - // [2463] ((char *)&__stdio_file+$46)[fopen::sp#0] = fopen::$15 -- pbuc1_derefidx_vbum1=vbuz2 - ldy sp - sta __stdio_file+$46,y - // ferror(stream) - // [2464] ferror::stream#0 = (struct $2 *)fopen::stream#0 - // [2465] call ferror - jsr ferror - // [2466] ferror::return#0 = ferror::return#1 - // fopen::@32 - // [2467] fopen::$16 = ferror::return#0 -- vwsz1=vwsm2 - lda ferror.return - sta.z fopen__16 - lda ferror.return+1 - sta.z fopen__16+1 - // if (ferror(stream)) - // [2468] if(0==fopen::$16) goto fopen::@4 -- 0_eq_vwsz1_then_la1 - lda.z fopen__16 - ora.z fopen__16+1 - beq __b4 - // fopen::@7 - // cbm_k_close(__logical) - // [2469] fopen::cbm_k_close1_channel = ((char *)&__stdio_file+$40)[fopen::sp#0] -- vbum1=pbuc1_derefidx_vbum2 - ldy sp - lda __stdio_file+$40,y - sta cbm_k_close1_channel - // fopen::cbm_k_close1 + // [1708] return + rts +} +.segment Code + // cbm_k_getin +/** + * @brief Scan a character from keyboard without pressing enter. + * + * @return char The character read. + */ +cbm_k_getin: { + // __mem unsigned char ch + // [1709] cbm_k_getin::ch = 0 -- vbum1=vbuc1 + lda #0 + sta ch // asm - // asm { ldachannel jsrCBM_CLOSE } - jsr CBM_CLOSE - // [2471] phi from fopen::cbm_k_close1 to fopen::@return [phi:fopen::cbm_k_close1->fopen::@return] - // [2471] phi __stdio_filecount#1 = __stdio_filecount#27 [phi:fopen::cbm_k_close1->fopen::@return#0] -- register_copy - // [2471] phi fopen::return#2 = 0 [phi:fopen::cbm_k_close1->fopen::@return#1] -- pssz1=vbuc1 - lda #<0 - sta.z return - sta.z return+1 - // fopen::@return + // asm { jsrCBM_GETIN stach } + jsr CBM_GETIN + sta ch + // return ch; + // [1711] cbm_k_getin::return#0 = cbm_k_getin::ch -- vbum1=vbum2 + sta return + // cbm_k_getin::@return // } - // [2472] return + // [1712] cbm_k_getin::return#1 = cbm_k_getin::return#0 + // [1713] return rts - // fopen::@4 - __b4: - // __stdio_filecount++; - // [2473] __stdio_filecount#0 = ++ __stdio_filecount#27 -- vbum1=_inc_vbum1 - inc __stdio_filecount - // [2474] fopen::return#10 = (struct $2 *)fopen::stream#0 - // [2471] phi from fopen::@4 to fopen::@return [phi:fopen::@4->fopen::@return] - // [2471] phi __stdio_filecount#1 = __stdio_filecount#0 [phi:fopen::@4->fopen::@return#0] -- register_copy - // [2471] phi fopen::return#2 = fopen::return#10 [phi:fopen::@4->fopen::@return#1] -- register_copy + .segment Data + ch: .byte 0 + return: .byte 0 +} +.segment Code + // insertup +// Insert a new line, and scroll the upper part of the screen up. +// void insertup(char rows) +insertup: { + .label insertup__0 = $32 + .label insertup__4 = $29 + .label insertup__6 = $2a + .label insertup__7 = $29 + // __conio.width+1 + // [1714] insertup::$0 = *((char *)&__conio+6) + 1 -- vbuz1=_deref_pbuc1_plus_1 + lda __conio+6 + inc + sta.z insertup__0 + // unsigned char width = (__conio.width+1) * 2 + // [1715] insertup::width#0 = insertup::$0 << 1 -- vbum1=vbuz2_rol_1 + // {asm{.byte $db}} + asl + sta width + // [1716] phi from insertup to insertup::@1 [phi:insertup->insertup::@1] + // [1716] phi insertup::y#2 = 0 [phi:insertup->insertup::@1#0] -- vbum1=vbuc1 + lda #0 + sta y + // insertup::@1 + __b1: + // for(unsigned char y=0; y<__conio.cursor_y; y++) + // [1717] if(insertup::y#2<*((char *)&__conio+1)) goto insertup::@2 -- vbum1_lt__deref_pbuc1_then_la1 + lda y + cmp __conio+1 + bcc __b2 + // [1718] phi from insertup::@1 to insertup::@3 [phi:insertup::@1->insertup::@3] + // insertup::@3 + // clearline() + // [1719] call clearline + jsr clearline + // insertup::@return + // } + // [1720] return rts - // fopen::@9 - __b9: - // if (pathstep > 0) - // [2475] if(fopen::pathstep#10>0) goto fopen::@11 -- vbum1_gt_0_then_la1 - lda pathstep - bne __b11 - // fopen::@25 - // __stdio_file.filename[pathpos] = '\0' - // [2476] ((char *)&__stdio_file)[fopen::pathpos#10] = '@' -- pbuc1_derefidx_vbum1=vbuc2 - lda #'@' - ldy pathpos_1 - sta __stdio_file,y - // path = pathtoken + 1 - // [2477] fopen::path#0 = fopen::pathtoken#10 + 1 -- pbuz1=pbuz2_plus_1 - clc - lda.z pathtoken_1 - adc #1 - sta.z path - lda.z pathtoken_1+1 - adc #0 - sta.z path+1 - // [2478] phi from fopen::@16 fopen::@17 fopen::@18 fopen::@19 fopen::@25 to fopen::@12 [phi:fopen::@16/fopen::@17/fopen::@18/fopen::@19/fopen::@25->fopen::@12] - // [2478] phi fopen::num#15 = fopen::num#2 [phi:fopen::@16/fopen::@17/fopen::@18/fopen::@19/fopen::@25->fopen::@12#0] -- register_copy - // [2478] phi fopen::path#14 = fopen::path#17 [phi:fopen::@16/fopen::@17/fopen::@18/fopen::@19/fopen::@25->fopen::@12#1] -- register_copy - // fopen::@12 - __b12: - // pathstep++; - // [2479] fopen::pathstep#1 = ++ fopen::pathstep#10 -- vbum1=_inc_vbum1 - inc pathstep - jmp __b10 - // fopen::@11 - __b11: - // char pathcmp = *path - // [2480] fopen::pathcmp#0 = *fopen::path#10 -- vbum1=_deref_pbuz2 - ldy #0 - lda (path),y - sta pathcmp - // case 'D': - // [2481] if(fopen::pathcmp#0=='D') goto fopen::@13 -- vbum1_eq_vbuc1_then_la1 - lda #'D' - cmp pathcmp - beq __b13 - // fopen::@20 - // case 'L': - // [2482] if(fopen::pathcmp#0=='L') goto fopen::@13 -- vbum1_eq_vbuc1_then_la1 - lda #'L' - cmp pathcmp - beq __b13 - // fopen::@21 - // case 'C': - // num = (char)atoi(path + 1); - // path = pathtoken + 1; - // [2483] if(fopen::pathcmp#0=='C') goto fopen::@13 -- vbum1_eq_vbuc1_then_la1 - lda #'C' - cmp pathcmp - beq __b13 - // [2484] phi from fopen::@21 fopen::@30 to fopen::@14 [phi:fopen::@21/fopen::@30->fopen::@14] - // [2484] phi fopen::path#17 = fopen::path#10 [phi:fopen::@21/fopen::@30->fopen::@14#0] -- register_copy - // [2484] phi fopen::num#2 = fopen::num#10 [phi:fopen::@21/fopen::@30->fopen::@14#1] -- register_copy - // fopen::@14 - __b14: - // case 'L': - // __logical = num; - // break; - // [2485] if(fopen::pathcmp#0=='L') goto fopen::@17 -- vbum1_eq_vbuc1_then_la1 - lda #'L' - cmp pathcmp - beq __b17 - // fopen::@15 - // case 'D': - // __device = num; - // break; - // [2486] if(fopen::pathcmp#0=='D') goto fopen::@18 -- vbum1_eq_vbuc1_then_la1 - lda #'D' - cmp pathcmp - beq __b18 - // fopen::@16 - // case 'C': - // __channel = num; - // break; - // [2487] if(fopen::pathcmp#0!='C') goto fopen::@12 -- vbum1_neq_vbuc1_then_la1 - lda #'C' - cmp pathcmp - bne __b12 - // fopen::@19 - // __channel = num - // [2488] ((char *)&__stdio_file+$44)[fopen::sp#0] = fopen::num#2 -- pbuc1_derefidx_vbum1=vbum2 - lda num - ldy sp - sta __stdio_file+$44,y - jmp __b12 - // fopen::@18 - __b18: - // __device = num - // [2489] ((char *)&__stdio_file+$42)[fopen::sp#0] = fopen::num#2 -- pbuc1_derefidx_vbum1=vbum2 - lda num - ldy sp - sta __stdio_file+$42,y - jmp __b12 - // fopen::@17 - __b17: - // __logical = num - // [2490] ((char *)&__stdio_file+$40)[fopen::sp#0] = fopen::num#2 -- pbuc1_derefidx_vbum1=vbum2 - lda num - ldy sp - sta __stdio_file+$40,y - jmp __b12 - // fopen::@13 - __b13: - // atoi(path + 1) - // [2491] atoi::str#0 = fopen::path#10 + 1 -- pbuz1=pbuz1_plus_1 - inc.z atoi.str - bne !+ - inc.z atoi.str+1 - !: - // [2492] call atoi - // [3278] phi from fopen::@13 to atoi [phi:fopen::@13->atoi] - // [3278] phi atoi::str#2 = atoi::str#0 [phi:fopen::@13->atoi#0] -- register_copy - jsr atoi - // atoi(path + 1) - // [2493] atoi::return#3 = atoi::return#2 - // fopen::@30 - // [2494] fopen::$26 = atoi::return#3 -- vwsz1=vwsm2 - lda atoi.return - sta.z fopen__26 - lda atoi.return+1 - sta.z fopen__26+1 - // num = (char)atoi(path + 1) - // [2495] fopen::num#1 = (char)fopen::$26 -- vbum1=_byte_vwsz2 - lda.z fopen__26 - sta num - // path = pathtoken + 1 - // [2496] fopen::path#1 = fopen::pathtoken#10 + 1 -- pbuz1=pbuz2_plus_1 - clc - lda.z pathtoken_1 - adc #1 - sta.z path - lda.z pathtoken_1+1 - adc #0 - sta.z path+1 - jmp __b14 + // insertup::@2 + __b2: + // y+1 + // [1721] insertup::$4 = insertup::y#2 + 1 -- vbuz1=vbum2_plus_1 + lda y + inc + sta.z insertup__4 + // memcpy8_vram_vram(__conio.mapbase_bank, __conio.offsets[y], __conio.mapbase_bank, __conio.offsets[y+1], width) + // [1722] insertup::$6 = insertup::y#2 << 1 -- vbuz1=vbum2_rol_1 + lda y + asl + sta.z insertup__6 + // [1723] insertup::$7 = insertup::$4 << 1 -- vbuz1=vbuz1_rol_1 + asl.z insertup__7 + // [1724] memcpy8_vram_vram::dbank_vram#0 = *((char *)&__conio+5) -- vbum1=_deref_pbuc1 + lda __conio+5 + sta memcpy8_vram_vram.dbank_vram + // [1725] memcpy8_vram_vram::doffset_vram#0 = ((unsigned int *)&__conio+$15)[insertup::$6] -- vwum1=pwuc1_derefidx_vbuz2 + ldy.z insertup__6 + lda __conio+$15,y + sta memcpy8_vram_vram.doffset_vram + lda __conio+$15+1,y + sta memcpy8_vram_vram.doffset_vram+1 + // [1726] memcpy8_vram_vram::sbank_vram#0 = *((char *)&__conio+5) -- vbum1=_deref_pbuc1 + lda __conio+5 + sta memcpy8_vram_vram.sbank_vram + // [1727] memcpy8_vram_vram::soffset_vram#0 = ((unsigned int *)&__conio+$15)[insertup::$7] -- vwum1=pwuc1_derefidx_vbuz2 + ldy.z insertup__7 + lda __conio+$15,y + sta memcpy8_vram_vram.soffset_vram + lda __conio+$15+1,y + sta memcpy8_vram_vram.soffset_vram+1 + // [1728] memcpy8_vram_vram::num8#1 = insertup::width#0 -- vbum1=vbum2 + lda width + sta memcpy8_vram_vram.num8_1 + // [1729] call memcpy8_vram_vram + jsr memcpy8_vram_vram + // insertup::@4 + // for(unsigned char y=0; y<__conio.cursor_y; y++) + // [1730] insertup::y#1 = ++ insertup::y#2 -- vbum1=_inc_vbum1 + inc y + // [1716] phi from insertup::@4 to insertup::@1 [phi:insertup::@4->insertup::@1] + // [1716] phi insertup::y#2 = insertup::y#1 [phi:insertup::@4->insertup::@1#0] -- register_copy + jmp __b1 .segment Data - cbm_k_setnam1_filename_len: .byte 0 - cbm_k_readst1_status: .byte 0 - cbm_k_close1_channel: .byte 0 - sp: .byte 0 - pathpos: .byte 0 - pathpos_1: .byte 0 - pathcmp: .byte 0 - // Parse path - pathstep: .byte 0 - num: .byte 0 - cbm_k_readst1_return: .byte 0 + width: .byte 0 + y: .byte 0 } .segment Code - // fgets -/** - * @brief Load a file to ram or (banked ram located between address 0xA000 and 0xBFFF), incrementing the banks. - * This function uses the new CX16 macptr kernal API at address $FF44. - * - * @param sptr The pointer between 0xA000 and 0xBFFF in banked ram. - * @param size The amount of bytes to be read. - * @param filename Name of the file to be loaded. - * @return ptr the pointer advanced to the point where the stream ends. - */ -// __mem() unsigned int fgets(__zp($43) char *ptr, __mem() unsigned int size, __zp($6e) struct $2 *stream) -fgets: { - .label fgets__1 = $61 - .label fgets__8 = $3a - .label fgets__9 = $42 - .label fgets__13 = $29 - .label ptr = $43 - .label stream = $6e - // unsigned char sp = (unsigned char)stream - // [2498] fgets::sp#0 = (char)fgets::stream#4 -- vbum1=_byte_pssz2 - lda.z stream - sta sp - // cbm_k_chkin(__logical) - // [2499] fgets::cbm_k_chkin1_channel = ((char *)&__stdio_file+$40)[fgets::sp#0] -- vbum1=pbuc1_derefidx_vbum2 + // clearline +clearline: { + .label clearline__0 = $24 + .label clearline__1 = $25 + .label clearline__2 = $26 + .label clearline__3 = $23 + .label c = $22 + // unsigned int addr = __conio.offsets[__conio.cursor_y] + // [1731] clearline::$3 = *((char *)&__conio+1) << 1 -- vbuz1=_deref_pbuc1_rol_1 + lda __conio+1 + asl + sta.z clearline__3 + // [1732] clearline::addr#0 = ((unsigned int *)&__conio+$15)[clearline::$3] -- vwum1=pwuc1_derefidx_vbuz2 tay - lda __stdio_file+$40,y - sta cbm_k_chkin1_channel - // fgets::cbm_k_chkin1 - // char status - // [2500] fgets::cbm_k_chkin1_status = 0 -- vbum1=vbuc1 - lda #0 - sta cbm_k_chkin1_status - // asm - // asm { ldxchannel jsrCBM_CHKIN stastatus } - ldx cbm_k_chkin1_channel - jsr CBM_CHKIN - sta cbm_k_chkin1_status - // fgets::cbm_k_readst1 - // char status - // [2502] fgets::cbm_k_readst1_status = 0 -- vbum1=vbuc1 - lda #0 - sta cbm_k_readst1_status - // asm - // asm { jsrCBM_READST stastatus } - jsr CBM_READST - sta cbm_k_readst1_status - // return status; - // [2504] fgets::cbm_k_readst1_return#0 = fgets::cbm_k_readst1_status -- vbum1=vbum2 - sta cbm_k_readst1_return - // fgets::cbm_k_readst1_@return - // } - // [2505] fgets::cbm_k_readst1_return#1 = fgets::cbm_k_readst1_return#0 - // fgets::@11 - // cbm_k_readst() - // [2506] fgets::$1 = fgets::cbm_k_readst1_return#1 -- vbuz1=vbum2 - sta.z fgets__1 - // __status = cbm_k_readst() - // [2507] ((char *)&__stdio_file+$46)[fgets::sp#0] = fgets::$1 -- pbuc1_derefidx_vbum1=vbuz2 - ldy sp - sta __stdio_file+$46,y - // if (__status) - // [2508] if(0==((char *)&__stdio_file+$46)[fgets::sp#0]) goto fgets::@1 -- 0_eq_pbuc1_derefidx_vbum1_then_la1 - lda __stdio_file+$46,y - cmp #0 - beq __b1 - // [2509] phi from fgets::@11 fgets::@12 fgets::@5 to fgets::@return [phi:fgets::@11/fgets::@12/fgets::@5->fgets::@return] - __b8: - // [2509] phi fgets::return#1 = 0 [phi:fgets::@11/fgets::@12/fgets::@5->fgets::@return#0] -- vwum1=vbuc1 - lda #<0 - sta return - sta return+1 - // fgets::@return - // } - // [2510] return - rts - // fgets::@1 + lda __conio+$15,y + sta addr + lda __conio+$15+1,y + sta addr+1 + // *VERA_CTRL &= ~VERA_ADDRSEL + // [1733] *VERA_CTRL = *VERA_CTRL & ~VERA_ADDRSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 + lda #VERA_ADDRSEL^$ff + and VERA_CTRL + sta VERA_CTRL + // BYTE0(addr) + // [1734] clearline::$0 = byte0 clearline::addr#0 -- vbuz1=_byte0_vwum2 + lda addr + sta.z clearline__0 + // *VERA_ADDRX_L = BYTE0(addr) + // [1735] *VERA_ADDRX_L = clearline::$0 -- _deref_pbuc1=vbuz1 + sta VERA_ADDRX_L + // BYTE1(addr) + // [1736] clearline::$1 = byte1 clearline::addr#0 -- vbuz1=_byte1_vwum2 + lda addr+1 + sta.z clearline__1 + // *VERA_ADDRX_M = BYTE1(addr) + // [1737] *VERA_ADDRX_M = clearline::$1 -- _deref_pbuc1=vbuz1 + sta VERA_ADDRX_M + // __conio.mapbase_bank | VERA_INC_1 + // [1738] clearline::$2 = *((char *)&__conio+5) | VERA_INC_1 -- vbuz1=_deref_pbuc1_bor_vbuc2 + lda #VERA_INC_1 + ora __conio+5 + sta.z clearline__2 + // *VERA_ADDRX_H = __conio.mapbase_bank | VERA_INC_1 + // [1739] *VERA_ADDRX_H = clearline::$2 -- _deref_pbuc1=vbuz1 + sta VERA_ADDRX_H + // register unsigned char c=__conio.width + // [1740] clearline::c#0 = *((char *)&__conio+6) -- vbuz1=_deref_pbuc1 + lda __conio+6 + sta.z c + // [1741] phi from clearline clearline::@1 to clearline::@1 [phi:clearline/clearline::@1->clearline::@1] + // [1741] phi clearline::c#2 = clearline::c#0 [phi:clearline/clearline::@1->clearline::@1#0] -- register_copy + // clearline::@1 __b1: - // [2511] fgets::remaining#22 = fgets::size#10 -- vwum1=vwum2 - lda size - sta remaining - lda size+1 - sta remaining+1 - // [2512] phi from fgets::@1 to fgets::@2 [phi:fgets::@1->fgets::@2] - // [2512] phi fgets::read#10 = 0 [phi:fgets::@1->fgets::@2#0] -- vwum1=vwuc1 - lda #<0 - sta read - sta read+1 - // [2512] phi fgets::remaining#11 = fgets::remaining#22 [phi:fgets::@1->fgets::@2#1] -- register_copy - // [2512] phi fgets::ptr#11 = fgets::ptr#14 [phi:fgets::@1->fgets::@2#2] -- register_copy - // [2512] phi from fgets::@17 fgets::@18 to fgets::@2 [phi:fgets::@17/fgets::@18->fgets::@2] - // [2512] phi fgets::read#10 = fgets::read#1 [phi:fgets::@17/fgets::@18->fgets::@2#0] -- register_copy - // [2512] phi fgets::remaining#11 = fgets::remaining#1 [phi:fgets::@17/fgets::@18->fgets::@2#1] -- register_copy - // [2512] phi fgets::ptr#11 = fgets::ptr#15 [phi:fgets::@17/fgets::@18->fgets::@2#2] -- register_copy - // fgets::@2 - __b2: - // if (!size) - // [2513] if(0==fgets::size#10) goto fgets::@3 -- 0_eq_vwum1_then_la1 - lda size - ora size+1 - bne !__b3+ - jmp __b3 - !__b3: - // fgets::@8 - // if (remaining >= 512) - // [2514] if(fgets::remaining#11>=$200) goto fgets::@4 -- vwum1_ge_vwuc1_then_la1 - lda remaining+1 - cmp #>$200 - bcc !+ - beq !__b4+ - jmp __b4 - !__b4: - lda remaining - cmp #<$200 - bcc !__b4+ - jmp __b4 - !__b4: - !: - // fgets::@9 - // cx16_k_macptr(remaining, ptr) - // [2515] cx16_k_macptr::bytes = fgets::remaining#11 -- vbum1=vwum2 - lda remaining - sta cx16_k_macptr.bytes - // [2516] cx16_k_macptr::buffer = (void *)fgets::ptr#11 -- pvoz1=pvoz2 - lda.z ptr - sta.z cx16_k_macptr.buffer - lda.z ptr+1 - sta.z cx16_k_macptr.buffer+1 - // [2517] call cx16_k_macptr - jsr cx16_k_macptr - // [2518] cx16_k_macptr::return#4 = cx16_k_macptr::return#1 - // fgets::@15 - __b15: - // bytes = cx16_k_macptr(remaining, ptr) - // [2519] fgets::bytes#3 = cx16_k_macptr::return#4 - // [2520] phi from fgets::@13 fgets::@14 fgets::@15 to fgets::cbm_k_readst2 [phi:fgets::@13/fgets::@14/fgets::@15->fgets::cbm_k_readst2] - // [2520] phi fgets::bytes#10 = fgets::bytes#1 [phi:fgets::@13/fgets::@14/fgets::@15->fgets::cbm_k_readst2#0] -- register_copy - // fgets::cbm_k_readst2 - // char status - // [2521] fgets::cbm_k_readst2_status = 0 -- vbum1=vbuc1 - lda #0 - sta cbm_k_readst2_status - // asm - // asm { jsrCBM_READST stastatus } - jsr CBM_READST - sta cbm_k_readst2_status - // return status; - // [2523] fgets::cbm_k_readst2_return#0 = fgets::cbm_k_readst2_status -- vbum1=vbum2 - sta cbm_k_readst2_return - // fgets::cbm_k_readst2_@return + // *VERA_DATA0 = ' ' + // [1742] *VERA_DATA0 = ' ' -- _deref_pbuc1=vbuc2 + lda #' ' + sta VERA_DATA0 + // *VERA_DATA0 = __conio.color + // [1743] *VERA_DATA0 = *((char *)&__conio+$d) -- _deref_pbuc1=_deref_pbuc2 + lda __conio+$d + sta VERA_DATA0 + // c--; + // [1744] clearline::c#1 = -- clearline::c#2 -- vbuz1=_dec_vbuz1 + dec.z c + // while(c) + // [1745] if(0!=clearline::c#1) goto clearline::@1 -- 0_neq_vbuz1_then_la1 + lda.z c + bne __b1 + // clearline::@return // } - // [2524] fgets::cbm_k_readst2_return#1 = fgets::cbm_k_readst2_return#0 - // fgets::@12 - // cbm_k_readst() - // [2525] fgets::$8 = fgets::cbm_k_readst2_return#1 -- vbuz1=vbum2 - sta.z fgets__8 - // __status = cbm_k_readst() - // [2526] ((char *)&__stdio_file+$46)[fgets::sp#0] = fgets::$8 -- pbuc1_derefidx_vbum1=vbuz2 - ldy sp - sta __stdio_file+$46,y - // __status & 0xBF - // [2527] fgets::$9 = ((char *)&__stdio_file+$46)[fgets::sp#0] & $bf -- vbuz1=pbuc1_derefidx_vbum2_band_vbuc2 - lda #$bf - and __stdio_file+$46,y - sta.z fgets__9 - // if (__status & 0xBF) - // [2528] if(0==fgets::$9) goto fgets::@5 -- 0_eq_vbuz1_then_la1 - beq __b5 - jmp __b8 - // fgets::@5 - __b5: - // if (bytes == 0xFFFF) - // [2529] if(fgets::bytes#10!=$ffff) goto fgets::@6 -- vwum1_neq_vwuc1_then_la1 - lda bytes+1 - cmp #>$ffff - bne __b6 - lda bytes - cmp #<$ffff - bne __b6 - jmp __b8 - // fgets::@6 - __b6: - // read += bytes - // [2530] fgets::read#1 = fgets::read#10 + fgets::bytes#10 -- vwum1=vwum1_plus_vwum2 - clc - lda read - adc bytes - sta read - lda read+1 - adc bytes+1 - sta read+1 - // ptr += bytes - // [2531] fgets::ptr#0 = fgets::ptr#11 + fgets::bytes#10 -- pbuz1=pbuz1_plus_vwum2 - clc - lda.z ptr - adc bytes - sta.z ptr - lda.z ptr+1 - adc bytes+1 - sta.z ptr+1 - // BYTE1(ptr) - // [2532] fgets::$13 = byte1 fgets::ptr#0 -- vbuz1=_byte1_pbuz2 - sta.z fgets__13 - // if (BYTE1(ptr) == 0xC0) - // [2533] if(fgets::$13!=$c0) goto fgets::@7 -- vbuz1_neq_vbuc1_then_la1 - lda #$c0 - cmp.z fgets__13 - bne __b7 - // fgets::@10 - // ptr -= 0x2000 - // [2534] fgets::ptr#1 = fgets::ptr#0 - $2000 -- pbuz1=pbuz1_minus_vwuc1 - lda.z ptr - sec - sbc #<$2000 - sta.z ptr - lda.z ptr+1 - sbc #>$2000 - sta.z ptr+1 - // [2535] phi from fgets::@10 fgets::@6 to fgets::@7 [phi:fgets::@10/fgets::@6->fgets::@7] - // [2535] phi fgets::ptr#15 = fgets::ptr#1 [phi:fgets::@10/fgets::@6->fgets::@7#0] -- register_copy - // fgets::@7 - __b7: - // remaining -= bytes - // [2536] fgets::remaining#1 = fgets::remaining#11 - fgets::bytes#10 -- vwum1=vwum1_minus_vwum2 - lda remaining - sec - sbc bytes - sta remaining - lda remaining+1 - sbc bytes+1 - sta remaining+1 - // while ((__status == 0) && ((size && remaining) || !size)) - // [2537] if(((char *)&__stdio_file+$46)[fgets::sp#0]==0) goto fgets::@16 -- pbuc1_derefidx_vbum1_eq_0_then_la1 - ldy sp - lda __stdio_file+$46,y - cmp #0 - beq __b16 - // [2509] phi from fgets::@17 fgets::@7 to fgets::@return [phi:fgets::@17/fgets::@7->fgets::@return] - // [2509] phi fgets::return#1 = fgets::read#1 [phi:fgets::@17/fgets::@7->fgets::@return#0] -- register_copy - rts - // fgets::@16 - __b16: - // while ((__status == 0) && ((size && remaining) || !size)) - // [2538] if(0==fgets::size#10) goto fgets::@17 -- 0_eq_vwum1_then_la1 - lda size - ora size+1 - beq __b17 - // fgets::@18 - // [2539] if(0!=fgets::remaining#1) goto fgets::@2 -- 0_neq_vwum1_then_la1 - lda remaining - ora remaining+1 - beq !__b2+ - jmp __b2 - !__b2: - // fgets::@17 - __b17: - // [2540] if(0==fgets::size#10) goto fgets::@2 -- 0_eq_vwum1_then_la1 - lda size - ora size+1 - bne !__b2+ - jmp __b2 - !__b2: + // [1746] return rts - // fgets::@4 - __b4: - // cx16_k_macptr(512, ptr) - // [2541] cx16_k_macptr::bytes = $200 -- vbum1=vwuc1 - lda #<$200 - sta cx16_k_macptr.bytes - // [2542] cx16_k_macptr::buffer = (void *)fgets::ptr#11 -- pvoz1=pvoz2 - lda.z ptr - sta.z cx16_k_macptr.buffer - lda.z ptr+1 - sta.z cx16_k_macptr.buffer+1 - // [2543] call cx16_k_macptr - jsr cx16_k_macptr - // [2544] cx16_k_macptr::return#3 = cx16_k_macptr::return#1 - // fgets::@14 - // bytes = cx16_k_macptr(512, ptr) - // [2545] fgets::bytes#2 = cx16_k_macptr::return#3 - jmp __b15 - // fgets::@3 - __b3: - // cx16_k_macptr(0, ptr) - // [2546] cx16_k_macptr::bytes = 0 -- vbum1=vbuc1 - lda #0 - sta cx16_k_macptr.bytes - // [2547] cx16_k_macptr::buffer = (void *)fgets::ptr#11 -- pvoz1=pvoz2 - lda.z ptr - sta.z cx16_k_macptr.buffer - lda.z ptr+1 - sta.z cx16_k_macptr.buffer+1 - // [2548] call cx16_k_macptr - jsr cx16_k_macptr - // [2549] cx16_k_macptr::return#2 = cx16_k_macptr::return#1 - // fgets::@13 - // bytes = cx16_k_macptr(0, ptr) - // [2550] fgets::bytes#1 = cx16_k_macptr::return#2 - jmp __b15 .segment Data - cbm_k_chkin1_channel: .byte 0 - cbm_k_chkin1_status: .byte 0 - cbm_k_readst1_status: .byte 0 - cbm_k_readst2_status: .byte 0 - sp: .byte 0 - cbm_k_readst1_return: .byte 0 - .label return = read - bytes: .word 0 - cbm_k_readst2_return: .byte 0 - read: .word 0 - remaining: .word 0 - size: .word 0 + addr: .word 0 } .segment Code - // fclose + // display_frame_maskxy /** - * @brief Close a file. - * - * @param fp The FILE pointer. - * @return - * - 0x0000: Something is wrong! Kernal Error Code (https://commodore.ca/manuals/pdfs/commodore_error_messages.pdf) - * - other: OK! The last pointer between 0xA000 and 0xBFFF is returned. Note that the last pointer is indicating the first free byte. + * @brief + * + * @param x + * @param y + * @return unsigned char */ -// int fclose(__zp($c3) struct $2 *stream) -fclose: { - .label fclose__1 = $3a - .label fclose__4 = $42 - .label fclose__6 = $29 - .label stream = $c3 - // unsigned char sp = (unsigned char)stream - // [2552] fclose::sp#0 = (char)fclose::stream#3 -- vbum1=_byte_pssz2 - lda.z stream - sta sp - // cbm_k_chkin(__logical) - // [2553] fclose::cbm_k_chkin1_channel = ((char *)&__stdio_file+$40)[fclose::sp#0] -- vbum1=pbuc1_derefidx_vbum2 - tay - lda __stdio_file+$40,y - sta cbm_k_chkin1_channel - // fclose::cbm_k_chkin1 - // char status - // [2554] fclose::cbm_k_chkin1_status = 0 -- vbum1=vbuc1 - lda #0 - sta cbm_k_chkin1_status - // asm - // asm { ldxchannel jsrCBM_CHKIN stastatus } - ldx cbm_k_chkin1_channel - jsr CBM_CHKIN - sta cbm_k_chkin1_status - // fclose::cbm_k_readst1 - // char status - // [2556] fclose::cbm_k_readst1_status = 0 -- vbum1=vbuc1 - lda #0 - sta cbm_k_readst1_status - // asm - // asm { jsrCBM_READST stastatus } - jsr CBM_READST - sta cbm_k_readst1_status - // return status; - // [2558] fclose::cbm_k_readst1_return#0 = fclose::cbm_k_readst1_status -- vbum1=vbum2 - sta cbm_k_readst1_return - // fclose::cbm_k_readst1_@return - // } - // [2559] fclose::cbm_k_readst1_return#1 = fclose::cbm_k_readst1_return#0 - // fclose::@3 - // cbm_k_readst() - // [2560] fclose::$1 = fclose::cbm_k_readst1_return#1 -- vbuz1=vbum2 - sta.z fclose__1 - // __status = cbm_k_readst() - // [2561] ((char *)&__stdio_file+$46)[fclose::sp#0] = fclose::$1 -- pbuc1_derefidx_vbum1=vbuz2 - ldy sp - sta __stdio_file+$46,y - // if (__status) - // [2562] if(0==((char *)&__stdio_file+$46)[fclose::sp#0]) goto fclose::@1 -- 0_eq_pbuc1_derefidx_vbum1_then_la1 - lda __stdio_file+$46,y - cmp #0 +// __mem() char display_frame_maskxy(__mem() char x, __mem() char y) +display_frame_maskxy: { + .label cpeekcxy1_cpeekc1_display_frame_maskxy__0 = $38 + .label cpeekcxy1_cpeekc1_display_frame_maskxy__1 = $4e + .label cpeekcxy1_cpeekc1_display_frame_maskxy__2 = $3b + // display_frame_maskxy::cpeekcxy1 + // gotoxy(x,y) + // [1748] gotoxy::x#9 = display_frame_maskxy::cpeekcxy1_x#0 -- vbum1=vbum2 + lda cpeekcxy1_x + sta gotoxy.x + // [1749] gotoxy::y#9 = display_frame_maskxy::cpeekcxy1_y#0 -- vbum1=vbum2 + lda cpeekcxy1_y + sta gotoxy.y + // [1750] call gotoxy + // [457] phi from display_frame_maskxy::cpeekcxy1 to gotoxy [phi:display_frame_maskxy::cpeekcxy1->gotoxy] + // [457] phi gotoxy::y#26 = gotoxy::y#9 [phi:display_frame_maskxy::cpeekcxy1->gotoxy#0] -- register_copy + // [457] phi gotoxy::x#26 = gotoxy::x#9 [phi:display_frame_maskxy::cpeekcxy1->gotoxy#1] -- register_copy + jsr gotoxy + // display_frame_maskxy::cpeekcxy1_cpeekc1 + // *VERA_CTRL &= ~VERA_ADDRSEL + // [1751] *VERA_CTRL = *VERA_CTRL & ~VERA_ADDRSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 + lda #VERA_ADDRSEL^$ff + and VERA_CTRL + sta VERA_CTRL + // BYTE0(__conio.offset) + // [1752] display_frame_maskxy::cpeekcxy1_cpeekc1_$0 = byte0 *((unsigned int *)&__conio+$13) -- vbuz1=_byte0__deref_pwuc1 + lda __conio+$13 + sta.z cpeekcxy1_cpeekc1_display_frame_maskxy__0 + // *VERA_ADDRX_L = BYTE0(__conio.offset) + // [1753] *VERA_ADDRX_L = display_frame_maskxy::cpeekcxy1_cpeekc1_$0 -- _deref_pbuc1=vbuz1 + sta VERA_ADDRX_L + // BYTE1(__conio.offset) + // [1754] display_frame_maskxy::cpeekcxy1_cpeekc1_$1 = byte1 *((unsigned int *)&__conio+$13) -- vbuz1=_byte1__deref_pwuc1 + lda __conio+$13+1 + sta.z cpeekcxy1_cpeekc1_display_frame_maskxy__1 + // *VERA_ADDRX_M = BYTE1(__conio.offset) + // [1755] *VERA_ADDRX_M = display_frame_maskxy::cpeekcxy1_cpeekc1_$1 -- _deref_pbuc1=vbuz1 + sta VERA_ADDRX_M + // __conio.mapbase_bank | VERA_INC_0 + // [1756] display_frame_maskxy::cpeekcxy1_cpeekc1_$2 = *((char *)&__conio+5) -- vbuz1=_deref_pbuc1 + lda __conio+5 + sta.z cpeekcxy1_cpeekc1_display_frame_maskxy__2 + // *VERA_ADDRX_H = __conio.mapbase_bank | VERA_INC_0 + // [1757] *VERA_ADDRX_H = display_frame_maskxy::cpeekcxy1_cpeekc1_$2 -- _deref_pbuc1=vbuz1 + sta VERA_ADDRX_H + // return *VERA_DATA0; + // [1758] display_frame_maskxy::c#0 = *VERA_DATA0 -- vbum1=_deref_pbuc1 + lda VERA_DATA0 + sta c + // display_frame_maskxy::@12 + // case 0x70: // DR corner. + // return 0b0110; + // [1759] if(display_frame_maskxy::c#0==$70) goto display_frame_maskxy::@return -- vbum1_eq_vbuc1_then_la1 + lda #$70 + cmp c + beq __b2 + // display_frame_maskxy::@1 + // case 0x6E: // DL corner. + // return 0b0011; + // [1760] if(display_frame_maskxy::c#0==$6e) goto display_frame_maskxy::@return -- vbum1_eq_vbuc1_then_la1 + lda #$6e + cmp c beq __b1 - // [2563] phi from fclose::@2 fclose::@3 fclose::@4 to fclose::@return [phi:fclose::@2/fclose::@3/fclose::@4->fclose::@return] - // [2563] phi __stdio_filecount#2 = __stdio_filecount#3 [phi:fclose::@2/fclose::@3/fclose::@4->fclose::@return#0] -- register_copy - // fclose::@return - // } - // [2564] return + // display_frame_maskxy::@2 + // case 0x6D: // UR corner. + // return 0b1100; + // [1761] if(display_frame_maskxy::c#0==$6d) goto display_frame_maskxy::@return -- vbum1_eq_vbuc1_then_la1 + lda #$6d + cmp c + beq __b3 + // display_frame_maskxy::@3 + // case 0x7D: // UL corner. + // return 0b1001; + // [1762] if(display_frame_maskxy::c#0==$7d) goto display_frame_maskxy::@return -- vbum1_eq_vbuc1_then_la1 + lda #$7d + cmp c + beq __b4 + // display_frame_maskxy::@4 + // case 0x40: // HL line. + // return 0b0101; + // [1763] if(display_frame_maskxy::c#0==$40) goto display_frame_maskxy::@return -- vbum1_eq_vbuc1_then_la1 + lda #$40 + cmp c + beq __b5 + // display_frame_maskxy::@5 + // case 0x5D: // VL line. + // return 0b1010; + // [1764] if(display_frame_maskxy::c#0==$5d) goto display_frame_maskxy::@return -- vbum1_eq_vbuc1_then_la1 + lda #$5d + cmp c + beq __b6 + // display_frame_maskxy::@6 + // case 0x6B: // VR junction. + // return 0b1110; + // [1765] if(display_frame_maskxy::c#0==$6b) goto display_frame_maskxy::@return -- vbum1_eq_vbuc1_then_la1 + lda #$6b + cmp c + beq __b7 + // display_frame_maskxy::@7 + // case 0x73: // VL junction. + // return 0b1011; + // [1766] if(display_frame_maskxy::c#0==$73) goto display_frame_maskxy::@return -- vbum1_eq_vbuc1_then_la1 + lda #$73 + cmp c + beq __b8 + // display_frame_maskxy::@8 + // case 0x72: // HD junction. + // return 0b0111; + // [1767] if(display_frame_maskxy::c#0==$72) goto display_frame_maskxy::@return -- vbum1_eq_vbuc1_then_la1 + lda #$72 + cmp c + beq __b9 + // display_frame_maskxy::@9 + // case 0x71: // HU junction. + // return 0b1101; + // [1768] if(display_frame_maskxy::c#0==$71) goto display_frame_maskxy::@return -- vbum1_eq_vbuc1_then_la1 + lda #$71 + cmp c + beq __b10 + // display_frame_maskxy::@10 + // case 0x5B: // HV junction. + // return 0b1111; + // [1769] if(display_frame_maskxy::c#0==$5b) goto display_frame_maskxy::@11 -- vbum1_eq_vbuc1_then_la1 + lda #$5b + cmp c + beq __b11 + // [1771] phi from display_frame_maskxy::@10 to display_frame_maskxy::@return [phi:display_frame_maskxy::@10->display_frame_maskxy::@return] + // [1771] phi display_frame_maskxy::return#12 = 0 [phi:display_frame_maskxy::@10->display_frame_maskxy::@return#0] -- vbum1=vbuc1 + lda #0 + sta return rts - // fclose::@1 + // [1770] phi from display_frame_maskxy::@10 to display_frame_maskxy::@11 [phi:display_frame_maskxy::@10->display_frame_maskxy::@11] + // display_frame_maskxy::@11 + __b11: + // [1771] phi from display_frame_maskxy::@11 to display_frame_maskxy::@return [phi:display_frame_maskxy::@11->display_frame_maskxy::@return] + // [1771] phi display_frame_maskxy::return#12 = $f [phi:display_frame_maskxy::@11->display_frame_maskxy::@return#0] -- vbum1=vbuc1 + lda #$f + sta return + rts + // [1771] phi from display_frame_maskxy::@1 to display_frame_maskxy::@return [phi:display_frame_maskxy::@1->display_frame_maskxy::@return] __b1: - // cbm_k_close(__logical) - // [2565] fclose::cbm_k_close1_channel = ((char *)&__stdio_file+$40)[fclose::sp#0] -- vbum1=pbuc1_derefidx_vbum2 - ldy sp - lda __stdio_file+$40,y - sta cbm_k_close1_channel - // fclose::cbm_k_close1 - // asm - // asm { ldachannel jsrCBM_CLOSE } - jsr CBM_CLOSE - // fclose::cbm_k_readst2 - // char status - // [2567] fclose::cbm_k_readst2_status = 0 -- vbum1=vbuc1 - lda #0 - sta cbm_k_readst2_status - // asm - // asm { jsrCBM_READST stastatus } - jsr CBM_READST - sta cbm_k_readst2_status - // return status; - // [2569] fclose::cbm_k_readst2_return#0 = fclose::cbm_k_readst2_status -- vbum1=vbum2 - sta cbm_k_readst2_return - // fclose::cbm_k_readst2_@return + // [1771] phi display_frame_maskxy::return#12 = 3 [phi:display_frame_maskxy::@1->display_frame_maskxy::@return#0] -- vbum1=vbuc1 + lda #3 + sta return + rts + // [1771] phi from display_frame_maskxy::@12 to display_frame_maskxy::@return [phi:display_frame_maskxy::@12->display_frame_maskxy::@return] + __b2: + // [1771] phi display_frame_maskxy::return#12 = 6 [phi:display_frame_maskxy::@12->display_frame_maskxy::@return#0] -- vbum1=vbuc1 + lda #6 + sta return + rts + // [1771] phi from display_frame_maskxy::@2 to display_frame_maskxy::@return [phi:display_frame_maskxy::@2->display_frame_maskxy::@return] + __b3: + // [1771] phi display_frame_maskxy::return#12 = $c [phi:display_frame_maskxy::@2->display_frame_maskxy::@return#0] -- vbum1=vbuc1 + lda #$c + sta return + rts + // [1771] phi from display_frame_maskxy::@3 to display_frame_maskxy::@return [phi:display_frame_maskxy::@3->display_frame_maskxy::@return] + __b4: + // [1771] phi display_frame_maskxy::return#12 = 9 [phi:display_frame_maskxy::@3->display_frame_maskxy::@return#0] -- vbum1=vbuc1 + lda #9 + sta return + rts + // [1771] phi from display_frame_maskxy::@4 to display_frame_maskxy::@return [phi:display_frame_maskxy::@4->display_frame_maskxy::@return] + __b5: + // [1771] phi display_frame_maskxy::return#12 = 5 [phi:display_frame_maskxy::@4->display_frame_maskxy::@return#0] -- vbum1=vbuc1 + lda #5 + sta return + rts + // [1771] phi from display_frame_maskxy::@5 to display_frame_maskxy::@return [phi:display_frame_maskxy::@5->display_frame_maskxy::@return] + __b6: + // [1771] phi display_frame_maskxy::return#12 = $a [phi:display_frame_maskxy::@5->display_frame_maskxy::@return#0] -- vbum1=vbuc1 + lda #$a + sta return + rts + // [1771] phi from display_frame_maskxy::@6 to display_frame_maskxy::@return [phi:display_frame_maskxy::@6->display_frame_maskxy::@return] + __b7: + // [1771] phi display_frame_maskxy::return#12 = $e [phi:display_frame_maskxy::@6->display_frame_maskxy::@return#0] -- vbum1=vbuc1 + lda #$e + sta return + rts + // [1771] phi from display_frame_maskxy::@7 to display_frame_maskxy::@return [phi:display_frame_maskxy::@7->display_frame_maskxy::@return] + __b8: + // [1771] phi display_frame_maskxy::return#12 = $b [phi:display_frame_maskxy::@7->display_frame_maskxy::@return#0] -- vbum1=vbuc1 + lda #$b + sta return + rts + // [1771] phi from display_frame_maskxy::@8 to display_frame_maskxy::@return [phi:display_frame_maskxy::@8->display_frame_maskxy::@return] + __b9: + // [1771] phi display_frame_maskxy::return#12 = 7 [phi:display_frame_maskxy::@8->display_frame_maskxy::@return#0] -- vbum1=vbuc1 + lda #7 + sta return + rts + // [1771] phi from display_frame_maskxy::@9 to display_frame_maskxy::@return [phi:display_frame_maskxy::@9->display_frame_maskxy::@return] + __b10: + // [1771] phi display_frame_maskxy::return#12 = $d [phi:display_frame_maskxy::@9->display_frame_maskxy::@return#0] -- vbum1=vbuc1 + lda #$d + sta return + // display_frame_maskxy::@return // } - // [2570] fclose::cbm_k_readst2_return#1 = fclose::cbm_k_readst2_return#0 - // fclose::@4 - // cbm_k_readst() - // [2571] fclose::$4 = fclose::cbm_k_readst2_return#1 -- vbuz1=vbum2 - sta.z fclose__4 - // __status = cbm_k_readst() - // [2572] ((char *)&__stdio_file+$46)[fclose::sp#0] = fclose::$4 -- pbuc1_derefidx_vbum1=vbuz2 - ldy sp - sta __stdio_file+$46,y - // if (__status) - // [2573] if(0==((char *)&__stdio_file+$46)[fclose::sp#0]) goto fclose::@2 -- 0_eq_pbuc1_derefidx_vbum1_then_la1 - lda __stdio_file+$46,y - cmp #0 + // [1772] return + rts + .segment Data + cpeekcxy1_x: .byte 0 + cpeekcxy1_y: .byte 0 + c: .byte 0 + // DR corner. + // DL corner. + // UR corner. + // UL corner. + // HL line. + // VL line. + // VR junction. + // VL junction. + // HD junction. + // HU junction. + // HV junction. + return: .byte 0 + .label x = cpeekcxy1_x + .label y = cpeekcxy1_y +} +.segment Code + // display_frame_char +/** + * @brief + * + * @param mask + * @return unsigned char + */ +// __mem() char display_frame_char(__mem() char mask) +display_frame_char: { + // case 0b0110: + // return 0x70; + // [1774] if(display_frame_char::mask#10==6) goto display_frame_char::@return -- vbum1_eq_vbuc1_then_la1 + lda #6 + cmp mask + beq __b1 + // display_frame_char::@1 + // case 0b0011: + // return 0x6E; + // [1775] if(display_frame_char::mask#10==3) goto display_frame_char::@return -- vbum1_eq_vbuc1_then_la1 + // DR corner. + lda #3 + cmp mask beq __b2 + // display_frame_char::@2 + // case 0b1100: + // return 0x6D; + // [1776] if(display_frame_char::mask#10==$c) goto display_frame_char::@return -- vbum1_eq_vbuc1_then_la1 + // DL corner. + lda #$c + cmp mask + beq __b3 + // display_frame_char::@3 + // case 0b1001: + // return 0x7D; + // [1777] if(display_frame_char::mask#10==9) goto display_frame_char::@return -- vbum1_eq_vbuc1_then_la1 + // UR corner. + lda #9 + cmp mask + beq __b4 + // display_frame_char::@4 + // case 0b0101: + // return 0x40; + // [1778] if(display_frame_char::mask#10==5) goto display_frame_char::@return -- vbum1_eq_vbuc1_then_la1 + // UL corner. + lda #5 + cmp mask + beq __b5 + // display_frame_char::@5 + // case 0b1010: + // return 0x5D; + // [1779] if(display_frame_char::mask#10==$a) goto display_frame_char::@return -- vbum1_eq_vbuc1_then_la1 + // HL line. + lda #$a + cmp mask + beq __b6 + // display_frame_char::@6 + // case 0b1110: + // return 0x6B; + // [1780] if(display_frame_char::mask#10==$e) goto display_frame_char::@return -- vbum1_eq_vbuc1_then_la1 + // VL line. + lda #$e + cmp mask + beq __b7 + // display_frame_char::@7 + // case 0b1011: + // return 0x73; + // [1781] if(display_frame_char::mask#10==$b) goto display_frame_char::@return -- vbum1_eq_vbuc1_then_la1 + // VR junction. + lda #$b + cmp mask + beq __b8 + // display_frame_char::@8 + // case 0b0111: + // return 0x72; + // [1782] if(display_frame_char::mask#10==7) goto display_frame_char::@return -- vbum1_eq_vbuc1_then_la1 + // VL junction. + lda #7 + cmp mask + beq __b9 + // display_frame_char::@9 + // case 0b1101: + // return 0x71; + // [1783] if(display_frame_char::mask#10==$d) goto display_frame_char::@return -- vbum1_eq_vbuc1_then_la1 + // HD junction. + lda #$d + cmp mask + beq __b10 + // display_frame_char::@10 + // case 0b1111: + // return 0x5B; + // [1784] if(display_frame_char::mask#10==$f) goto display_frame_char::@11 -- vbum1_eq_vbuc1_then_la1 + // HU junction. + lda #$f + cmp mask + beq __b11 + // [1786] phi from display_frame_char::@10 to display_frame_char::@return [phi:display_frame_char::@10->display_frame_char::@return] + // [1786] phi display_frame_char::return#12 = $20 [phi:display_frame_char::@10->display_frame_char::@return#0] -- vbum1=vbuc1 + lda #$20 + sta return rts - // fclose::@2 + // [1785] phi from display_frame_char::@10 to display_frame_char::@11 [phi:display_frame_char::@10->display_frame_char::@11] + // display_frame_char::@11 + __b11: + // [1786] phi from display_frame_char::@11 to display_frame_char::@return [phi:display_frame_char::@11->display_frame_char::@return] + // [1786] phi display_frame_char::return#12 = $5b [phi:display_frame_char::@11->display_frame_char::@return#0] -- vbum1=vbuc1 + lda #$5b + sta return + rts + // [1786] phi from display_frame_char to display_frame_char::@return [phi:display_frame_char->display_frame_char::@return] + __b1: + // [1786] phi display_frame_char::return#12 = $70 [phi:display_frame_char->display_frame_char::@return#0] -- vbum1=vbuc1 + lda #$70 + sta return + rts + // [1786] phi from display_frame_char::@1 to display_frame_char::@return [phi:display_frame_char::@1->display_frame_char::@return] __b2: - // __logical = 0 - // [2574] ((char *)&__stdio_file+$40)[fclose::sp#0] = 0 -- pbuc1_derefidx_vbum1=vbuc2 - lda #0 - ldy sp - sta __stdio_file+$40,y - // __device = 0 - // [2575] ((char *)&__stdio_file+$42)[fclose::sp#0] = 0 -- pbuc1_derefidx_vbum1=vbuc2 - sta __stdio_file+$42,y - // __channel = 0 - // [2576] ((char *)&__stdio_file+$44)[fclose::sp#0] = 0 -- pbuc1_derefidx_vbum1=vbuc2 - sta __stdio_file+$44,y - // __filename - // [2577] fclose::$6 = fclose::sp#0 << 1 -- vbuz1=vbum2_rol_1 - tya - asl - sta.z fclose__6 - // *__filename = '\0' - // [2578] ((char *)&__stdio_file)[fclose::$6] = '@' -- pbuc1_derefidx_vbuz1=vbuc2 - lda #'@' - ldy.z fclose__6 - sta __stdio_file,y - // __stdio_filecount--; - // [2579] __stdio_filecount#3 = -- __stdio_filecount#1 -- vbum1=_dec_vbum1 - dec __stdio_filecount + // [1786] phi display_frame_char::return#12 = $6e [phi:display_frame_char::@1->display_frame_char::@return#0] -- vbum1=vbuc1 + lda #$6e + sta return + rts + // [1786] phi from display_frame_char::@2 to display_frame_char::@return [phi:display_frame_char::@2->display_frame_char::@return] + __b3: + // [1786] phi display_frame_char::return#12 = $6d [phi:display_frame_char::@2->display_frame_char::@return#0] -- vbum1=vbuc1 + lda #$6d + sta return + rts + // [1786] phi from display_frame_char::@3 to display_frame_char::@return [phi:display_frame_char::@3->display_frame_char::@return] + __b4: + // [1786] phi display_frame_char::return#12 = $7d [phi:display_frame_char::@3->display_frame_char::@return#0] -- vbum1=vbuc1 + lda #$7d + sta return + rts + // [1786] phi from display_frame_char::@4 to display_frame_char::@return [phi:display_frame_char::@4->display_frame_char::@return] + __b5: + // [1786] phi display_frame_char::return#12 = $40 [phi:display_frame_char::@4->display_frame_char::@return#0] -- vbum1=vbuc1 + lda #$40 + sta return + rts + // [1786] phi from display_frame_char::@5 to display_frame_char::@return [phi:display_frame_char::@5->display_frame_char::@return] + __b6: + // [1786] phi display_frame_char::return#12 = $5d [phi:display_frame_char::@5->display_frame_char::@return#0] -- vbum1=vbuc1 + lda #$5d + sta return + rts + // [1786] phi from display_frame_char::@6 to display_frame_char::@return [phi:display_frame_char::@6->display_frame_char::@return] + __b7: + // [1786] phi display_frame_char::return#12 = $6b [phi:display_frame_char::@6->display_frame_char::@return#0] -- vbum1=vbuc1 + lda #$6b + sta return + rts + // [1786] phi from display_frame_char::@7 to display_frame_char::@return [phi:display_frame_char::@7->display_frame_char::@return] + __b8: + // [1786] phi display_frame_char::return#12 = $73 [phi:display_frame_char::@7->display_frame_char::@return#0] -- vbum1=vbuc1 + lda #$73 + sta return + rts + // [1786] phi from display_frame_char::@8 to display_frame_char::@return [phi:display_frame_char::@8->display_frame_char::@return] + __b9: + // [1786] phi display_frame_char::return#12 = $72 [phi:display_frame_char::@8->display_frame_char::@return#0] -- vbum1=vbuc1 + lda #$72 + sta return + rts + // [1786] phi from display_frame_char::@9 to display_frame_char::@return [phi:display_frame_char::@9->display_frame_char::@return] + __b10: + // [1786] phi display_frame_char::return#12 = $71 [phi:display_frame_char::@9->display_frame_char::@return#0] -- vbum1=vbuc1 + lda #$71 + sta return + // display_frame_char::@return + // } + // [1787] return rts .segment Data - cbm_k_chkin1_channel: .byte 0 - cbm_k_chkin1_status: .byte 0 - cbm_k_readst1_status: .byte 0 - cbm_k_close1_channel: .byte 0 - cbm_k_readst2_status: .byte 0 - sp: .byte 0 - cbm_k_readst1_return: .byte 0 - cbm_k_readst2_return: .byte 0 -} -.segment Code - // display_action_text_reading -// void display_action_text_reading(__zp($50) char *action, __zp($70) char *file, __mem() unsigned long bytes, __mem() unsigned long size, __mem() char bram_bank, __zp($72) char *bram_ptr) -display_action_text_reading: { - .label action = $50 - .label bram_ptr = $72 - .label file = $70 - // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) - // [2581] call snprintf_init - // [1205] phi from display_action_text_reading to snprintf_init [phi:display_action_text_reading->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:display_action_text_reading->snprintf_init#0] -- pbuz1=pbuc1 - lda #info_text - sta.z snprintf_init.s+1 - jsr snprintf_init - // display_action_text_reading::@1 - // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) - // [2582] printf_string::str#14 = display_action_text_reading::action#3 - // [2583] call printf_string - // [1219] phi from display_action_text_reading::@1 to printf_string [phi:display_action_text_reading::@1->printf_string] - // [1219] phi printf_string::putc#26 = &snputc [phi:display_action_text_reading::@1->printf_string#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#14 [phi:display_action_text_reading::@1->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 0 [phi:display_action_text_reading::@1->printf_string#2] -- vbum1=vbuc1 - lda #0 - sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = 0 [phi:display_action_text_reading::@1->printf_string#3] -- vbum1=vbuc1 - sta printf_string.format_min_length - jsr printf_string - // [2584] phi from display_action_text_reading::@1 to display_action_text_reading::@2 [phi:display_action_text_reading::@1->display_action_text_reading::@2] - // display_action_text_reading::@2 - // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) - // [2585] call printf_str - // [1210] phi from display_action_text_reading::@2 to printf_str [phi:display_action_text_reading::@2->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:display_action_text_reading::@2->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s4 [phi:display_action_text_reading::@2->printf_str#1] -- pbuz1=pbuc1 - lda #s4 - sta.z printf_str.s+1 - jsr printf_str - // display_action_text_reading::@3 - // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) - // [2586] printf_string::str#15 = display_action_text_reading::file#3 -- pbuz1=pbuz2 - lda.z file - sta.z printf_string.str - lda.z file+1 - sta.z printf_string.str+1 - // [2587] call printf_string - // [1219] phi from display_action_text_reading::@3 to printf_string [phi:display_action_text_reading::@3->printf_string] - // [1219] phi printf_string::putc#26 = &snputc [phi:display_action_text_reading::@3->printf_string#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#15 [phi:display_action_text_reading::@3->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 0 [phi:display_action_text_reading::@3->printf_string#2] -- vbum1=vbuc1 - lda #0 - sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = 0 [phi:display_action_text_reading::@3->printf_string#3] -- vbum1=vbuc1 - sta printf_string.format_min_length - jsr printf_string - // [2588] phi from display_action_text_reading::@3 to display_action_text_reading::@4 [phi:display_action_text_reading::@3->display_action_text_reading::@4] - // display_action_text_reading::@4 - // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) - // [2589] call printf_str - // [1210] phi from display_action_text_reading::@4 to printf_str [phi:display_action_text_reading::@4->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:display_action_text_reading::@4->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s2 [phi:display_action_text_reading::@4->printf_str#1] -- pbuz1=pbuc1 - lda #<@s2 - sta.z printf_str.s - lda #>@s2 - sta.z printf_str.s+1 - jsr printf_str - // display_action_text_reading::@5 - // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) - // [2590] printf_ulong::uvalue#5 = display_action_text_reading::bytes#3 - // [2591] call printf_ulong - // [1741] phi from display_action_text_reading::@5 to printf_ulong [phi:display_action_text_reading::@5->printf_ulong] - // [1741] phi printf_ulong::format_zero_padding#15 = 1 [phi:display_action_text_reading::@5->printf_ulong#0] -- vbum1=vbuc1 - lda #1 - sta printf_ulong.format_zero_padding - // [1741] phi printf_ulong::format_min_length#15 = 5 [phi:display_action_text_reading::@5->printf_ulong#1] -- vbum1=vbuc1 - lda #5 - sta printf_ulong.format_min_length - // [1741] phi printf_ulong::format_radix#15 = HEXADECIMAL [phi:display_action_text_reading::@5->printf_ulong#2] -- vbum1=vbuc1 - lda #HEXADECIMAL - sta printf_ulong.format_radix - // [1741] phi printf_ulong::uvalue#15 = printf_ulong::uvalue#5 [phi:display_action_text_reading::@5->printf_ulong#3] -- register_copy - jsr printf_ulong - // [2592] phi from display_action_text_reading::@5 to display_action_text_reading::@6 [phi:display_action_text_reading::@5->display_action_text_reading::@6] - // display_action_text_reading::@6 - // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) - // [2593] call printf_str - // [1210] phi from display_action_text_reading::@6 to printf_str [phi:display_action_text_reading::@6->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:display_action_text_reading::@6->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = display_action_text_reading::s2 [phi:display_action_text_reading::@6->printf_str#1] -- pbuz1=pbuc1 - lda #s2 - sta.z printf_str.s+1 - jsr printf_str - // display_action_text_reading::@7 - // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) - // [2594] printf_ulong::uvalue#6 = display_action_text_reading::size#10 -- vdum1=vdum2 - lda size - sta printf_ulong.uvalue - lda size+1 - sta printf_ulong.uvalue+1 - lda size+2 - sta printf_ulong.uvalue+2 - lda size+3 - sta printf_ulong.uvalue+3 - // [2595] call printf_ulong - // [1741] phi from display_action_text_reading::@7 to printf_ulong [phi:display_action_text_reading::@7->printf_ulong] - // [1741] phi printf_ulong::format_zero_padding#15 = 1 [phi:display_action_text_reading::@7->printf_ulong#0] -- vbum1=vbuc1 - lda #1 - sta printf_ulong.format_zero_padding - // [1741] phi printf_ulong::format_min_length#15 = 5 [phi:display_action_text_reading::@7->printf_ulong#1] -- vbum1=vbuc1 - lda #5 - sta printf_ulong.format_min_length - // [1741] phi printf_ulong::format_radix#15 = HEXADECIMAL [phi:display_action_text_reading::@7->printf_ulong#2] -- vbum1=vbuc1 - lda #HEXADECIMAL - sta printf_ulong.format_radix - // [1741] phi printf_ulong::uvalue#15 = printf_ulong::uvalue#6 [phi:display_action_text_reading::@7->printf_ulong#3] -- register_copy - jsr printf_ulong - // [2596] phi from display_action_text_reading::@7 to display_action_text_reading::@8 [phi:display_action_text_reading::@7->display_action_text_reading::@8] - // display_action_text_reading::@8 - // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) - // [2597] call printf_str - // [1210] phi from display_action_text_reading::@8 to printf_str [phi:display_action_text_reading::@8->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:display_action_text_reading::@8->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = display_action_text_reading::s3 [phi:display_action_text_reading::@8->printf_str#1] -- pbuz1=pbuc1 - lda #s3 - sta.z printf_str.s+1 - jsr printf_str - // display_action_text_reading::@9 - // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) - // [2598] printf_uchar::uvalue#6 = display_action_text_reading::bram_bank#10 -- vbum1=vbum2 - lda bram_bank - sta printf_uchar.uvalue - // [2599] call printf_uchar - // [1346] phi from display_action_text_reading::@9 to printf_uchar [phi:display_action_text_reading::@9->printf_uchar] - // [1346] phi printf_uchar::format_zero_padding#18 = 1 [phi:display_action_text_reading::@9->printf_uchar#0] -- vbum1=vbuc1 - lda #1 - sta printf_uchar.format_zero_padding - // [1346] phi printf_uchar::format_min_length#18 = 2 [phi:display_action_text_reading::@9->printf_uchar#1] -- vbum1=vbuc1 - lda #2 - sta printf_uchar.format_min_length - // [1346] phi printf_uchar::putc#18 = &snputc [phi:display_action_text_reading::@9->printf_uchar#2] -- pprz1=pprc1 - lda #snputc - sta.z printf_uchar.putc+1 - // [1346] phi printf_uchar::format_radix#18 = HEXADECIMAL [phi:display_action_text_reading::@9->printf_uchar#3] -- vbum1=vbuc1 - lda #HEXADECIMAL - sta printf_uchar.format_radix - // [1346] phi printf_uchar::uvalue#18 = printf_uchar::uvalue#6 [phi:display_action_text_reading::@9->printf_uchar#4] -- register_copy - jsr printf_uchar - // [2600] phi from display_action_text_reading::@9 to display_action_text_reading::@10 [phi:display_action_text_reading::@9->display_action_text_reading::@10] - // display_action_text_reading::@10 - // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) - // [2601] call printf_str - // [1210] phi from display_action_text_reading::@10 to printf_str [phi:display_action_text_reading::@10->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:display_action_text_reading::@10->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s2 [phi:display_action_text_reading::@10->printf_str#1] -- pbuz1=pbuc1 - lda #<@s2 - sta.z printf_str.s - lda #>@s2 - sta.z printf_str.s+1 - jsr printf_str - // display_action_text_reading::@11 - // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) - // [2602] printf_uint::uvalue#3 = (unsigned int)display_action_text_reading::bram_ptr#10 -- vwum1=vwuz2 - lda.z bram_ptr - sta printf_uint.uvalue - lda.z bram_ptr+1 - sta printf_uint.uvalue+1 - // [2603] call printf_uint - // [2086] phi from display_action_text_reading::@11 to printf_uint [phi:display_action_text_reading::@11->printf_uint] - // [2086] phi printf_uint::format_zero_padding#10 = 1 [phi:display_action_text_reading::@11->printf_uint#0] -- vbum1=vbuc1 - lda #1 - sta printf_uint.format_zero_padding - // [2086] phi printf_uint::format_min_length#10 = 4 [phi:display_action_text_reading::@11->printf_uint#1] -- vbum1=vbuc1 - lda #4 - sta printf_uint.format_min_length - // [2086] phi printf_uint::putc#10 = &snputc [phi:display_action_text_reading::@11->printf_uint#2] -- pprz1=pprc1 - lda #snputc - sta.z printf_uint.putc+1 - // [2086] phi printf_uint::format_radix#10 = HEXADECIMAL [phi:display_action_text_reading::@11->printf_uint#3] -- vbum1=vbuc1 - lda #HEXADECIMAL - sta printf_uint.format_radix - // [2086] phi printf_uint::uvalue#10 = printf_uint::uvalue#3 [phi:display_action_text_reading::@11->printf_uint#4] -- register_copy - jsr printf_uint - // [2604] phi from display_action_text_reading::@11 to display_action_text_reading::@12 [phi:display_action_text_reading::@11->display_action_text_reading::@12] - // display_action_text_reading::@12 - // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) - // [2605] call printf_str - // [1210] phi from display_action_text_reading::@12 to printf_str [phi:display_action_text_reading::@12->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:display_action_text_reading::@12->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s6 [phi:display_action_text_reading::@12->printf_str#1] -- pbuz1=pbuc1 - lda #s6 - sta.z printf_str.s+1 - jsr printf_str - // display_action_text_reading::@13 - // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) - // [2606] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 - lda #0 - pha - // [2607] callexecute snputc -- call_vprc1 - jsr snputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // display_action_text(info_text) - // [2609] call display_action_text - // [1357] phi from display_action_text_reading::@13 to display_action_text [phi:display_action_text_reading::@13->display_action_text] - // [1357] phi display_action_text::info_text#25 = info_text [phi:display_action_text_reading::@13->display_action_text#0] -- pbuz1=pbuc1 - lda #info_text - sta.z display_action_text.info_text+1 - jsr display_action_text - // display_action_text_reading::@return - // } - // [2610] return - rts - .segment Data - s2: .text "/" - .byte 0 - s3: .text " -> RAM:" - .byte 0 - .label bytes = printf_ulong.uvalue - bram_bank: .byte 0 - size: .dword 0 + .label return = cputcxy.c + .label mask = display_frame_maskxy.return } .segment Code // strlen // Computes the length of the string str up to but not including the terminating null character. -// __mem() unsigned int strlen(__zp($31) char *str) +// __mem() unsigned int strlen(__zp($2d) char *str) strlen: { - .label str = $31 - // [2612] phi from strlen to strlen::@1 [phi:strlen->strlen::@1] - // [2612] phi strlen::len#2 = 0 [phi:strlen->strlen::@1#0] -- vwum1=vwuc1 + .label str = $2d + // [1789] phi from strlen to strlen::@1 [phi:strlen->strlen::@1] + // [1789] phi strlen::len#2 = 0 [phi:strlen->strlen::@1#0] -- vwum1=vwuc1 lda #<0 sta len sta len+1 - // [2612] phi strlen::str#6 = strlen::str#8 [phi:strlen->strlen::@1#1] -- register_copy + // [1789] phi strlen::str#6 = strlen::str#8 [phi:strlen->strlen::@1#1] -- register_copy // strlen::@1 __b1: // while(*str) - // [2613] if(0!=*strlen::str#6) goto strlen::@2 -- 0_neq__deref_pbuz1_then_la1 + // [1790] if(0!=*strlen::str#6) goto strlen::@2 -- 0_neq__deref_pbuz1_then_la1 ldy #0 lda (str),y cmp #0 bne __b2 // strlen::@return // } - // [2614] return + // [1791] return rts // strlen::@2 __b2: // len++; - // [2615] strlen::len#1 = ++ strlen::len#2 -- vwum1=_inc_vwum1 + // [1792] strlen::len#1 = ++ strlen::len#2 -- vwum1=_inc_vwum1 inc len bne !+ inc len+1 !: // str++; - // [2616] strlen::str#1 = ++ strlen::str#6 -- pbuz1=_inc_pbuz1 + // [1793] strlen::str#1 = ++ strlen::str#6 -- pbuz1=_inc_pbuz1 inc.z str bne !+ inc.z str+1 !: - // [2612] phi from strlen::@2 to strlen::@1 [phi:strlen::@2->strlen::@1] - // [2612] phi strlen::len#2 = strlen::len#1 [phi:strlen::@2->strlen::@1#0] -- register_copy - // [2612] phi strlen::str#6 = strlen::str#1 [phi:strlen::@2->strlen::@1#1] -- register_copy + // [1789] phi from strlen::@2 to strlen::@1 [phi:strlen::@2->strlen::@1] + // [1789] phi strlen::len#2 = strlen::len#1 [phi:strlen::@2->strlen::@1#0] -- register_copy + // [1789] phi strlen::str#6 = strlen::str#1 [phi:strlen::@2->strlen::@1#1] -- register_copy jmp __b1 .segment Data .label return = len @@ -17163,2157 +11353,2106 @@ strlen: { .segment Code // printf_padding // Print a padding char a number of times -// void printf_padding(__zp($31) void (*putc)(char), __mem() char pad, __mem() char length) +// void printf_padding(__zp($2d) void (*putc)(char), __mem() char pad, __mem() char length) printf_padding: { - .label putc = $31 - // [2618] phi from printf_padding to printf_padding::@1 [phi:printf_padding->printf_padding::@1] - // [2618] phi printf_padding::i#2 = 0 [phi:printf_padding->printf_padding::@1#0] -- vbum1=vbuc1 + .label putc = $2d + // [1795] phi from printf_padding to printf_padding::@1 [phi:printf_padding->printf_padding::@1] + // [1795] phi printf_padding::i#2 = 0 [phi:printf_padding->printf_padding::@1#0] -- vbum1=vbuc1 lda #0 sta i // printf_padding::@1 __b1: // for(char i=0;iprintf_padding::@1] - // [2618] phi printf_padding::i#2 = printf_padding::i#1 [phi:printf_padding::@3->printf_padding::@1#0] -- register_copy + // [1795] phi from printf_padding::@3 to printf_padding::@1 [phi:printf_padding::@3->printf_padding::@1] + // [1795] phi printf_padding::i#2 = printf_padding::i#1 [phi:printf_padding::@3->printf_padding::@1#0] -- register_copy jmp __b1 // Outside Flow - icall38: + icall19: jmp (putc) .segment Data i: .byte 0 length: .byte 0 pad: .byte 0 } -.segment CodeVera - // vera_read -// __mem() unsigned long vera_read(__mem() char info_status) -vera_read: { - .const bank_set_brom1_bank = 0 - .label fp = $c8 - // We start for VERA from 0x1:0xA000. - .label vera_bram_ptr = $a9 - .label vera_action_text = $64 - // vera_read::bank_set_bram1 - // BRAM = bank - // [2626] BRAM = 1 -- vbuz1=vbuc1 - lda #1 - sta.z BRAM - // vera_read::@16 - // if(info_status == STATUS_READING) - // [2627] if(vera_read::info_status#12==STATUS_READING) goto vera_read::@1 -- vbum1_eq_vbuc1_then_la1 - lda #STATUS_READING - cmp info_status - beq __b1 - // [2629] phi from vera_read::@16 to vera_read::@2 [phi:vera_read::@16->vera_read::@2] - // [2629] phi vera_read::vera_bram_bank#14 = 0 [phi:vera_read::@16->vera_read::@2#0] -- vbum1=vbuc1 - lda #0 - sta vera_bram_bank - // [2629] phi vera_read::vera_action_text#10 = smc_action_text#2 [phi:vera_read::@16->vera_read::@2#1] -- pbuz1=pbuc1 - lda #smc_action_text_1 - sta.z vera_action_text+1 - jmp __b2 - // [2628] phi from vera_read::@16 to vera_read::@1 [phi:vera_read::@16->vera_read::@1] - // vera_read::@1 +.segment Code + // display_chip_led +/** + * @brief Print the colored led of a chip figure. + * + * @param x Start X + * @param y Start Y + * @param w width + * @param tc Fore color + * @param bc Back color + */ +// void display_chip_led(__mem() char x, char y, __mem() char w, __mem() char tc, char bc) +display_chip_led: { + // textcolor(tc) + // [1803] textcolor::color#11 = display_chip_led::tc#3 -- vbum1=vbum2 + lda tc + sta textcolor.color + // [1804] call textcolor + // [439] phi from display_chip_led to textcolor [phi:display_chip_led->textcolor] + // [439] phi textcolor::color#21 = textcolor::color#11 [phi:display_chip_led->textcolor#0] -- register_copy + jsr textcolor + // [1805] phi from display_chip_led to display_chip_led::@3 [phi:display_chip_led->display_chip_led::@3] + // display_chip_led::@3 + // bgcolor(bc) + // [1806] call bgcolor + // [444] phi from display_chip_led::@3 to bgcolor [phi:display_chip_led::@3->bgcolor] + // [444] phi bgcolor::color#15 = BLUE [phi:display_chip_led::@3->bgcolor#0] -- vbum1=vbuc1 + lda #BLUE + sta bgcolor.color + jsr bgcolor + // [1807] phi from display_chip_led::@3 display_chip_led::@5 to display_chip_led::@1 [phi:display_chip_led::@3/display_chip_led::@5->display_chip_led::@1] + // [1807] phi display_chip_led::w#4 = display_chip_led::w#7 [phi:display_chip_led::@3/display_chip_led::@5->display_chip_led::@1#0] -- register_copy + // [1807] phi display_chip_led::x#4 = display_chip_led::x#7 [phi:display_chip_led::@3/display_chip_led::@5->display_chip_led::@1#1] -- register_copy + // display_chip_led::@1 __b1: - // [2629] phi from vera_read::@1 to vera_read::@2 [phi:vera_read::@1->vera_read::@2] - // [2629] phi vera_read::vera_bram_bank#14 = 1 [phi:vera_read::@1->vera_read::@2#0] -- vbum1=vbuc1 - lda #1 - sta vera_bram_bank - // [2629] phi vera_read::vera_action_text#10 = smc_action_text#1 [phi:vera_read::@1->vera_read::@2#1] -- pbuz1=pbuc1 - lda #smc_action_text - sta.z vera_action_text+1 - // vera_read::@2 - __b2: - // vera_read::bank_set_brom1 - // BROM = bank - // [2630] BROM = vera_read::bank_set_brom1_bank#0 -- vbuz1=vbuc1 - lda #bank_set_brom1_bank - sta.z BROM - // [2631] phi from vera_read::bank_set_brom1 to vera_read::@17 [phi:vera_read::bank_set_brom1->vera_read::@17] - // vera_read::@17 - // display_action_text("Opening VERA.BIN from SD card ...") - // [2632] call display_action_text - // [1357] phi from vera_read::@17 to display_action_text [phi:vera_read::@17->display_action_text] - // [1357] phi display_action_text::info_text#25 = vera_read::info_text [phi:vera_read::@17->display_action_text#0] -- pbuz1=pbuc1 - lda #info_text - sta.z display_action_text.info_text+1 - jsr display_action_text - // [2633] phi from vera_read::@17 to vera_read::@19 [phi:vera_read::@17->vera_read::@19] - // vera_read::@19 - // FILE *fp = fopen("VERA.BIN", "r") - // [2634] call fopen - // [2416] phi from vera_read::@19 to fopen [phi:vera_read::@19->fopen] - // [2416] phi __errno#473 = __errno#100 [phi:vera_read::@19->fopen#0] -- register_copy - // [2416] phi fopen::pathtoken#0 = vera_read::path [phi:vera_read::@19->fopen#1] -- pbuz1=pbuc1 - lda #path - sta.z fopen.pathtoken+1 - // [2416] phi __stdio_filecount#27 = __stdio_filecount#123 [phi:vera_read::@19->fopen#2] -- register_copy - jsr fopen - // FILE *fp = fopen("VERA.BIN", "r") - // [2635] fopen::return#3 = fopen::return#2 - // vera_read::@20 - // [2636] vera_read::fp#0 = fopen::return#3 -- pssz1=pssz2 - lda.z fopen.return - sta.z fp - lda.z fopen.return+1 - sta.z fp+1 - // if (fp) - // [2637] if((struct $2 *)0==vera_read::fp#0) goto vera_read::@3 -- pssc1_eq_pssz1_then_la1 - lda.z fp - cmp #<0 - bne !+ - lda.z fp+1 - cmp #>0 - beq __b4 - !: - // [2638] phi from vera_read::@20 to vera_read::@4 [phi:vera_read::@20->vera_read::@4] - // vera_read::@4 - // gotoxy(x, y) - // [2639] call gotoxy - // [802] phi from vera_read::@4 to gotoxy [phi:vera_read::@4->gotoxy] - // [802] phi gotoxy::y#37 = PROGRESS_Y [phi:vera_read::@4->gotoxy#0] -- vbum1=vbuc1 - lda #PROGRESS_Y - sta gotoxy.y - // [802] phi gotoxy::x#37 = PROGRESS_X [phi:vera_read::@4->gotoxy#1] -- vbum1=vbuc1 - lda #PROGRESS_X - sta gotoxy.x - jsr gotoxy - // [2640] phi from vera_read::@4 to vera_read::@5 [phi:vera_read::@4->vera_read::@5] - // [2640] phi vera_read::y#11 = PROGRESS_Y [phi:vera_read::@4->vera_read::@5#0] -- vbum1=vbuc1 - lda #PROGRESS_Y - sta y - // [2640] phi vera_read::progress_row_current#10 = 0 [phi:vera_read::@4->vera_read::@5#1] -- vwum1=vwuc1 - lda #<0 - sta progress_row_current - sta progress_row_current+1 - // [2640] phi vera_read::vera_bram_ptr#13 = (char *)$a000 [phi:vera_read::@4->vera_read::@5#2] -- pbuz1=pbuc1 - lda #<$a000 - sta.z vera_bram_ptr - lda #>$a000 - sta.z vera_bram_ptr+1 - // [2640] phi vera_read::vera_bram_bank#10 = vera_read::vera_bram_bank#14 [phi:vera_read::@4->vera_read::@5#3] -- register_copy - // [2640] phi vera_read::vera_file_size#11 = 0 [phi:vera_read::@4->vera_read::@5#4] -- vdum1=vduc1 - lda #<0 - sta vera_file_size - sta vera_file_size+1 - lda #<0>>$10 - sta vera_file_size+2 - lda #>0>>$10 - sta vera_file_size+3 - // vera_read::@5 - __b5: - // while (vera_file_size < vera_size) - // [2641] if(vera_read::vera_file_size#11vera_size>>$10 - bcc __b6 - bne !+ - lda vera_file_size+2 - cmp #>$10 - bcc __b6 - bne !+ - lda vera_file_size+1 - cmp #>vera_size - bcc __b6 - bne !+ - lda vera_file_size - cmp #fclose] - // [2551] phi fclose::stream#3 = fclose::stream#0 [phi:vera_read::@9->fclose#0] -- register_copy - jsr fclose - // [2644] phi from vera_read::@9 to vera_read::@3 [phi:vera_read::@9->vera_read::@3] - // [2644] phi __stdio_filecount#36 = __stdio_filecount#2 [phi:vera_read::@9->vera_read::@3#0] -- register_copy - // [2644] phi vera_read::return#0 = vera_read::vera_file_size#11 [phi:vera_read::@9->vera_read::@3#1] -- register_copy - rts - // [2644] phi from vera_read::@20 to vera_read::@3 [phi:vera_read::@20->vera_read::@3] - __b4: - // [2644] phi __stdio_filecount#36 = __stdio_filecount#1 [phi:vera_read::@20->vera_read::@3#0] -- register_copy - // [2644] phi vera_read::return#0 = 0 [phi:vera_read::@20->vera_read::@3#1] -- vdum1=vduc1 - lda #<0 - sta return - sta return+1 - lda #<0>>$10 - sta return+2 - lda #>0>>$10 - sta return+3 - // vera_read::@3 - // vera_read::@return + // cputcxy(x, y, 0x6F) + // [1808] cputcxy::x#11 = display_chip_led::x#4 -- vbum1=vbum2 + lda x + sta cputcxy.x + // [1809] call cputcxy + // [1346] phi from display_chip_led::@1 to cputcxy [phi:display_chip_led::@1->cputcxy] + // [1346] phi cputcxy::c#15 = $6f [phi:display_chip_led::@1->cputcxy#0] -- vbum1=vbuc1 + lda #$6f + sta cputcxy.c + // [1346] phi cputcxy::y#15 = 3 [phi:display_chip_led::@1->cputcxy#1] -- vbum1=vbuc1 + lda #3 + sta cputcxy.y + // [1346] phi cputcxy::x#15 = cputcxy::x#11 [phi:display_chip_led::@1->cputcxy#2] -- register_copy + jsr cputcxy + // display_chip_led::@4 + // cputcxy(x, y+1, 0x77) + // [1810] cputcxy::x#12 = display_chip_led::x#4 -- vbum1=vbum2 + lda x + sta cputcxy.x + // [1811] call cputcxy + // [1346] phi from display_chip_led::@4 to cputcxy [phi:display_chip_led::@4->cputcxy] + // [1346] phi cputcxy::c#15 = $77 [phi:display_chip_led::@4->cputcxy#0] -- vbum1=vbuc1 + lda #$77 + sta cputcxy.c + // [1346] phi cputcxy::y#15 = 3+1 [phi:display_chip_led::@4->cputcxy#1] -- vbum1=vbuc1 + lda #3+1 + sta cputcxy.y + // [1346] phi cputcxy::x#15 = cputcxy::x#12 [phi:display_chip_led::@4->cputcxy#2] -- register_copy + jsr cputcxy + // display_chip_led::@5 + // x++; + // [1812] display_chip_led::x#0 = ++ display_chip_led::x#4 -- vbum1=_inc_vbum1 + inc x + // while(--w) + // [1813] display_chip_led::w#0 = -- display_chip_led::w#4 -- vbum1=_dec_vbum1 + dec w + // [1814] if(0!=display_chip_led::w#0) goto display_chip_led::@1 -- 0_neq_vbum1_then_la1 + lda w + bne __b1 + // [1815] phi from display_chip_led::@5 to display_chip_led::@2 [phi:display_chip_led::@5->display_chip_led::@2] + // display_chip_led::@2 + // textcolor(WHITE) + // [1816] call textcolor + // [439] phi from display_chip_led::@2 to textcolor [phi:display_chip_led::@2->textcolor] + // [439] phi textcolor::color#21 = WHITE [phi:display_chip_led::@2->textcolor#0] -- vbum1=vbuc1 + lda #WHITE + sta textcolor.color + jsr textcolor + // [1817] phi from display_chip_led::@2 to display_chip_led::@6 [phi:display_chip_led::@2->display_chip_led::@6] + // display_chip_led::@6 + // bgcolor(BLUE) + // [1818] call bgcolor + // [444] phi from display_chip_led::@6 to bgcolor [phi:display_chip_led::@6->bgcolor] + // [444] phi bgcolor::color#15 = BLUE [phi:display_chip_led::@6->bgcolor#0] -- vbum1=vbuc1 + lda #BLUE + sta bgcolor.color + jsr bgcolor + // display_chip_led::@return // } - // [2645] return + // [1819] return rts - // vera_read::@6 - __b6: - // if(info_status == STATUS_CHECKING) - // [2646] if(vera_read::info_status#12!=STATUS_CHECKING) goto vera_read::@23 -- vbum1_neq_vbuc1_then_la1 - lda #STATUS_CHECKING - cmp info_status - bne __b7 - // [2648] phi from vera_read::@6 to vera_read::@7 [phi:vera_read::@6->vera_read::@7] - // [2648] phi vera_read::vera_bram_ptr#10 = (char *) 1024 [phi:vera_read::@6->vera_read::@7#0] -- pbuz1=pbuc1 - lda #<$400 - sta.z vera_bram_ptr - lda #>$400 - sta.z vera_bram_ptr+1 - // [2647] phi from vera_read::@6 to vera_read::@23 [phi:vera_read::@6->vera_read::@23] - // vera_read::@23 - // [2648] phi from vera_read::@23 to vera_read::@7 [phi:vera_read::@23->vera_read::@7] - // [2648] phi vera_read::vera_bram_ptr#10 = vera_read::vera_bram_ptr#13 [phi:vera_read::@23->vera_read::@7#0] -- register_copy - // vera_read::@7 - __b7: - // display_action_text_reading(vera_action_text, "VERA.BIN", vera_file_size, vera_size, vera_bram_bank, vera_bram_ptr) - // [2649] display_action_text_reading::action#0 = vera_read::vera_action_text#10 -- pbuz1=pbuz2 - lda.z vera_action_text - sta.z display_action_text_reading.action - lda.z vera_action_text+1 - sta.z display_action_text_reading.action+1 - // [2650] display_action_text_reading::bytes#0 = vera_read::vera_file_size#11 -- vdum1=vdum2 - lda vera_file_size - sta display_action_text_reading.bytes - lda vera_file_size+1 - sta display_action_text_reading.bytes+1 - lda vera_file_size+2 - sta display_action_text_reading.bytes+2 - lda vera_file_size+3 - sta display_action_text_reading.bytes+3 - // [2651] display_action_text_reading::bram_bank#0 = vera_read::vera_bram_bank#10 -- vbum1=vbum2 - lda vera_bram_bank - sta display_action_text_reading.bram_bank - // [2652] display_action_text_reading::bram_ptr#0 = vera_read::vera_bram_ptr#10 -- pbuz1=pbuz2 - lda.z vera_bram_ptr - sta.z display_action_text_reading.bram_ptr - lda.z vera_bram_ptr+1 - sta.z display_action_text_reading.bram_ptr+1 - // [2653] call display_action_text_reading - // [2580] phi from vera_read::@7 to display_action_text_reading [phi:vera_read::@7->display_action_text_reading] - // [2580] phi display_action_text_reading::bram_ptr#10 = display_action_text_reading::bram_ptr#0 [phi:vera_read::@7->display_action_text_reading#0] -- register_copy - // [2580] phi display_action_text_reading::bram_bank#10 = display_action_text_reading::bram_bank#0 [phi:vera_read::@7->display_action_text_reading#1] -- register_copy - // [2580] phi display_action_text_reading::size#10 = vera_size [phi:vera_read::@7->display_action_text_reading#2] -- vdum1=vduc1 - lda #vera_size - sta display_action_text_reading.size+1 - lda #>$10 - sta display_action_text_reading.size+2 - lda #>vera_size>>$10 - sta display_action_text_reading.size+3 - // [2580] phi display_action_text_reading::bytes#3 = display_action_text_reading::bytes#0 [phi:vera_read::@7->display_action_text_reading#3] -- register_copy - // [2580] phi display_action_text_reading::file#3 = vera_read::path [phi:vera_read::@7->display_action_text_reading#4] -- pbuz1=pbuc1 - lda #path - sta.z display_action_text_reading.file+1 - // [2580] phi display_action_text_reading::action#3 = display_action_text_reading::action#0 [phi:vera_read::@7->display_action_text_reading#5] -- register_copy - jsr display_action_text_reading - // vera_read::bank_set_bram2 - // BRAM = bank - // [2654] BRAM = vera_read::vera_bram_bank#10 -- vbuz1=vbum2 - lda vera_bram_bank - sta.z BRAM - // vera_read::@18 - // unsigned int vera_package_read = fgets(vera_bram_ptr, VERA_PROGRESS_CELL, fp) - // [2655] fgets::ptr#2 = vera_read::vera_bram_ptr#10 -- pbuz1=pbuz2 - lda.z vera_bram_ptr - sta.z fgets.ptr - lda.z vera_bram_ptr+1 - sta.z fgets.ptr+1 - // [2656] fgets::stream#0 = vera_read::fp#0 -- pssz1=pssz2 - lda.z fp - sta.z fgets.stream - lda.z fp+1 - sta.z fgets.stream+1 - // [2657] call fgets - // [2497] phi from vera_read::@18 to fgets [phi:vera_read::@18->fgets] - // [2497] phi fgets::ptr#14 = fgets::ptr#2 [phi:vera_read::@18->fgets#0] -- register_copy - // [2497] phi fgets::size#10 = VERA_PROGRESS_CELL [phi:vera_read::@18->fgets#1] -- vwum1=vbuc1 - lda #VERA_PROGRESS_CELL - sta fgets.size+1 - // [2497] phi fgets::stream#4 = fgets::stream#0 [phi:vera_read::@18->fgets#2] -- register_copy - jsr fgets - // unsigned int vera_package_read = fgets(vera_bram_ptr, VERA_PROGRESS_CELL, fp) - // [2658] fgets::return#10 = fgets::return#1 - // vera_read::@21 - // [2659] vera_read::vera_package_read#0 = fgets::return#10 -- vwum1=vwum2 - lda fgets.return - sta vera_package_read - lda fgets.return+1 - sta vera_package_read+1 - // if (!vera_package_read) - // [2660] if(0!=vera_read::vera_package_read#0) goto vera_read::@8 -- 0_neq_vwum1_then_la1 - lda vera_package_read - ora vera_package_read+1 - bne __b8 - jmp __b9 - // vera_read::@8 - __b8: - // if (progress_row_current == VERA_PROGRESS_ROW) - // [2661] if(vera_read::progress_row_current#10!=VERA_PROGRESS_ROW) goto vera_read::@10 -- vwum1_neq_vwuc1_then_la1 - lda progress_row_current+1 - cmp #>VERA_PROGRESS_ROW - bne __b10 - lda progress_row_current - cmp #gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#6 [phi:vera_read::@13->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = PROGRESS_X [phi:vera_read::@13->gotoxy#1] -- vbum1=vbuc1 - lda #PROGRESS_X - sta gotoxy.x + // [1823] call gotoxy + // [457] phi from display_chip_line to gotoxy [phi:display_chip_line->gotoxy] + // [457] phi gotoxy::y#26 = gotoxy::y#11 [phi:display_chip_line->gotoxy#0] -- register_copy + // [457] phi gotoxy::x#26 = gotoxy::x#11 [phi:display_chip_line->gotoxy#1] -- register_copy jsr gotoxy - // [2665] phi from vera_read::@13 to vera_read::@10 [phi:vera_read::@13->vera_read::@10] - // [2665] phi vera_read::y#22 = vera_read::y#1 [phi:vera_read::@13->vera_read::@10#0] -- register_copy - // [2665] phi vera_read::progress_row_current#4 = 0 [phi:vera_read::@13->vera_read::@10#1] -- vwum1=vbuc1 - lda #<0 - sta progress_row_current - sta progress_row_current+1 - // [2665] phi from vera_read::@8 to vera_read::@10 [phi:vera_read::@8->vera_read::@10] - // [2665] phi vera_read::y#22 = vera_read::y#11 [phi:vera_read::@8->vera_read::@10#0] -- register_copy - // [2665] phi vera_read::progress_row_current#4 = vera_read::progress_row_current#10 [phi:vera_read::@8->vera_read::@10#1] -- register_copy - // vera_read::@10 - __b10: - // if(info_status == STATUS_READING) - // [2666] if(vera_read::info_status#12!=STATUS_READING) goto vera_read::@11 -- vbum1_neq_vbuc1_then_la1 - lda #STATUS_READING - cmp info_status - bne __b11 - // vera_read::@14 - // cputc('.') - // [2667] stackpush(char) = '.' -- _stackpushbyte_=vbuc1 - lda #'.' + // [1824] phi from display_chip_line to display_chip_line::@4 [phi:display_chip_line->display_chip_line::@4] + // display_chip_line::@4 + // textcolor(GREY) + // [1825] call textcolor + // [439] phi from display_chip_line::@4 to textcolor [phi:display_chip_line::@4->textcolor] + // [439] phi textcolor::color#21 = GREY [phi:display_chip_line::@4->textcolor#0] -- vbum1=vbuc1 + lda #GREY + sta textcolor.color + jsr textcolor + // [1826] phi from display_chip_line::@4 to display_chip_line::@5 [phi:display_chip_line::@4->display_chip_line::@5] + // display_chip_line::@5 + // bgcolor(BLUE) + // [1827] call bgcolor + // [444] phi from display_chip_line::@5 to bgcolor [phi:display_chip_line::@5->bgcolor] + // [444] phi bgcolor::color#15 = BLUE [phi:display_chip_line::@5->bgcolor#0] -- vbum1=vbuc1 + lda #BLUE + sta bgcolor.color + jsr bgcolor + // display_chip_line::@6 + // cputc(VERA_CHR_UR) + // [1828] stackpush(char) = $7c -- _stackpushbyte_=vbuc1 + lda #$7c pha - // [2668] callexecute cputc -- call_vprc1 + // [1829] callexecute cputc -- call_vprc1 jsr cputc // sideeffect stackpullpadding(1) -- _stackpullpadding_1 pla - // vera_read::@11 - __b11: - // vera_bram_ptr += vera_package_read - // [2670] vera_read::vera_bram_ptr#2 = vera_read::vera_bram_ptr#10 + vera_read::vera_package_read#0 -- pbuz1=pbuz1_plus_vwum2 + // textcolor(WHITE) + // [1831] call textcolor + // [439] phi from display_chip_line::@6 to textcolor [phi:display_chip_line::@6->textcolor] + // [439] phi textcolor::color#21 = WHITE [phi:display_chip_line::@6->textcolor#0] -- vbum1=vbuc1 + lda #WHITE + sta textcolor.color + jsr textcolor + // [1832] phi from display_chip_line::@6 to display_chip_line::@7 [phi:display_chip_line::@6->display_chip_line::@7] + // display_chip_line::@7 + // bgcolor(BLACK) + // [1833] call bgcolor + // [444] phi from display_chip_line::@7 to bgcolor [phi:display_chip_line::@7->bgcolor] + // [444] phi bgcolor::color#15 = BLACK [phi:display_chip_line::@7->bgcolor#0] -- vbum1=vbuc1 + lda #BLACK + sta bgcolor.color + jsr bgcolor + // [1834] phi from display_chip_line::@7 to display_chip_line::@1 [phi:display_chip_line::@7->display_chip_line::@1] + // [1834] phi display_chip_line::i#2 = 0 [phi:display_chip_line::@7->display_chip_line::@1#0] -- vbum1=vbuc1 + lda #0 + sta i + // display_chip_line::@1 + __b1: + // for(char i=0; idisplay_chip_line::@3] + // display_chip_line::@3 + // textcolor(GREY) + // [1837] call textcolor + // [439] phi from display_chip_line::@3 to textcolor [phi:display_chip_line::@3->textcolor] + // [439] phi textcolor::color#21 = GREY [phi:display_chip_line::@3->textcolor#0] -- vbum1=vbuc1 + lda #GREY + sta textcolor.color + jsr textcolor + // [1838] phi from display_chip_line::@3 to display_chip_line::@8 [phi:display_chip_line::@3->display_chip_line::@8] + // display_chip_line::@8 + // bgcolor(BLUE) + // [1839] call bgcolor + // [444] phi from display_chip_line::@8 to bgcolor [phi:display_chip_line::@8->bgcolor] + // [444] phi bgcolor::color#15 = BLUE [phi:display_chip_line::@8->bgcolor#0] -- vbum1=vbuc1 + lda #BLUE + sta bgcolor.color + jsr bgcolor + // display_chip_line::@9 + // cputc(VERA_CHR_UL) + // [1840] stackpush(char) = $7e -- _stackpushbyte_=vbuc1 + lda #$7e + pha + // [1841] callexecute cputc -- call_vprc1 + jsr cputc + // sideeffect stackpullpadding(1) -- _stackpullpadding_1 + pla + // textcolor(WHITE) + // [1843] call textcolor + // [439] phi from display_chip_line::@9 to textcolor [phi:display_chip_line::@9->textcolor] + // [439] phi textcolor::color#21 = WHITE [phi:display_chip_line::@9->textcolor#0] -- vbum1=vbuc1 + lda #WHITE + sta textcolor.color + jsr textcolor + // [1844] phi from display_chip_line::@9 to display_chip_line::@10 [phi:display_chip_line::@9->display_chip_line::@10] + // display_chip_line::@10 + // bgcolor(BLACK) + // [1845] call bgcolor + // [444] phi from display_chip_line::@10 to bgcolor [phi:display_chip_line::@10->bgcolor] + // [444] phi bgcolor::color#15 = BLACK [phi:display_chip_line::@10->bgcolor#0] -- vbum1=vbuc1 + lda #BLACK + sta bgcolor.color + jsr bgcolor + // display_chip_line::@11 + // cputcxy(x+2, y, c) + // [1846] cputcxy::x#10 = display_chip_line::x#16 + 2 -- vbum1=vbum2_plus_2 + lda x clc - lda.z vera_bram_ptr - adc vera_package_read - sta.z vera_bram_ptr - lda.z vera_bram_ptr+1 - adc vera_package_read+1 - sta.z vera_bram_ptr+1 - // vera_file_size += vera_package_read - // [2671] vera_read::vera_file_size#1 = vera_read::vera_file_size#11 + vera_read::vera_package_read#0 -- vdum1=vdum1_plus_vwum2 - lda vera_file_size - clc - adc vera_package_read - sta vera_file_size - lda vera_file_size+1 - adc vera_package_read+1 - sta vera_file_size+1 - lda vera_file_size+2 - adc #0 - sta vera_file_size+2 - lda vera_file_size+3 - adc #0 - sta vera_file_size+3 - // progress_row_current += vera_package_read - // [2672] vera_read::progress_row_current#15 = vera_read::progress_row_current#4 + vera_read::vera_package_read#0 -- vwum1=vwum1_plus_vwum2 - clc - lda progress_row_current - adc vera_package_read - sta progress_row_current - lda progress_row_current+1 - adc vera_package_read+1 - sta progress_row_current+1 - // if (vera_bram_ptr == (bram_ptr_t)BRAM_HIGH) - // [2673] if(vera_read::vera_bram_ptr#2!=(char *)$c000) goto vera_read::@12 -- pbuz1_neq_pbuc1_then_la1 - lda.z vera_bram_ptr+1 - cmp #>$c000 - bne __b12 - lda.z vera_bram_ptr - cmp #<$c000 - bne __b12 - // vera_read::@15 - // vera_bram_bank++; - // [2674] vera_read::vera_bram_bank#2 = ++ vera_read::vera_bram_bank#10 -- vbum1=_inc_vbum1 - inc vera_bram_bank - // [2675] phi from vera_read::@15 to vera_read::@12 [phi:vera_read::@15->vera_read::@12] - // [2675] phi vera_read::vera_bram_bank#13 = vera_read::vera_bram_bank#2 [phi:vera_read::@15->vera_read::@12#0] -- register_copy - // [2675] phi vera_read::vera_bram_ptr#8 = (char *)$a000 [phi:vera_read::@15->vera_read::@12#1] -- pbuz1=pbuc1 - lda #<$a000 - sta.z vera_bram_ptr - lda #>$a000 - sta.z vera_bram_ptr+1 - // [2675] phi from vera_read::@11 to vera_read::@12 [phi:vera_read::@11->vera_read::@12] - // [2675] phi vera_read::vera_bram_bank#13 = vera_read::vera_bram_bank#10 [phi:vera_read::@11->vera_read::@12#0] -- register_copy - // [2675] phi vera_read::vera_bram_ptr#8 = vera_read::vera_bram_ptr#2 [phi:vera_read::@11->vera_read::@12#1] -- register_copy - // vera_read::@12 - __b12: - // if (vera_bram_ptr == (bram_ptr_t)RAM_HIGH) - // [2676] if(vera_read::vera_bram_ptr#8!=(char *)$9800) goto vera_read::@22 -- pbuz1_neq_pbuc1_then_la1 - lda.z vera_bram_ptr+1 - cmp #>$9800 - beq !__b5+ - jmp __b5 - !__b5: - lda.z vera_bram_ptr - cmp #<$9800 - beq !__b5+ - jmp __b5 - !__b5: - // [2640] phi from vera_read::@12 to vera_read::@5 [phi:vera_read::@12->vera_read::@5] - // [2640] phi vera_read::y#11 = vera_read::y#22 [phi:vera_read::@12->vera_read::@5#0] -- register_copy - // [2640] phi vera_read::progress_row_current#10 = vera_read::progress_row_current#15 [phi:vera_read::@12->vera_read::@5#1] -- register_copy - // [2640] phi vera_read::vera_bram_ptr#13 = (char *)$a000 [phi:vera_read::@12->vera_read::@5#2] -- pbuz1=pbuc1 - lda #<$a000 - sta.z vera_bram_ptr - lda #>$a000 - sta.z vera_bram_ptr+1 - // [2640] phi vera_read::vera_bram_bank#10 = 1 [phi:vera_read::@12->vera_read::@5#3] -- vbum1=vbuc1 - lda #1 - sta vera_bram_bank - // [2640] phi vera_read::vera_file_size#11 = vera_read::vera_file_size#1 [phi:vera_read::@12->vera_read::@5#4] -- register_copy - jmp __b5 - // [2677] phi from vera_read::@12 to vera_read::@22 [phi:vera_read::@12->vera_read::@22] - // vera_read::@22 - // [2640] phi from vera_read::@22 to vera_read::@5 [phi:vera_read::@22->vera_read::@5] - // [2640] phi vera_read::y#11 = vera_read::y#22 [phi:vera_read::@22->vera_read::@5#0] -- register_copy - // [2640] phi vera_read::progress_row_current#10 = vera_read::progress_row_current#15 [phi:vera_read::@22->vera_read::@5#1] -- register_copy - // [2640] phi vera_read::vera_bram_ptr#13 = vera_read::vera_bram_ptr#8 [phi:vera_read::@22->vera_read::@5#2] -- register_copy - // [2640] phi vera_read::vera_bram_bank#10 = vera_read::vera_bram_bank#13 [phi:vera_read::@22->vera_read::@5#3] -- register_copy - // [2640] phi vera_read::vera_file_size#11 = vera_read::vera_file_size#1 [phi:vera_read::@22->vera_read::@5#4] -- register_copy - .segment DataVera - info_text: .text "Opening VERA.BIN from SD card ..." - .byte 0 - path: .text "VERA.BIN" - .byte 0 - return: .dword 0 - vera_package_read: .word 0 + adc #2 + sta cputcxy.x + // [1847] cputcxy::y#10 = display_chip_line::y#16 -- vbum1=vbum2 + lda y + sta cputcxy.y + // [1848] cputcxy::c#10 = display_chip_line::c#15 -- vbum1=vbum2 + lda c + sta cputcxy.c + // [1849] call cputcxy + // [1346] phi from display_chip_line::@11 to cputcxy [phi:display_chip_line::@11->cputcxy] + // [1346] phi cputcxy::c#15 = cputcxy::c#10 [phi:display_chip_line::@11->cputcxy#0] -- register_copy + // [1346] phi cputcxy::y#15 = cputcxy::y#10 [phi:display_chip_line::@11->cputcxy#1] -- register_copy + // [1346] phi cputcxy::x#15 = cputcxy::x#10 [phi:display_chip_line::@11->cputcxy#2] -- register_copy + jsr cputcxy + // display_chip_line::@return + // } + // [1850] return + rts + // display_chip_line::@2 + __b2: + // cputc(VERA_CHR_SPACE) + // [1851] stackpush(char) = $20 -- _stackpushbyte_=vbuc1 + lda #$20 + pha + // [1852] callexecute cputc -- call_vprc1 + jsr cputc + // sideeffect stackpullpadding(1) -- _stackpullpadding_1 + pla + // for(char i=0; idisplay_chip_line::@1] + // [1834] phi display_chip_line::i#2 = display_chip_line::i#1 [phi:display_chip_line::@2->display_chip_line::@1#0] -- register_copy + jmp __b1 + .segment Data + i: .byte 0 + x: .byte 0 + w: .byte 0 + c: .byte 0 y: .byte 0 - .label vera_file_size = return - vera_bram_bank: .byte 0 - progress_row_current: .word 0 - info_status: .byte 0 } .segment Code - // uctoa + // display_chip_end +/** + * @brief Print last line of a chip figure. + * + * @param x Start X + * @param y Start Y + * @param w Width + */ +// void display_chip_end(__mem() char x, char y, __mem() char w) +display_chip_end: { + // gotoxy(x, y) + // [1855] gotoxy::x#12 = display_chip_end::x#0 -- vbum1=vbum2 + lda x + sta gotoxy.x + // [1856] call gotoxy + // [457] phi from display_chip_end to gotoxy [phi:display_chip_end->gotoxy] + // [457] phi gotoxy::y#26 = display_print_chip::y#21 [phi:display_chip_end->gotoxy#0] -- vbum1=vbuc1 + lda #display_print_chip.y + sta gotoxy.y + // [457] phi gotoxy::x#26 = gotoxy::x#12 [phi:display_chip_end->gotoxy#1] -- register_copy + jsr gotoxy + // [1857] phi from display_chip_end to display_chip_end::@4 [phi:display_chip_end->display_chip_end::@4] + // display_chip_end::@4 + // textcolor(GREY) + // [1858] call textcolor + // [439] phi from display_chip_end::@4 to textcolor [phi:display_chip_end::@4->textcolor] + // [439] phi textcolor::color#21 = GREY [phi:display_chip_end::@4->textcolor#0] -- vbum1=vbuc1 + lda #GREY + sta textcolor.color + jsr textcolor + // [1859] phi from display_chip_end::@4 to display_chip_end::@5 [phi:display_chip_end::@4->display_chip_end::@5] + // display_chip_end::@5 + // bgcolor(BLUE) + // [1860] call bgcolor + // [444] phi from display_chip_end::@5 to bgcolor [phi:display_chip_end::@5->bgcolor] + // [444] phi bgcolor::color#15 = BLUE [phi:display_chip_end::@5->bgcolor#0] -- vbum1=vbuc1 + lda #BLUE + sta bgcolor.color + jsr bgcolor + // display_chip_end::@6 + // cputc(VERA_CHR_UR) + // [1861] stackpush(char) = $7c -- _stackpushbyte_=vbuc1 + lda #$7c + pha + // [1862] callexecute cputc -- call_vprc1 + jsr cputc + // sideeffect stackpullpadding(1) -- _stackpullpadding_1 + pla + // textcolor(BLUE) + // [1864] call textcolor + // [439] phi from display_chip_end::@6 to textcolor [phi:display_chip_end::@6->textcolor] + // [439] phi textcolor::color#21 = BLUE [phi:display_chip_end::@6->textcolor#0] -- vbum1=vbuc1 + lda #BLUE + sta textcolor.color + jsr textcolor + // [1865] phi from display_chip_end::@6 to display_chip_end::@7 [phi:display_chip_end::@6->display_chip_end::@7] + // display_chip_end::@7 + // bgcolor(BLACK) + // [1866] call bgcolor + // [444] phi from display_chip_end::@7 to bgcolor [phi:display_chip_end::@7->bgcolor] + // [444] phi bgcolor::color#15 = BLACK [phi:display_chip_end::@7->bgcolor#0] -- vbum1=vbuc1 + lda #BLACK + sta bgcolor.color + jsr bgcolor + // [1867] phi from display_chip_end::@7 to display_chip_end::@1 [phi:display_chip_end::@7->display_chip_end::@1] + // [1867] phi display_chip_end::i#2 = 0 [phi:display_chip_end::@7->display_chip_end::@1#0] -- vbum1=vbuc1 + lda #0 + sta i + // display_chip_end::@1 + __b1: + // for(char i=0; idisplay_chip_end::@3] + // display_chip_end::@3 + // textcolor(GREY) + // [1870] call textcolor + // [439] phi from display_chip_end::@3 to textcolor [phi:display_chip_end::@3->textcolor] + // [439] phi textcolor::color#21 = GREY [phi:display_chip_end::@3->textcolor#0] -- vbum1=vbuc1 + lda #GREY + sta textcolor.color + jsr textcolor + // [1871] phi from display_chip_end::@3 to display_chip_end::@8 [phi:display_chip_end::@3->display_chip_end::@8] + // display_chip_end::@8 + // bgcolor(BLUE) + // [1872] call bgcolor + // [444] phi from display_chip_end::@8 to bgcolor [phi:display_chip_end::@8->bgcolor] + // [444] phi bgcolor::color#15 = BLUE [phi:display_chip_end::@8->bgcolor#0] -- vbum1=vbuc1 + lda #BLUE + sta bgcolor.color + jsr bgcolor + // display_chip_end::@9 + // cputc(VERA_CHR_UL) + // [1873] stackpush(char) = $7e -- _stackpushbyte_=vbuc1 + lda #$7e + pha + // [1874] callexecute cputc -- call_vprc1 + jsr cputc + // sideeffect stackpullpadding(1) -- _stackpullpadding_1 + pla + // display_chip_end::@return + // } + // [1876] return + rts + // display_chip_end::@2 + __b2: + // cputc(VERA_CHR_HL) + // [1877] stackpush(char) = $62 -- _stackpushbyte_=vbuc1 + lda #$62 + pha + // [1878] callexecute cputc -- call_vprc1 + jsr cputc + // sideeffect stackpullpadding(1) -- _stackpullpadding_1 + pla + // for(char i=0; idisplay_chip_end::@1] + // [1867] phi display_chip_end::i#2 = display_chip_end::i#1 [phi:display_chip_end::@2->display_chip_end::@1#0] -- register_copy + jmp __b1 + .segment Data + i: .byte 0 + .label x = display_print_chip.x + w: .byte 0 +} +.segment Code + // utoa // Converts unsigned number value to a string representing it in RADIX format. // If the leading digits are zero they are not included in the string. // - value : The number to be converted to RADIX // - buffer : receives the string representing the number and zero-termination. // - radix : The radix to convert the number to (from the enum RADIX) -// void uctoa(__mem() char value, __zp($38) char *buffer, __mem() char radix) -uctoa: { - .label uctoa__4 = $29 - .label buffer = $38 - .label digit_values = $4a +// void utoa(__mem() unsigned int value, __zp($36) char *buffer, __mem() char radix) +utoa: { + .label utoa__4 = $3b + .label utoa__10 = $38 + .label utoa__11 = $4e + .label buffer = $36 + .label digit_values = $3c // if(radix==DECIMAL) - // [2678] if(uctoa::radix#0==DECIMAL) goto uctoa::@1 -- vbum1_eq_vbuc1_then_la1 + // [1881] if(utoa::radix#0==DECIMAL) goto utoa::@1 -- vbum1_eq_vbuc1_then_la1 lda #DECIMAL cmp radix beq __b2 - // uctoa::@2 + // utoa::@2 // if(radix==HEXADECIMAL) - // [2679] if(uctoa::radix#0==HEXADECIMAL) goto uctoa::@1 -- vbum1_eq_vbuc1_then_la1 + // [1882] if(utoa::radix#0==HEXADECIMAL) goto utoa::@1 -- vbum1_eq_vbuc1_then_la1 lda #HEXADECIMAL cmp radix beq __b3 - // uctoa::@3 + // utoa::@3 // if(radix==OCTAL) - // [2680] if(uctoa::radix#0==OCTAL) goto uctoa::@1 -- vbum1_eq_vbuc1_then_la1 + // [1883] if(utoa::radix#0==OCTAL) goto utoa::@1 -- vbum1_eq_vbuc1_then_la1 lda #OCTAL cmp radix beq __b4 - // uctoa::@4 + // utoa::@4 // if(radix==BINARY) - // [2681] if(uctoa::radix#0==BINARY) goto uctoa::@1 -- vbum1_eq_vbuc1_then_la1 + // [1884] if(utoa::radix#0==BINARY) goto utoa::@1 -- vbum1_eq_vbuc1_then_la1 lda #BINARY cmp radix beq __b5 - // uctoa::@5 + // utoa::@5 // *buffer++ = 'e' - // [2682] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS) = 'e' -- _deref_pbuc1=vbuc2 + // [1885] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS) = 'e' -- _deref_pbuc1=vbuc2 // Unknown radix lda #'e' sta printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS // *buffer++ = 'r' - // [2683] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+1) = 'r' -- _deref_pbuc1=vbuc2 + // [1886] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+1) = 'r' -- _deref_pbuc1=vbuc2 lda #'r' sta printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+1 - // [2684] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+2) = 'r' -- _deref_pbuc1=vbuc2 + // [1887] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+2) = 'r' -- _deref_pbuc1=vbuc2 sta printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+2 // *buffer = 0 - // [2685] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+3) = 0 -- _deref_pbuc1=vbuc2 + // [1888] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+3) = 0 -- _deref_pbuc1=vbuc2 lda #0 sta printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+3 - // uctoa::@return + // utoa::@return // } - // [2686] return + // [1889] return rts - // [2687] phi from uctoa to uctoa::@1 [phi:uctoa->uctoa::@1] + // [1890] phi from utoa to utoa::@1 [phi:utoa->utoa::@1] __b2: - // [2687] phi uctoa::digit_values#8 = RADIX_DECIMAL_VALUES_CHAR [phi:uctoa->uctoa::@1#0] -- pbuz1=pbuc1 - lda #utoa::@1#0] -- pwuz1=pwuc1 + lda #RADIX_DECIMAL_VALUES_CHAR + lda #>RADIX_DECIMAL_VALUES sta.z digit_values+1 - // [2687] phi uctoa::max_digits#7 = 3 [phi:uctoa->uctoa::@1#1] -- vbum1=vbuc1 - lda #3 + // [1890] phi utoa::max_digits#7 = 5 [phi:utoa->utoa::@1#1] -- vbum1=vbuc1 + lda #5 sta max_digits jmp __b1 - // [2687] phi from uctoa::@2 to uctoa::@1 [phi:uctoa::@2->uctoa::@1] + // [1890] phi from utoa::@2 to utoa::@1 [phi:utoa::@2->utoa::@1] __b3: - // [2687] phi uctoa::digit_values#8 = RADIX_HEXADECIMAL_VALUES_CHAR [phi:uctoa::@2->uctoa::@1#0] -- pbuz1=pbuc1 - lda #utoa::@1#0] -- pwuz1=pwuc1 + lda #RADIX_HEXADECIMAL_VALUES_CHAR + lda #>RADIX_HEXADECIMAL_VALUES sta.z digit_values+1 - // [2687] phi uctoa::max_digits#7 = 2 [phi:uctoa::@2->uctoa::@1#1] -- vbum1=vbuc1 - lda #2 + // [1890] phi utoa::max_digits#7 = 4 [phi:utoa::@2->utoa::@1#1] -- vbum1=vbuc1 + lda #4 sta max_digits jmp __b1 - // [2687] phi from uctoa::@3 to uctoa::@1 [phi:uctoa::@3->uctoa::@1] + // [1890] phi from utoa::@3 to utoa::@1 [phi:utoa::@3->utoa::@1] __b4: - // [2687] phi uctoa::digit_values#8 = RADIX_OCTAL_VALUES_CHAR [phi:uctoa::@3->uctoa::@1#0] -- pbuz1=pbuc1 - lda #utoa::@1#0] -- pwuz1=pwuc1 + lda #RADIX_OCTAL_VALUES_CHAR + lda #>RADIX_OCTAL_VALUES sta.z digit_values+1 - // [2687] phi uctoa::max_digits#7 = 3 [phi:uctoa::@3->uctoa::@1#1] -- vbum1=vbuc1 - lda #3 + // [1890] phi utoa::max_digits#7 = 6 [phi:utoa::@3->utoa::@1#1] -- vbum1=vbuc1 + lda #6 sta max_digits jmp __b1 - // [2687] phi from uctoa::@4 to uctoa::@1 [phi:uctoa::@4->uctoa::@1] + // [1890] phi from utoa::@4 to utoa::@1 [phi:utoa::@4->utoa::@1] __b5: - // [2687] phi uctoa::digit_values#8 = RADIX_BINARY_VALUES_CHAR [phi:uctoa::@4->uctoa::@1#0] -- pbuz1=pbuc1 - lda #utoa::@1#0] -- pwuz1=pwuc1 + lda #RADIX_BINARY_VALUES_CHAR + lda #>RADIX_BINARY_VALUES sta.z digit_values+1 - // [2687] phi uctoa::max_digits#7 = 8 [phi:uctoa::@4->uctoa::@1#1] -- vbum1=vbuc1 - lda #8 + // [1890] phi utoa::max_digits#7 = $10 [phi:utoa::@4->utoa::@1#1] -- vbum1=vbuc1 + lda #$10 sta max_digits - // uctoa::@1 + // utoa::@1 __b1: - // [2688] phi from uctoa::@1 to uctoa::@6 [phi:uctoa::@1->uctoa::@6] - // [2688] phi uctoa::buffer#11 = (char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS [phi:uctoa::@1->uctoa::@6#0] -- pbuz1=pbuc1 + // [1891] phi from utoa::@1 to utoa::@6 [phi:utoa::@1->utoa::@6] + // [1891] phi utoa::buffer#11 = (char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS [phi:utoa::@1->utoa::@6#0] -- pbuz1=pbuc1 lda #printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS sta.z buffer+1 - // [2688] phi uctoa::started#2 = 0 [phi:uctoa::@1->uctoa::@6#1] -- vbum1=vbuc1 + // [1891] phi utoa::started#2 = 0 [phi:utoa::@1->utoa::@6#1] -- vbum1=vbuc1 lda #0 sta started - // [2688] phi uctoa::value#2 = uctoa::value#1 [phi:uctoa::@1->uctoa::@6#2] -- register_copy - // [2688] phi uctoa::digit#2 = 0 [phi:uctoa::@1->uctoa::@6#3] -- vbum1=vbuc1 + // [1891] phi utoa::value#2 = utoa::value#1 [phi:utoa::@1->utoa::@6#2] -- register_copy + // [1891] phi utoa::digit#2 = 0 [phi:utoa::@1->utoa::@6#3] -- vbum1=vbuc1 sta digit - // uctoa::@6 + // utoa::@6 __b6: // max_digits-1 - // [2689] uctoa::$4 = uctoa::max_digits#7 - 1 -- vbuz1=vbum2_minus_1 + // [1892] utoa::$4 = utoa::max_digits#7 - 1 -- vbuz1=vbum2_minus_1 ldx max_digits dex - stx.z uctoa__4 + stx.z utoa__4 // for( char digit=0; digit= digit_value) - // [2695] if(0!=uctoa::started#2) goto uctoa::@10 -- 0_neq_vbum1_then_la1 + // [1900] if(0!=utoa::started#2) goto utoa::@10 -- 0_neq_vbum1_then_la1 lda started bne __b10 - // uctoa::@12 - // [2696] if(uctoa::value#2>=uctoa::digit_value#0) goto uctoa::@10 -- vbum1_ge_vbum2_then_la1 - lda value - cmp digit_value - bcs __b10 - // [2697] phi from uctoa::@12 to uctoa::@9 [phi:uctoa::@12->uctoa::@9] - // [2697] phi uctoa::buffer#14 = uctoa::buffer#11 [phi:uctoa::@12->uctoa::@9#0] -- register_copy - // [2697] phi uctoa::started#4 = uctoa::started#2 [phi:uctoa::@12->uctoa::@9#1] -- register_copy - // [2697] phi uctoa::value#6 = uctoa::value#2 [phi:uctoa::@12->uctoa::@9#2] -- register_copy - // uctoa::@9 - __b9: - // for( char digit=0; digit=utoa::digit_value#0) goto utoa::@10 -- vwum1_ge_vwum2_then_la1 + lda digit_value+1 + cmp value+1 + bne !+ + lda digit_value + cmp value + beq __b10 + !: + bcc __b10 + // [1902] phi from utoa::@12 to utoa::@9 [phi:utoa::@12->utoa::@9] + // [1902] phi utoa::buffer#14 = utoa::buffer#11 [phi:utoa::@12->utoa::@9#0] -- register_copy + // [1902] phi utoa::started#4 = utoa::started#2 [phi:utoa::@12->utoa::@9#1] -- register_copy + // [1902] phi utoa::value#6 = utoa::value#2 [phi:utoa::@12->utoa::@9#2] -- register_copy + // utoa::@9 + __b9: + // for( char digit=0; digituctoa::@6] - // [2688] phi uctoa::buffer#11 = uctoa::buffer#14 [phi:uctoa::@9->uctoa::@6#0] -- register_copy - // [2688] phi uctoa::started#2 = uctoa::started#4 [phi:uctoa::@9->uctoa::@6#1] -- register_copy - // [2688] phi uctoa::value#2 = uctoa::value#6 [phi:uctoa::@9->uctoa::@6#2] -- register_copy - // [2688] phi uctoa::digit#2 = uctoa::digit#1 [phi:uctoa::@9->uctoa::@6#3] -- register_copy + // [1891] phi from utoa::@9 to utoa::@6 [phi:utoa::@9->utoa::@6] + // [1891] phi utoa::buffer#11 = utoa::buffer#14 [phi:utoa::@9->utoa::@6#0] -- register_copy + // [1891] phi utoa::started#2 = utoa::started#4 [phi:utoa::@9->utoa::@6#1] -- register_copy + // [1891] phi utoa::value#2 = utoa::value#6 [phi:utoa::@9->utoa::@6#2] -- register_copy + // [1891] phi utoa::digit#2 = utoa::digit#1 [phi:utoa::@9->utoa::@6#3] -- register_copy jmp __b6 - // uctoa::@10 + // utoa::@10 __b10: - // uctoa_append(buffer++, value, digit_value) - // [2699] uctoa_append::buffer#0 = uctoa::buffer#11 -- pbuz1=pbuz2 + // utoa_append(buffer++, value, digit_value) + // [1904] utoa_append::buffer#0 = utoa::buffer#11 -- pbuz1=pbuz2 lda.z buffer - sta.z uctoa_append.buffer + sta.z utoa_append.buffer lda.z buffer+1 - sta.z uctoa_append.buffer+1 - // [2700] uctoa_append::value#0 = uctoa::value#2 - // [2701] uctoa_append::sub#0 = uctoa::digit_value#0 - // [2702] call uctoa_append - // [3299] phi from uctoa::@10 to uctoa_append [phi:uctoa::@10->uctoa_append] - jsr uctoa_append - // uctoa_append(buffer++, value, digit_value) - // [2703] uctoa_append::return#0 = uctoa_append::value#2 - // uctoa::@11 - // value = uctoa_append(buffer++, value, digit_value) - // [2704] uctoa::value#0 = uctoa_append::return#0 - // value = uctoa_append(buffer++, value, digit_value); - // [2705] uctoa::buffer#4 = ++ uctoa::buffer#11 -- pbuz1=_inc_pbuz1 + sta.z utoa_append.buffer+1 + // [1905] utoa_append::value#0 = utoa::value#2 + // [1906] utoa_append::sub#0 = utoa::digit_value#0 + // [1907] call utoa_append + // [2242] phi from utoa::@10 to utoa_append [phi:utoa::@10->utoa_append] + jsr utoa_append + // utoa_append(buffer++, value, digit_value) + // [1908] utoa_append::return#0 = utoa_append::value#2 + // utoa::@11 + // value = utoa_append(buffer++, value, digit_value) + // [1909] utoa::value#0 = utoa_append::return#0 + // value = utoa_append(buffer++, value, digit_value); + // [1910] utoa::buffer#4 = ++ utoa::buffer#11 -- pbuz1=_inc_pbuz1 inc.z buffer bne !+ inc.z buffer+1 !: - // [2697] phi from uctoa::@11 to uctoa::@9 [phi:uctoa::@11->uctoa::@9] - // [2697] phi uctoa::buffer#14 = uctoa::buffer#4 [phi:uctoa::@11->uctoa::@9#0] -- register_copy - // [2697] phi uctoa::started#4 = 1 [phi:uctoa::@11->uctoa::@9#1] -- vbum1=vbuc1 + // [1902] phi from utoa::@11 to utoa::@9 [phi:utoa::@11->utoa::@9] + // [1902] phi utoa::buffer#14 = utoa::buffer#4 [phi:utoa::@11->utoa::@9#0] -- register_copy + // [1902] phi utoa::started#4 = 1 [phi:utoa::@11->utoa::@9#1] -- vbum1=vbuc1 lda #1 sta started - // [2697] phi uctoa::value#6 = uctoa::value#0 [phi:uctoa::@11->uctoa::@9#2] -- register_copy + // [1902] phi utoa::value#6 = utoa::value#0 [phi:utoa::@11->utoa::@9#2] -- register_copy jmp __b9 .segment Data - digit_value: .byte 0 + digit_value: .word 0 digit: .byte 0 - .label value = smc_get_version_text.release - .label radix = printf_uchar.format_radix + .label value = printf_uint.uvalue + .label radix = printf_uint.format_radix started: .byte 0 max_digits: .byte 0 } +.segment CodeVera + // spi_get_jedec +spi_get_jedec: { + // spi_fast() + // [1912] call spi_fast + /* +; Returns +; .X = Vendor ID +; .Y = Memory Type +; .A = Memory Capacity +.proc spi_get_jedec + jsr spi_fast + + jsr spi_select + lda #$9F + jsr spi_write + jsr spi_read + tax + jsr spi_read + tay + jsr spi_read + rts +.endproc + */ + jsr spi_fast + // [1913] phi from spi_get_jedec to spi_get_jedec::@1 [phi:spi_get_jedec->spi_get_jedec::@1] + // spi_get_jedec::@1 + // spi_select() + // [1914] call spi_select + // [2251] phi from spi_get_jedec::@1 to spi_select [phi:spi_get_jedec::@1->spi_select] + jsr spi_select + // spi_get_jedec::@2 + // spi_write(0x9F) + // [1915] spi_write::data = $9f -- vbum1=vbuc1 + lda #$9f + sta spi_write.data + // [1916] call spi_write + jsr spi_write + // [1917] phi from spi_get_jedec::@2 to spi_get_jedec::@3 [phi:spi_get_jedec::@2->spi_get_jedec::@3] + // spi_get_jedec::@3 + // spi_read() + // [1918] call spi_read + jsr spi_read + // [1919] spi_read::return#0 = spi_read::return#4 -- vbum1=vbum2 + lda spi_read.return_3 + sta spi_read.return + // [1920] phi from spi_get_jedec::@3 to spi_get_jedec::@4 [phi:spi_get_jedec::@3->spi_get_jedec::@4] + // spi_get_jedec::@4 + // spi_read() + // [1921] call spi_read + jsr spi_read + // [1922] spi_read::return#1 = spi_read::return#4 -- vbum1=vbum2 + lda spi_read.return_3 + sta spi_read.return_1 + // [1923] phi from spi_get_jedec::@4 to spi_get_jedec::@5 [phi:spi_get_jedec::@4->spi_get_jedec::@5] + // spi_get_jedec::@5 + // spi_read() + // [1924] call spi_read + jsr spi_read + // [1925] spi_read::return#2 = spi_read::return#4 -- vbum1=vbum2 + lda spi_read.return_3 + sta spi_read.return_2 + // spi_get_jedec::@return + // } + // [1926] return + rts +} .segment Code - // printf_number_buffer -// Print the contents of the number buffer using a specific format. -// This handles minimum length, zero-filling, and left/right justification from the format -// void printf_number_buffer(__zp($3b) void (*putc)(char), __mem() char buffer_sign, char *buffer_digits, __mem() char format_min_length, char format_justify_left, char format_sign_always, __mem() char format_zero_padding, char format_upper_case, char format_radix) -printf_number_buffer: { - .label printf_number_buffer__19 = $4a - .label putc = $3b - // if(format.min_length) - // [2707] if(0==printf_number_buffer::format_min_length#3) goto printf_number_buffer::@1 -- 0_eq_vbum1_then_la1 - lda format_min_length - beq __b5 - // [2708] phi from printf_number_buffer to printf_number_buffer::@5 [phi:printf_number_buffer->printf_number_buffer::@5] - // printf_number_buffer::@5 - // strlen(buffer.digits) - // [2709] call strlen - // [2611] phi from printf_number_buffer::@5 to strlen [phi:printf_number_buffer::@5->strlen] - // [2611] phi strlen::str#8 = (char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS [phi:printf_number_buffer::@5->strlen#0] -- pbuz1=pbuc1 - lda #printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS - sta.z strlen.str+1 - jsr strlen - // strlen(buffer.digits) - // [2710] strlen::return#3 = strlen::len#2 - // printf_number_buffer::@11 - // [2711] printf_number_buffer::$19 = strlen::return#3 -- vwuz1=vwum2 - lda strlen.return - sta.z printf_number_buffer__19 - lda strlen.return+1 - sta.z printf_number_buffer__19+1 - // signed char len = (signed char)strlen(buffer.digits) - // [2712] printf_number_buffer::len#0 = (signed char)printf_number_buffer::$19 -- vbsm1=_sbyte_vwuz2 - // There is a minimum length - work out the padding - lda.z printf_number_buffer__19 - sta len - // if(buffer.sign) - // [2713] if(0==printf_number_buffer::buffer_sign#10) goto printf_number_buffer::@10 -- 0_eq_vbum1_then_la1 - lda buffer_sign - beq __b10 - // printf_number_buffer::@6 - // len++; - // [2714] printf_number_buffer::len#1 = ++ printf_number_buffer::len#0 -- vbsm1=_inc_vbsm1 - inc len - // [2715] phi from printf_number_buffer::@11 printf_number_buffer::@6 to printf_number_buffer::@10 [phi:printf_number_buffer::@11/printf_number_buffer::@6->printf_number_buffer::@10] - // [2715] phi printf_number_buffer::len#2 = printf_number_buffer::len#0 [phi:printf_number_buffer::@11/printf_number_buffer::@6->printf_number_buffer::@10#0] -- register_copy - // printf_number_buffer::@10 + // fopen +/** + * @brief Load a file to banked ram located between address 0xA000 and 0xBFFF incrementing the banks. + * + * @param channel Input channel. + * @param device Input device. + * @param secondary Secondary channel. + * @param filename Name of the file to be loaded. + * @return + * - 0x0000: Something is wrong! Kernal Error Code (https://commodore.ca/manuals/pdfs/commodore_error_messages.pdf) + * - other: OK! The last pointer between 0xA000 and 0xBFFF is returned. Note that the last pointer is indicating the first free byte. + */ +// __zp($40) struct $2 * fopen(__zp($49) const char *path, const char *mode) +fopen: { + .label fopen__4 = $4e + .label fopen__9 = $38 + .label fopen__11 = $3e + .label fopen__15 = $3b + .label fopen__16 = $59 + .label fopen__26 = $5f + .label fopen__28 = $51 + .label fopen__30 = $40 + .label cbm_k_setnam1_filename = $78 + .label cbm_k_setnam1_fopen__0 = $3c + .label stream = $40 + .label pathtoken = $36 + .label path = $49 + .label return = $40 + // unsigned char sp = __stdio_filecount + // [1927] fopen::sp#0 = __stdio_filecount#105 -- vbum1=vbum2 + lda __stdio_filecount + sta sp + // (unsigned int)sp | 0x8000 + // [1928] fopen::$30 = (unsigned int)fopen::sp#0 -- vwuz1=_word_vbum2 + sta.z fopen__30 + lda #0 + sta.z fopen__30+1 + // [1929] fopen::stream#0 = fopen::$30 | $8000 -- vwuz1=vwuz1_bor_vwuc1 + lda.z stream + ora #<$8000 + sta.z stream + lda.z stream+1 + ora #>$8000 + sta.z stream+1 + // char pathpos = sp * __STDIO_FILECOUNT + // [1930] fopen::pathpos#0 = fopen::sp#0 << 1 -- vbum1=vbum2_rol_1 + lda sp + asl + sta pathpos + // __logical = 0 + // [1931] ((char *)&__stdio_file+$40)[fopen::sp#0] = 0 -- pbuc1_derefidx_vbum1=vbuc2 + lda #0 + ldy sp + sta __stdio_file+$40,y + // __device = 0 + // [1932] ((char *)&__stdio_file+$42)[fopen::sp#0] = 0 -- pbuc1_derefidx_vbum1=vbuc2 + sta __stdio_file+$42,y + // __channel = 0 + // [1933] ((char *)&__stdio_file+$44)[fopen::sp#0] = 0 -- pbuc1_derefidx_vbum1=vbuc2 + sta __stdio_file+$44,y + // [1934] fopen::pathpos#21 = fopen::pathpos#0 -- vbum1=vbum2 + lda pathpos + sta pathpos_1 + // [1935] phi from fopen to fopen::@8 [phi:fopen->fopen::@8] + // [1935] phi fopen::num#10 = 0 [phi:fopen->fopen::@8#0] -- vbum1=vbuc1 + lda #0 + sta num + // [1935] phi fopen::pathpos#10 = fopen::pathpos#21 [phi:fopen->fopen::@8#1] -- register_copy + // [1935] phi fopen::path#13 = vera_read::path [phi:fopen->fopen::@8#2] -- pbuz1=pbuc1 + lda #vera_read.path + sta.z path+1 + // [1935] phi fopen::pathstep#10 = 0 [phi:fopen->fopen::@8#3] -- vbum1=vbuc1 + lda #0 + sta pathstep + // [1935] phi fopen::pathtoken#10 = vera_read::path [phi:fopen->fopen::@8#4] -- pbuz1=pbuc1 + lda #vera_read.path + sta.z pathtoken+1 + // Iterate while path is not \0. + // [1935] phi from fopen::@22 to fopen::@8 [phi:fopen::@22->fopen::@8] + // [1935] phi fopen::num#10 = fopen::num#13 [phi:fopen::@22->fopen::@8#0] -- register_copy + // [1935] phi fopen::pathpos#10 = fopen::pathpos#7 [phi:fopen::@22->fopen::@8#1] -- register_copy + // [1935] phi fopen::path#13 = fopen::path#10 [phi:fopen::@22->fopen::@8#2] -- register_copy + // [1935] phi fopen::pathstep#10 = fopen::pathstep#11 [phi:fopen::@22->fopen::@8#3] -- register_copy + // [1935] phi fopen::pathtoken#10 = fopen::pathtoken#1 [phi:fopen::@22->fopen::@8#4] -- register_copy + // fopen::@8 + __b8: + // if (*pathtoken == ',' || *pathtoken == '\0') + // [1936] if(*fopen::pathtoken#10==',') goto fopen::@9 -- _deref_pbuz1_eq_vbuc1_then_la1 + lda #',' + ldy #0 + cmp (pathtoken),y + bne !__b9+ + jmp __b9 + !__b9: + // fopen::@33 + // [1937] if(*fopen::pathtoken#10=='@') goto fopen::@9 -- _deref_pbuz1_eq_vbuc1_then_la1 + lda #'@' + cmp (pathtoken),y + bne !__b9+ + jmp __b9 + !__b9: + // fopen::@23 + // if (pathstep == 0) + // [1938] if(fopen::pathstep#10!=0) goto fopen::@10 -- vbum1_neq_0_then_la1 + lda pathstep + bne __b10 + // fopen::@24 + // __stdio_file.filename[pathpos] = *pathtoken + // [1939] ((char *)&__stdio_file)[fopen::pathpos#10] = *fopen::pathtoken#10 -- pbuc1_derefidx_vbum1=_deref_pbuz2 + lda (pathtoken),y + ldy pathpos_1 + sta __stdio_file,y + // pathpos++; + // [1940] fopen::pathpos#1 = ++ fopen::pathpos#10 -- vbum1=_inc_vbum1 + inc pathpos_1 + // [1941] phi from fopen::@12 fopen::@23 fopen::@24 to fopen::@10 [phi:fopen::@12/fopen::@23/fopen::@24->fopen::@10] + // [1941] phi fopen::num#13 = fopen::num#15 [phi:fopen::@12/fopen::@23/fopen::@24->fopen::@10#0] -- register_copy + // [1941] phi fopen::pathpos#7 = fopen::pathpos#10 [phi:fopen::@12/fopen::@23/fopen::@24->fopen::@10#1] -- register_copy + // [1941] phi fopen::path#10 = fopen::path#12 [phi:fopen::@12/fopen::@23/fopen::@24->fopen::@10#2] -- register_copy + // [1941] phi fopen::pathstep#11 = fopen::pathstep#1 [phi:fopen::@12/fopen::@23/fopen::@24->fopen::@10#3] -- register_copy + // fopen::@10 __b10: - // padding = (signed char)format.min_length - len - // [2716] printf_number_buffer::padding#1 = (signed char)printf_number_buffer::format_min_length#3 - printf_number_buffer::len#2 -- vbsm1=vbsm2_minus_vbsm1 - lda format_min_length + // pathtoken++; + // [1942] fopen::pathtoken#1 = ++ fopen::pathtoken#10 -- pbuz1=_inc_pbuz1 + inc.z pathtoken + bne !+ + inc.z pathtoken+1 + !: + // fopen::@22 + // pathtoken - 1 + // [1943] fopen::$28 = fopen::pathtoken#1 - 1 -- pbuz1=pbuz2_minus_1 + lda.z pathtoken sec - sbc padding - sta padding - // if(padding<0) - // [2717] if(printf_number_buffer::padding#1>=0) goto printf_number_buffer::@15 -- vbsm1_ge_0_then_la1 + sbc #1 + sta.z fopen__28 + lda.z pathtoken+1 + sbc #0 + sta.z fopen__28+1 + // while (*(pathtoken - 1)) + // [1944] if(0!=*fopen::$28) goto fopen::@8 -- 0_neq__deref_pbuz1_then_la1 + ldy #0 + lda (fopen__28),y cmp #0 - bpl __b1 - // [2719] phi from printf_number_buffer printf_number_buffer::@10 to printf_number_buffer::@1 [phi:printf_number_buffer/printf_number_buffer::@10->printf_number_buffer::@1] - __b5: - // [2719] phi printf_number_buffer::padding#10 = 0 [phi:printf_number_buffer/printf_number_buffer::@10->printf_number_buffer::@1#0] -- vbsm1=vbsc1 - lda #0 - sta padding - // [2718] phi from printf_number_buffer::@10 to printf_number_buffer::@15 [phi:printf_number_buffer::@10->printf_number_buffer::@15] - // printf_number_buffer::@15 - // [2719] phi from printf_number_buffer::@15 to printf_number_buffer::@1 [phi:printf_number_buffer::@15->printf_number_buffer::@1] - // [2719] phi printf_number_buffer::padding#10 = printf_number_buffer::padding#1 [phi:printf_number_buffer::@15->printf_number_buffer::@1#0] -- register_copy - // printf_number_buffer::@1 + bne __b8 + // fopen::@26 + // __status = 0 + // [1945] ((char *)&__stdio_file+$46)[fopen::sp#0] = 0 -- pbuc1_derefidx_vbum1=vbuc2 + tya + ldy sp + sta __stdio_file+$46,y + // if(!__logical) + // [1946] if(0!=((char *)&__stdio_file+$40)[fopen::sp#0]) goto fopen::@1 -- 0_neq_pbuc1_derefidx_vbum1_then_la1 + lda __stdio_file+$40,y + cmp #0 + bne __b1 + // fopen::@27 + // __stdio_filecount+1 + // [1947] fopen::$4 = __stdio_filecount#105 + 1 -- vbuz1=vbum2_plus_1 + lda __stdio_filecount + inc + sta.z fopen__4 + // __logical = __stdio_filecount+1 + // [1948] ((char *)&__stdio_file+$40)[fopen::sp#0] = fopen::$4 -- pbuc1_derefidx_vbum1=vbuz2 + sta __stdio_file+$40,y + // fopen::@1 __b1: - // printf_number_buffer::@13 - // if(!format.justify_left && !format.zero_padding && padding) - // [2720] if(0!=printf_number_buffer::format_zero_padding#10) goto printf_number_buffer::@2 -- 0_neq_vbum1_then_la1 - lda format_zero_padding + // if(!__device) + // [1949] if(0!=((char *)&__stdio_file+$42)[fopen::sp#0]) goto fopen::@2 -- 0_neq_pbuc1_derefidx_vbum1_then_la1 + ldy sp + lda __stdio_file+$42,y + cmp #0 bne __b2 - // printf_number_buffer::@12 - // [2721] if(0!=printf_number_buffer::padding#10) goto printf_number_buffer::@7 -- 0_neq_vbsm1_then_la1 - lda padding + // fopen::@5 + // __device = 8 + // [1950] ((char *)&__stdio_file+$42)[fopen::sp#0] = 8 -- pbuc1_derefidx_vbum1=vbuc2 + lda #8 + sta __stdio_file+$42,y + // fopen::@2 + __b2: + // if(!__channel) + // [1951] if(0!=((char *)&__stdio_file+$44)[fopen::sp#0]) goto fopen::@3 -- 0_neq_pbuc1_derefidx_vbum1_then_la1 + ldy sp + lda __stdio_file+$44,y cmp #0 - bne __b7 - jmp __b2 - // printf_number_buffer::@7 - __b7: - // printf_padding(putc, ' ',(char)padding) - // [2722] printf_padding::putc#0 = printf_number_buffer::putc#10 -- pprz1=pprz2 - lda.z putc - sta.z printf_padding.putc - lda.z putc+1 - sta.z printf_padding.putc+1 - // [2723] printf_padding::length#0 = (char)printf_number_buffer::padding#10 -- vbum1=vbum2 - lda padding - sta printf_padding.length - // [2724] call printf_padding - // [2617] phi from printf_number_buffer::@7 to printf_padding [phi:printf_number_buffer::@7->printf_padding] - // [2617] phi printf_padding::putc#7 = printf_padding::putc#0 [phi:printf_number_buffer::@7->printf_padding#0] -- register_copy - // [2617] phi printf_padding::pad#7 = ' ' [phi:printf_number_buffer::@7->printf_padding#1] -- vbum1=vbuc1 - lda #' ' - sta printf_padding.pad - // [2617] phi printf_padding::length#6 = printf_padding::length#0 [phi:printf_number_buffer::@7->printf_padding#2] -- register_copy - jsr printf_padding - // printf_number_buffer::@2 - __b2: - // if(buffer.sign) - // [2725] if(0==printf_number_buffer::buffer_sign#10) goto printf_number_buffer::@3 -- 0_eq_vbum1_then_la1 - lda buffer_sign - beq __b3 - // printf_number_buffer::@8 - // putc(buffer.sign) - // [2726] stackpush(char) = printf_number_buffer::buffer_sign#10 -- _stackpushbyte_=vbum1 - pha - // [2727] callexecute *printf_number_buffer::putc#10 -- call__deref_pprz1 - jsr icall40 - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // printf_number_buffer::@3 + bne __b3 + // fopen::@6 + // __stdio_filecount+2 + // [1952] fopen::$9 = __stdio_filecount#105 + 2 -- vbuz1=vbum2_plus_2 + lda __stdio_filecount + clc + adc #2 + sta.z fopen__9 + // __channel = __stdio_filecount+2 + // [1953] ((char *)&__stdio_file+$44)[fopen::sp#0] = fopen::$9 -- pbuc1_derefidx_vbum1=vbuz2 + sta __stdio_file+$44,y + // fopen::@3 __b3: - // if(format.zero_padding && padding) - // [2729] if(0==printf_number_buffer::format_zero_padding#10) goto printf_number_buffer::@4 -- 0_eq_vbum1_then_la1 - lda format_zero_padding - beq __b4 - // printf_number_buffer::@14 - // [2730] if(0!=printf_number_buffer::padding#10) goto printf_number_buffer::@9 -- 0_neq_vbsm1_then_la1 - lda padding - cmp #0 - bne __b9 - jmp __b4 - // printf_number_buffer::@9 - __b9: - // printf_padding(putc, '0',(char)padding) - // [2731] printf_padding::putc#1 = printf_number_buffer::putc#10 -- pprz1=pprz2 - lda.z putc - sta.z printf_padding.putc - lda.z putc+1 - sta.z printf_padding.putc+1 - // [2732] printf_padding::length#1 = (char)printf_number_buffer::padding#10 -- vbum1=vbum2 - lda padding - sta printf_padding.length - // [2733] call printf_padding - // [2617] phi from printf_number_buffer::@9 to printf_padding [phi:printf_number_buffer::@9->printf_padding] - // [2617] phi printf_padding::putc#7 = printf_padding::putc#1 [phi:printf_number_buffer::@9->printf_padding#0] -- register_copy - // [2617] phi printf_padding::pad#7 = '0' [phi:printf_number_buffer::@9->printf_padding#1] -- vbum1=vbuc1 - lda #'0' - sta printf_padding.pad - // [2617] phi printf_padding::length#6 = printf_padding::length#1 [phi:printf_number_buffer::@9->printf_padding#2] -- register_copy - jsr printf_padding - // printf_number_buffer::@4 - __b4: - // printf_str(putc, buffer.digits) - // [2734] printf_str::putc#0 = printf_number_buffer::putc#10 - // [2735] call printf_str - // [1210] phi from printf_number_buffer::@4 to printf_str [phi:printf_number_buffer::@4->printf_str] - // [1210] phi printf_str::putc#84 = printf_str::putc#0 [phi:printf_number_buffer::@4->printf_str#0] -- register_copy - // [1210] phi printf_str::s#84 = (char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS [phi:printf_number_buffer::@4->printf_str#1] -- pbuz1=pbuc1 - lda #printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS - sta.z printf_str.s+1 - jsr printf_str - // printf_number_buffer::@return + // __filename + // [1954] fopen::$11 = (char *)&__stdio_file + fopen::pathpos#0 -- pbuz1=pbuc1_plus_vbum2 + lda pathpos + clc + adc #<__stdio_file + sta.z fopen__11 + lda #>__stdio_file + adc #0 + sta.z fopen__11+1 + // cbm_k_setnam(__filename) + // [1955] fopen::cbm_k_setnam1_filename = fopen::$11 -- pbuz1=pbuz2 + lda.z fopen__11 + sta.z cbm_k_setnam1_filename + lda.z fopen__11+1 + sta.z cbm_k_setnam1_filename+1 + // fopen::cbm_k_setnam1 + // strlen(filename) + // [1956] strlen::str#4 = fopen::cbm_k_setnam1_filename -- pbuz1=pbuz2 + lda.z cbm_k_setnam1_filename + sta.z strlen.str + lda.z cbm_k_setnam1_filename+1 + sta.z strlen.str+1 + // [1957] call strlen + // [1788] phi from fopen::cbm_k_setnam1 to strlen [phi:fopen::cbm_k_setnam1->strlen] + // [1788] phi strlen::str#8 = strlen::str#4 [phi:fopen::cbm_k_setnam1->strlen#0] -- register_copy + jsr strlen + // strlen(filename) + // [1958] strlen::return#11 = strlen::len#2 + // fopen::@31 + // [1959] fopen::cbm_k_setnam1_$0 = strlen::return#11 -- vwuz1=vwum2 + lda strlen.return + sta.z cbm_k_setnam1_fopen__0 + lda strlen.return+1 + sta.z cbm_k_setnam1_fopen__0+1 + // char filename_len = (char)strlen(filename) + // [1960] fopen::cbm_k_setnam1_filename_len = (char)fopen::cbm_k_setnam1_$0 -- vbum1=_byte_vwuz2 + lda.z cbm_k_setnam1_fopen__0 + sta cbm_k_setnam1_filename_len + // asm + // asm { ldafilename_len ldxfilename ldyfilename+1 jsrCBM_SETNAM } + ldx cbm_k_setnam1_filename + ldy cbm_k_setnam1_filename+1 + jsr CBM_SETNAM + // fopen::@28 + // cbm_k_setlfs(__logical, __device, __channel) + // [1962] cbm_k_setlfs::channel = ((char *)&__stdio_file+$40)[fopen::sp#0] -- vbum1=pbuc1_derefidx_vbum2 + ldy sp + lda __stdio_file+$40,y + sta cbm_k_setlfs.channel + // [1963] cbm_k_setlfs::device = ((char *)&__stdio_file+$42)[fopen::sp#0] -- vbum1=pbuc1_derefidx_vbum2 + lda __stdio_file+$42,y + sta cbm_k_setlfs.device + // [1964] cbm_k_setlfs::command = ((char *)&__stdio_file+$44)[fopen::sp#0] -- vbum1=pbuc1_derefidx_vbum2 + lda __stdio_file+$44,y + sta cbm_k_setlfs.command + // [1965] call cbm_k_setlfs + jsr cbm_k_setlfs + // fopen::cbm_k_open1 + // asm + // asm { jsrCBM_OPEN } + jsr CBM_OPEN + // fopen::cbm_k_readst1 + // char status + // [1967] fopen::cbm_k_readst1_status = 0 -- vbum1=vbuc1 + lda #0 + sta cbm_k_readst1_status + // asm + // asm { jsrCBM_READST stastatus } + jsr CBM_READST + sta cbm_k_readst1_status + // return status; + // [1969] fopen::cbm_k_readst1_return#0 = fopen::cbm_k_readst1_status -- vbum1=vbum2 + sta cbm_k_readst1_return + // fopen::cbm_k_readst1_@return // } - // [2736] return - rts - // Outside Flow - icall40: - jmp (putc) - .segment Data - buffer_sign: .byte 0 - .label format_min_length = printf_uchar.format_min_length - .label format_zero_padding = printf_uchar.format_zero_padding - len: .byte 0 - .label padding = len -} -.segment CodeVera - // vera_verify -vera_verify: { - .label vera_verify__16 = $a9 - .label vera_bram_ptr = $c0 - // vera_verify::bank_set_bram1 - // BRAM = bank - // [2738] BRAM = 1 -- vbuz1=vbuc1 - lda #1 - sta.z BRAM - // vera_verify::@11 - // unsigned long vera_boundary = vera_file_size - // [2739] vera_verify::vera_boundary#0 = vera_file_size#1 -- vdum1=vdum2 - lda vera_file_size - sta vera_boundary - lda vera_file_size+1 - sta vera_boundary+1 - lda vera_file_size+2 - sta vera_boundary+2 - lda vera_file_size+3 - sta vera_boundary+3 - // [2740] spi_manufacturer#597 = spi_read::return#0 -- vbum1=vbum2 - lda spi_read.return - sta spi_manufacturer - // [2741] spi_memory_type#598 = spi_read::return#1 -- vbum1=vbum2 - lda spi_read.return_1 - sta spi_memory_type - // [2742] spi_memory_capacity#599 = spi_read::return#2 -- vbum1=vbum2 - lda spi_read.return_2 - sta spi_memory_capacity - // display_info_vera(STATUS_COMPARING, "Comparing VERA ...") - // [2743] call display_info_vera - // [998] phi from vera_verify::@11 to display_info_vera [phi:vera_verify::@11->display_info_vera] - // [998] phi display_info_vera::info_text#19 = vera_verify::info_text [phi:vera_verify::@11->display_info_vera#0] -- pbuz1=pbuc1 - lda #info_text - sta.z display_info_vera.info_text+1 - // [998] phi spi_memory_capacity#106 = spi_memory_capacity#599 [phi:vera_verify::@11->display_info_vera#1] -- register_copy - // [998] phi spi_memory_type#107 = spi_memory_type#598 [phi:vera_verify::@11->display_info_vera#2] -- register_copy - // [998] phi spi_manufacturer#108 = spi_manufacturer#597 [phi:vera_verify::@11->display_info_vera#3] -- register_copy - // [998] phi display_info_vera::info_status#19 = STATUS_COMPARING [phi:vera_verify::@11->display_info_vera#4] -- vbum1=vbuc1 - lda #STATUS_COMPARING - sta display_info_vera.info_status - jsr display_info_vera - // [2744] phi from vera_verify::@11 to vera_verify::@12 [phi:vera_verify::@11->vera_verify::@12] - // vera_verify::@12 - // gotoxy(x, y) - // [2745] call gotoxy - // [802] phi from vera_verify::@12 to gotoxy [phi:vera_verify::@12->gotoxy] - // [802] phi gotoxy::y#37 = PROGRESS_Y [phi:vera_verify::@12->gotoxy#0] -- vbum1=vbuc1 - lda #PROGRESS_Y - sta gotoxy.y - // [802] phi gotoxy::x#37 = PROGRESS_X [phi:vera_verify::@12->gotoxy#1] -- vbum1=vbuc1 - lda #PROGRESS_X - sta gotoxy.x - jsr gotoxy - // [2746] phi from vera_verify::@12 to vera_verify::@13 [phi:vera_verify::@12->vera_verify::@13] - // vera_verify::@13 - // spi_read_flash(0UL) - // [2747] call spi_read_flash - // [3306] phi from vera_verify::@13 to spi_read_flash [phi:vera_verify::@13->spi_read_flash] - jsr spi_read_flash - // [2748] phi from vera_verify::@13 to vera_verify::@1 [phi:vera_verify::@13->vera_verify::@1] - // [2748] phi vera_verify::y#3 = PROGRESS_Y [phi:vera_verify::@13->vera_verify::@1#0] -- vbum1=vbuc1 - lda #PROGRESS_Y - sta y - // [2748] phi vera_verify::progress_row_current#3 = 0 [phi:vera_verify::@13->vera_verify::@1#1] -- vwum1=vwuc1 - lda #<0 - sta progress_row_current - sta progress_row_current+1 - // [2748] phi vera_verify::vera_different_bytes#11 = 0 [phi:vera_verify::@13->vera_verify::@1#2] -- vdum1=vduc1 - sta vera_different_bytes - sta vera_different_bytes+1 - lda #<0>>$10 - sta vera_different_bytes+2 - lda #>0>>$10 - sta vera_different_bytes+3 - // [2748] phi vera_verify::vera_bram_ptr#10 = (char *)$a000 [phi:vera_verify::@13->vera_verify::@1#3] -- pbuz1=pbuc1 - lda #<$a000 - sta.z vera_bram_ptr - lda #>$a000 - sta.z vera_bram_ptr+1 - // [2748] phi vera_verify::vera_bram_bank#11 = 1 [phi:vera_verify::@13->vera_verify::@1#4] -- vbum1=vbuc1 - lda #1 - sta vera_bram_bank - // [2748] phi vera_verify::vera_address#11 = 0 [phi:vera_verify::@13->vera_verify::@1#5] -- vdum1=vduc1 + // [1970] fopen::cbm_k_readst1_return#1 = fopen::cbm_k_readst1_return#0 + // fopen::@29 + // cbm_k_readst() + // [1971] fopen::$15 = fopen::cbm_k_readst1_return#1 -- vbuz1=vbum2 + sta.z fopen__15 + // __status = cbm_k_readst() + // [1972] ((char *)&__stdio_file+$46)[fopen::sp#0] = fopen::$15 -- pbuc1_derefidx_vbum1=vbuz2 + ldy sp + sta __stdio_file+$46,y + // ferror(stream) + // [1973] ferror::stream#0 = (struct $2 *)fopen::stream#0 + // [1974] call ferror + jsr ferror + // [1975] ferror::return#0 = ferror::return#1 + // fopen::@32 + // [1976] fopen::$16 = ferror::return#0 -- vwsz1=vwsm2 + lda ferror.return + sta.z fopen__16 + lda ferror.return+1 + sta.z fopen__16+1 + // if (ferror(stream)) + // [1977] if(0==fopen::$16) goto fopen::@4 -- 0_eq_vwsz1_then_la1 + lda.z fopen__16 + ora.z fopen__16+1 + beq __b4 + // fopen::@7 + // cbm_k_close(__logical) + // [1978] fopen::cbm_k_close1_channel = ((char *)&__stdio_file+$40)[fopen::sp#0] -- vbum1=pbuc1_derefidx_vbum2 + ldy sp + lda __stdio_file+$40,y + sta cbm_k_close1_channel + // fopen::cbm_k_close1 + // asm + // asm { ldachannel jsrCBM_CLOSE } + jsr CBM_CLOSE + // [1980] phi from fopen::cbm_k_close1 to fopen::@return [phi:fopen::cbm_k_close1->fopen::@return] + // [1980] phi __stdio_filecount#1 = __stdio_filecount#105 [phi:fopen::cbm_k_close1->fopen::@return#0] -- register_copy + // [1980] phi fopen::return#2 = 0 [phi:fopen::cbm_k_close1->fopen::@return#1] -- pssz1=vbuc1 lda #<0 - sta vera_address - sta vera_address+1 - lda #<0>>$10 - sta vera_address+2 - lda #>0>>$10 - sta vera_address+3 - // vera_verify::@1 - __b1: - // while (vera_address < vera_boundary) - // [2749] if(vera_verify::vera_address#11vera_compare] - jsr vera_compare - // unsigned int equal_bytes = vera_compare(vera_bram_bank, (bram_ptr_t)vera_bram_ptr, VERA_PROGRESS_CELL) - // [2754] vera_compare::return#0 = vera_compare::equal_bytes#2 - // vera_verify::@14 - // [2755] vera_verify::equal_bytes#0 = vera_compare::return#0 - // if (progress_row_current == VERA_PROGRESS_ROW) - // [2756] if(vera_verify::progress_row_current#3!=VERA_PROGRESS_ROW) goto vera_verify::@3 -- vwum1_neq_vwuc1_then_la1 - lda progress_row_current+1 - cmp #>VERA_PROGRESS_ROW - bne __b3 - lda progress_row_current - cmp #gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#8 [phi:vera_verify::@8->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = PROGRESS_X [phi:vera_verify::@8->gotoxy#1] -- vbum1=vbuc1 - lda #PROGRESS_X - sta gotoxy.x - jsr gotoxy - // [2760] phi from vera_verify::@8 to vera_verify::@3 [phi:vera_verify::@8->vera_verify::@3] - // [2760] phi vera_verify::y#10 = vera_verify::y#1 [phi:vera_verify::@8->vera_verify::@3#0] -- register_copy - // [2760] phi vera_verify::progress_row_current#4 = 0 [phi:vera_verify::@8->vera_verify::@3#1] -- vwum1=vbuc1 - lda #<0 - sta progress_row_current - sta progress_row_current+1 - // [2760] phi from vera_verify::@14 to vera_verify::@3 [phi:vera_verify::@14->vera_verify::@3] - // [2760] phi vera_verify::y#10 = vera_verify::y#3 [phi:vera_verify::@14->vera_verify::@3#0] -- register_copy - // [2760] phi vera_verify::progress_row_current#4 = vera_verify::progress_row_current#3 [phi:vera_verify::@14->vera_verify::@3#1] -- register_copy - // vera_verify::@3 - __b3: - // if (equal_bytes != VERA_PROGRESS_CELL) - // [2761] if(vera_verify::equal_bytes#0!=VERA_PROGRESS_CELL) goto vera_verify::@4 -- vwum1_neq_vbuc1_then_la1 - lda equal_bytes+1 - beq !__b4+ - jmp __b4 - !__b4: - lda equal_bytes - cmp #VERA_PROGRESS_CELL - beq !__b4+ - jmp __b4 - !__b4: - // vera_verify::@9 - // cputc('=') - // [2762] stackpush(char) = '=' -- _stackpushbyte_=vbuc1 - lda #'=' - pha - // [2763] callexecute cputc -- call_vprc1 - jsr cputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // vera_verify::@5 - __b5: - // vera_bram_ptr += VERA_PROGRESS_CELL - // [2765] vera_verify::vera_bram_ptr#1 = vera_verify::vera_bram_ptr#10 + VERA_PROGRESS_CELL -- pbuz1=pbuz1_plus_vbuc1 - lda #VERA_PROGRESS_CELL - clc - adc.z vera_bram_ptr - sta.z vera_bram_ptr - bcc !+ - inc.z vera_bram_ptr+1 - !: - // vera_address += VERA_PROGRESS_CELL - // [2766] vera_verify::vera_address#1 = vera_verify::vera_address#11 + VERA_PROGRESS_CELL -- vdum1=vdum1_plus_vbuc1 - lda vera_address + // fopen::@4 + __b4: + // __stdio_filecount++; + // [1982] __stdio_filecount#0 = ++ __stdio_filecount#105 -- vbum1=_inc_vbum1 + inc __stdio_filecount + // [1983] fopen::return#6 = (struct $2 *)fopen::stream#0 + // [1980] phi from fopen::@4 to fopen::@return [phi:fopen::@4->fopen::@return] + // [1980] phi __stdio_filecount#1 = __stdio_filecount#0 [phi:fopen::@4->fopen::@return#0] -- register_copy + // [1980] phi fopen::return#2 = fopen::return#6 [phi:fopen::@4->fopen::@return#1] -- register_copy + rts + // fopen::@9 + __b9: + // if (pathstep > 0) + // [1984] if(fopen::pathstep#10>0) goto fopen::@11 -- vbum1_gt_0_then_la1 + lda pathstep + bne __b11 + // fopen::@25 + // __stdio_file.filename[pathpos] = '\0' + // [1985] ((char *)&__stdio_file)[fopen::pathpos#10] = '@' -- pbuc1_derefidx_vbum1=vbuc2 + lda #'@' + ldy pathpos_1 + sta __stdio_file,y + // path = pathtoken + 1 + // [1986] fopen::path#0 = fopen::pathtoken#10 + 1 -- pbuz1=pbuz2_plus_1 clc - adc #VERA_PROGRESS_CELL - sta vera_address - bcc !+ - inc vera_address+1 - bne !+ - inc vera_address+2 + lda.z pathtoken + adc #1 + sta.z path + lda.z pathtoken+1 + adc #0 + sta.z path+1 + // [1987] phi from fopen::@16 fopen::@17 fopen::@18 fopen::@19 fopen::@25 to fopen::@12 [phi:fopen::@16/fopen::@17/fopen::@18/fopen::@19/fopen::@25->fopen::@12] + // [1987] phi fopen::num#15 = fopen::num#2 [phi:fopen::@16/fopen::@17/fopen::@18/fopen::@19/fopen::@25->fopen::@12#0] -- register_copy + // [1987] phi fopen::path#12 = fopen::path#15 [phi:fopen::@16/fopen::@17/fopen::@18/fopen::@19/fopen::@25->fopen::@12#1] -- register_copy + // fopen::@12 + __b12: + // pathstep++; + // [1988] fopen::pathstep#1 = ++ fopen::pathstep#10 -- vbum1=_inc_vbum1 + inc pathstep + jmp __b10 + // fopen::@11 + __b11: + // char pathcmp = *path + // [1989] fopen::pathcmp#0 = *fopen::path#13 -- vbum1=_deref_pbuz2 + ldy #0 + lda (path),y + sta pathcmp + // case 'D': + // [1990] if(fopen::pathcmp#0=='D') goto fopen::@13 -- vbum1_eq_vbuc1_then_la1 + lda #'D' + cmp pathcmp + beq __b13 + // fopen::@20 + // case 'L': + // [1991] if(fopen::pathcmp#0=='L') goto fopen::@13 -- vbum1_eq_vbuc1_then_la1 + lda #'L' + cmp pathcmp + beq __b13 + // fopen::@21 + // case 'C': + // num = (char)atoi(path + 1); + // path = pathtoken + 1; + // [1992] if(fopen::pathcmp#0=='C') goto fopen::@13 -- vbum1_eq_vbuc1_then_la1 + lda #'C' + cmp pathcmp + beq __b13 + // [1993] phi from fopen::@21 fopen::@30 to fopen::@14 [phi:fopen::@21/fopen::@30->fopen::@14] + // [1993] phi fopen::path#15 = fopen::path#13 [phi:fopen::@21/fopen::@30->fopen::@14#0] -- register_copy + // [1993] phi fopen::num#2 = fopen::num#10 [phi:fopen::@21/fopen::@30->fopen::@14#1] -- register_copy + // fopen::@14 + __b14: + // case 'L': + // __logical = num; + // break; + // [1994] if(fopen::pathcmp#0=='L') goto fopen::@17 -- vbum1_eq_vbuc1_then_la1 + lda #'L' + cmp pathcmp + beq __b17 + // fopen::@15 + // case 'D': + // __device = num; + // break; + // [1995] if(fopen::pathcmp#0=='D') goto fopen::@18 -- vbum1_eq_vbuc1_then_la1 + lda #'D' + cmp pathcmp + beq __b18 + // fopen::@16 + // case 'C': + // __channel = num; + // break; + // [1996] if(fopen::pathcmp#0!='C') goto fopen::@12 -- vbum1_neq_vbuc1_then_la1 + lda #'C' + cmp pathcmp + bne __b12 + // fopen::@19 + // __channel = num + // [1997] ((char *)&__stdio_file+$44)[fopen::sp#0] = fopen::num#2 -- pbuc1_derefidx_vbum1=vbum2 + lda num + ldy sp + sta __stdio_file+$44,y + jmp __b12 + // fopen::@18 + __b18: + // __device = num + // [1998] ((char *)&__stdio_file+$42)[fopen::sp#0] = fopen::num#2 -- pbuc1_derefidx_vbum1=vbum2 + lda num + ldy sp + sta __stdio_file+$42,y + jmp __b12 + // fopen::@17 + __b17: + // __logical = num + // [1999] ((char *)&__stdio_file+$40)[fopen::sp#0] = fopen::num#2 -- pbuc1_derefidx_vbum1=vbum2 + lda num + ldy sp + sta __stdio_file+$40,y + jmp __b12 + // fopen::@13 + __b13: + // atoi(path + 1) + // [2000] atoi::str#0 = fopen::path#13 + 1 -- pbuz1=pbuz1_plus_1 + inc.z atoi.str bne !+ - inc vera_address+3 - !: - // progress_row_current += VERA_PROGRESS_CELL - // [2767] vera_verify::progress_row_current#11 = vera_verify::progress_row_current#4 + VERA_PROGRESS_CELL -- vwum1=vwum1_plus_vbuc1 - lda #VERA_PROGRESS_CELL - clc - adc progress_row_current - sta progress_row_current - bcc !+ - inc progress_row_current+1 + inc.z atoi.str+1 !: - // if (vera_bram_ptr == BRAM_HIGH) - // [2768] if(vera_verify::vera_bram_ptr#1!=$c000) goto vera_verify::@6 -- pbuz1_neq_vwuc1_then_la1 - lda.z vera_bram_ptr+1 - cmp #>$c000 - bne __b6 - lda.z vera_bram_ptr - cmp #<$c000 - bne __b6 - // vera_verify::@10 - // vera_bram_bank++; - // [2769] vera_verify::vera_bram_bank#1 = ++ vera_verify::vera_bram_bank#11 -- vbum1=_inc_vbum1 - inc vera_bram_bank - // [2770] phi from vera_verify::@10 to vera_verify::@6 [phi:vera_verify::@10->vera_verify::@6] - // [2770] phi vera_verify::vera_bram_bank#25 = vera_verify::vera_bram_bank#1 [phi:vera_verify::@10->vera_verify::@6#0] -- register_copy - // [2770] phi vera_verify::vera_bram_ptr#6 = (char *)$a000 [phi:vera_verify::@10->vera_verify::@6#1] -- pbuz1=pbuc1 - lda #<$a000 - sta.z vera_bram_ptr - lda #>$a000 - sta.z vera_bram_ptr+1 - // [2770] phi from vera_verify::@5 to vera_verify::@6 [phi:vera_verify::@5->vera_verify::@6] - // [2770] phi vera_verify::vera_bram_bank#25 = vera_verify::vera_bram_bank#11 [phi:vera_verify::@5->vera_verify::@6#0] -- register_copy - // [2770] phi vera_verify::vera_bram_ptr#6 = vera_verify::vera_bram_ptr#1 [phi:vera_verify::@5->vera_verify::@6#1] -- register_copy - // vera_verify::@6 - __b6: - // if (vera_bram_ptr == RAM_HIGH) - // [2771] if(vera_verify::vera_bram_ptr#6!=$9800) goto vera_verify::@24 -- pbuz1_neq_vwuc1_then_la1 - lda.z vera_bram_ptr+1 - cmp #>$9800 - bne __b7 - lda.z vera_bram_ptr - cmp #<$9800 - bne __b7 - // [2773] phi from vera_verify::@6 to vera_verify::@7 [phi:vera_verify::@6->vera_verify::@7] - // [2773] phi vera_verify::vera_bram_ptr#11 = (char *)$a000 [phi:vera_verify::@6->vera_verify::@7#0] -- pbuz1=pbuc1 - lda #<$a000 - sta.z vera_bram_ptr - lda #>$a000 - sta.z vera_bram_ptr+1 - // [2773] phi vera_verify::vera_bram_bank#10 = 1 [phi:vera_verify::@6->vera_verify::@7#1] -- vbum1=vbuc1 - lda #1 - sta vera_bram_bank - // [2772] phi from vera_verify::@6 to vera_verify::@24 [phi:vera_verify::@6->vera_verify::@24] - // vera_verify::@24 - // [2773] phi from vera_verify::@24 to vera_verify::@7 [phi:vera_verify::@24->vera_verify::@7] - // [2773] phi vera_verify::vera_bram_ptr#11 = vera_verify::vera_bram_ptr#6 [phi:vera_verify::@24->vera_verify::@7#0] -- register_copy - // [2773] phi vera_verify::vera_bram_bank#10 = vera_verify::vera_bram_bank#25 [phi:vera_verify::@24->vera_verify::@7#1] -- register_copy - // vera_verify::@7 - __b7: - // VERA_PROGRESS_CELL - equal_bytes - // [2774] vera_verify::$16 = VERA_PROGRESS_CELL - vera_verify::equal_bytes#0 -- vwuz1=vwuc1_minus_vwum2 - sec - lda #VERA_PROGRESS_CELL - sbc equal_bytes+1 - sta.z vera_verify__16+1 - // vera_different_bytes += (VERA_PROGRESS_CELL - equal_bytes) - // [2775] vera_verify::vera_different_bytes#1 = vera_verify::vera_different_bytes#11 + vera_verify::$16 -- vdum1=vdum1_plus_vwuz2 - lda vera_different_bytes + // [2001] call atoi + // [2311] phi from fopen::@13 to atoi [phi:fopen::@13->atoi] + // [2311] phi atoi::str#2 = atoi::str#0 [phi:fopen::@13->atoi#0] -- register_copy + jsr atoi + // atoi(path + 1) + // [2002] atoi::return#3 = atoi::return#2 + // fopen::@30 + // [2003] fopen::$26 = atoi::return#3 -- vwsz1=vwsm2 + lda atoi.return + sta.z fopen__26 + lda atoi.return+1 + sta.z fopen__26+1 + // num = (char)atoi(path + 1) + // [2004] fopen::num#1 = (char)fopen::$26 -- vbum1=_byte_vwsz2 + lda.z fopen__26 + sta num + // path = pathtoken + 1 + // [2005] fopen::path#1 = fopen::pathtoken#10 + 1 -- pbuz1=pbuz2_plus_1 clc - adc.z vera_verify__16 - sta vera_different_bytes - lda vera_different_bytes+1 - adc.z vera_verify__16+1 - sta vera_different_bytes+1 - lda vera_different_bytes+2 - adc #0 - sta vera_different_bytes+2 - lda vera_different_bytes+3 + lda.z pathtoken + adc #1 + sta.z path + lda.z pathtoken+1 adc #0 - sta vera_different_bytes+3 - // sprintf(info_text, "Comparing: %05x differences between RAM:%02x:%04p <-> ROM:%05x", vera_different_bytes, vera_bram_bank, vera_bram_ptr, vera_address) - // [2776] call snprintf_init - // [1205] phi from vera_verify::@7 to snprintf_init [phi:vera_verify::@7->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:vera_verify::@7->snprintf_init#0] -- pbuz1=pbuc1 - lda #<@info_text - sta.z snprintf_init.s - lda #>@info_text - sta.z snprintf_init.s+1 - jsr snprintf_init - // [2777] phi from vera_verify::@7 to vera_verify::@15 [phi:vera_verify::@7->vera_verify::@15] - // vera_verify::@15 - // sprintf(info_text, "Comparing: %05x differences between RAM:%02x:%04p <-> ROM:%05x", vera_different_bytes, vera_bram_bank, vera_bram_ptr, vera_address) - // [2778] call printf_str - // [1210] phi from vera_verify::@15 to printf_str [phi:vera_verify::@15->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:vera_verify::@15->printf_str#0] -- pprz1=pprc1 - lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s [phi:vera_verify::@15->printf_str#1] -- pbuz1=pbuc1 - lda #s - sta.z printf_str.s+1 - jsr printf_str - // vera_verify::@16 - // sprintf(info_text, "Comparing: %05x differences between RAM:%02x:%04p <-> ROM:%05x", vera_different_bytes, vera_bram_bank, vera_bram_ptr, vera_address) - // [2779] printf_ulong::uvalue#0 = vera_verify::vera_different_bytes#1 -- vdum1=vdum2 - lda vera_different_bytes - sta printf_ulong.uvalue - lda vera_different_bytes+1 - sta printf_ulong.uvalue+1 - lda vera_different_bytes+2 - sta printf_ulong.uvalue+2 - lda vera_different_bytes+3 - sta printf_ulong.uvalue+3 - // [2780] call printf_ulong - // [1741] phi from vera_verify::@16 to printf_ulong [phi:vera_verify::@16->printf_ulong] - // [1741] phi printf_ulong::format_zero_padding#15 = 1 [phi:vera_verify::@16->printf_ulong#0] -- vbum1=vbuc1 - lda #1 - sta printf_ulong.format_zero_padding - // [1741] phi printf_ulong::format_min_length#15 = 5 [phi:vera_verify::@16->printf_ulong#1] -- vbum1=vbuc1 - lda #5 - sta printf_ulong.format_min_length - // [1741] phi printf_ulong::format_radix#15 = HEXADECIMAL [phi:vera_verify::@16->printf_ulong#2] -- vbum1=vbuc1 - lda #HEXADECIMAL - sta printf_ulong.format_radix - // [1741] phi printf_ulong::uvalue#15 = printf_ulong::uvalue#0 [phi:vera_verify::@16->printf_ulong#3] -- register_copy - jsr printf_ulong - // [2781] phi from vera_verify::@16 to vera_verify::@17 [phi:vera_verify::@16->vera_verify::@17] - // vera_verify::@17 - // sprintf(info_text, "Comparing: %05x differences between RAM:%02x:%04p <-> ROM:%05x", vera_different_bytes, vera_bram_bank, vera_bram_ptr, vera_address) - // [2782] call printf_str - // [1210] phi from vera_verify::@17 to printf_str [phi:vera_verify::@17->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:vera_verify::@17->printf_str#0] -- pprz1=pprc1 + sta.z path+1 + jmp __b14 + .segment Data + cbm_k_setnam1_filename_len: .byte 0 + cbm_k_readst1_status: .byte 0 + cbm_k_close1_channel: .byte 0 + sp: .byte 0 + pathpos: .byte 0 + pathpos_1: .byte 0 + pathcmp: .byte 0 + // Parse path + pathstep: .byte 0 + num: .byte 0 + cbm_k_readst1_return: .byte 0 +} +.segment Code + // fclose +/** + * @brief Close a file. + * + * @param fp The FILE pointer. + * @return + * - 0x0000: Something is wrong! Kernal Error Code (https://commodore.ca/manuals/pdfs/commodore_error_messages.pdf) + * - other: OK! The last pointer between 0xA000 and 0xBFFF is returned. Note that the last pointer is indicating the first free byte. + */ +// int fclose(__zp($4f) struct $2 *stream) +fclose: { + .label fclose__1 = $3b + .label fclose__4 = $38 + .label fclose__6 = $39 + .label stream = $4f + // unsigned char sp = (unsigned char)stream + // [2006] fclose::sp#0 = (char)fclose::stream#0 -- vbum1=_byte_pssz2 + lda.z stream + sta sp + // cbm_k_chkin(__logical) + // [2007] fclose::cbm_k_chkin1_channel = ((char *)&__stdio_file+$40)[fclose::sp#0] -- vbum1=pbuc1_derefidx_vbum2 + tay + lda __stdio_file+$40,y + sta cbm_k_chkin1_channel + // fclose::cbm_k_chkin1 + // char status + // [2008] fclose::cbm_k_chkin1_status = 0 -- vbum1=vbuc1 + lda #0 + sta cbm_k_chkin1_status + // asm + // asm { ldxchannel jsrCBM_CHKIN stastatus } + ldx cbm_k_chkin1_channel + jsr CBM_CHKIN + sta cbm_k_chkin1_status + // fclose::cbm_k_readst1 + // char status + // [2010] fclose::cbm_k_readst1_status = 0 -- vbum1=vbuc1 + lda #0 + sta cbm_k_readst1_status + // asm + // asm { jsrCBM_READST stastatus } + jsr CBM_READST + sta cbm_k_readst1_status + // return status; + // [2012] fclose::cbm_k_readst1_return#0 = fclose::cbm_k_readst1_status -- vbum1=vbum2 + sta cbm_k_readst1_return + // fclose::cbm_k_readst1_@return + // } + // [2013] fclose::cbm_k_readst1_return#1 = fclose::cbm_k_readst1_return#0 + // fclose::@3 + // cbm_k_readst() + // [2014] fclose::$1 = fclose::cbm_k_readst1_return#1 -- vbuz1=vbum2 + sta.z fclose__1 + // __status = cbm_k_readst() + // [2015] ((char *)&__stdio_file+$46)[fclose::sp#0] = fclose::$1 -- pbuc1_derefidx_vbum1=vbuz2 + ldy sp + sta __stdio_file+$46,y + // if (__status) + // [2016] if(0==((char *)&__stdio_file+$46)[fclose::sp#0]) goto fclose::@1 -- 0_eq_pbuc1_derefidx_vbum1_then_la1 + lda __stdio_file+$46,y + cmp #0 + beq __b1 + // [2017] phi from fclose::@2 fclose::@3 fclose::@4 to fclose::@return [phi:fclose::@2/fclose::@3/fclose::@4->fclose::@return] + // [2017] phi __stdio_filecount#2 = __stdio_filecount#3 [phi:fclose::@2/fclose::@3/fclose::@4->fclose::@return#0] -- register_copy + // fclose::@return + // } + // [2018] return + rts + // fclose::@1 + __b1: + // cbm_k_close(__logical) + // [2019] fclose::cbm_k_close1_channel = ((char *)&__stdio_file+$40)[fclose::sp#0] -- vbum1=pbuc1_derefidx_vbum2 + ldy sp + lda __stdio_file+$40,y + sta cbm_k_close1_channel + // fclose::cbm_k_close1 + // asm + // asm { ldachannel jsrCBM_CLOSE } + jsr CBM_CLOSE + // fclose::cbm_k_readst2 + // char status + // [2021] fclose::cbm_k_readst2_status = 0 -- vbum1=vbuc1 + lda #0 + sta cbm_k_readst2_status + // asm + // asm { jsrCBM_READST stastatus } + jsr CBM_READST + sta cbm_k_readst2_status + // return status; + // [2023] fclose::cbm_k_readst2_return#0 = fclose::cbm_k_readst2_status -- vbum1=vbum2 + sta cbm_k_readst2_return + // fclose::cbm_k_readst2_@return + // } + // [2024] fclose::cbm_k_readst2_return#1 = fclose::cbm_k_readst2_return#0 + // fclose::@4 + // cbm_k_readst() + // [2025] fclose::$4 = fclose::cbm_k_readst2_return#1 -- vbuz1=vbum2 + sta.z fclose__4 + // __status = cbm_k_readst() + // [2026] ((char *)&__stdio_file+$46)[fclose::sp#0] = fclose::$4 -- pbuc1_derefidx_vbum1=vbuz2 + ldy sp + sta __stdio_file+$46,y + // if (__status) + // [2027] if(0==((char *)&__stdio_file+$46)[fclose::sp#0]) goto fclose::@2 -- 0_eq_pbuc1_derefidx_vbum1_then_la1 + lda __stdio_file+$46,y + cmp #0 + beq __b2 + rts + // fclose::@2 + __b2: + // __logical = 0 + // [2028] ((char *)&__stdio_file+$40)[fclose::sp#0] = 0 -- pbuc1_derefidx_vbum1=vbuc2 + lda #0 + ldy sp + sta __stdio_file+$40,y + // __device = 0 + // [2029] ((char *)&__stdio_file+$42)[fclose::sp#0] = 0 -- pbuc1_derefidx_vbum1=vbuc2 + sta __stdio_file+$42,y + // __channel = 0 + // [2030] ((char *)&__stdio_file+$44)[fclose::sp#0] = 0 -- pbuc1_derefidx_vbum1=vbuc2 + sta __stdio_file+$44,y + // __filename + // [2031] fclose::$6 = fclose::sp#0 << 1 -- vbuz1=vbum2_rol_1 + tya + asl + sta.z fclose__6 + // *__filename = '\0' + // [2032] ((char *)&__stdio_file)[fclose::$6] = '@' -- pbuc1_derefidx_vbuz1=vbuc2 + lda #'@' + ldy.z fclose__6 + sta __stdio_file,y + // __stdio_filecount--; + // [2033] __stdio_filecount#3 = -- __stdio_filecount#1 -- vbum1=_dec_vbum1 + dec __stdio_filecount + rts + .segment Data + cbm_k_chkin1_channel: .byte 0 + cbm_k_chkin1_status: .byte 0 + cbm_k_readst1_status: .byte 0 + cbm_k_close1_channel: .byte 0 + cbm_k_readst2_status: .byte 0 + sp: .byte 0 + cbm_k_readst1_return: .byte 0 + cbm_k_readst2_return: .byte 0 +} +.segment Code + // display_action_text_reading +// void display_action_text_reading(__zp($42) char *action, char *file, __mem() unsigned long bytes, unsigned long size, __mem() char bram_bank, __zp($6c) char *bram_ptr) +display_action_text_reading: { + .label action = $42 + .label bram_ptr = $6c + // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) + // [2035] call snprintf_init + jsr snprintf_init + // display_action_text_reading::@1 + // [2036] printf_string::str#14 = display_action_text_reading::action#0 + // [2037] call printf_string + // [1308] phi from display_action_text_reading::@1 to printf_string [phi:display_action_text_reading::@1->printf_string] + // [1308] phi printf_string::putc#17 = &snputc [phi:display_action_text_reading::@1->printf_string#0] -- pprz1=pprc1 + lda #snputc + sta.z printf_string.putc+1 + // [1308] phi printf_string::str#17 = printf_string::str#14 [phi:display_action_text_reading::@1->printf_string#1] -- register_copy + // [1308] phi printf_string::format_justify_left#17 = 0 [phi:display_action_text_reading::@1->printf_string#2] -- vbum1=vbuc1 + lda #0 + sta printf_string.format_justify_left + // [1308] phi printf_string::format_min_length#17 = 0 [phi:display_action_text_reading::@1->printf_string#3] -- vbum1=vbuc1 + sta printf_string.format_min_length + jsr printf_string + // [2038] phi from display_action_text_reading::@1 to display_action_text_reading::@2 [phi:display_action_text_reading::@1->display_action_text_reading::@2] + // display_action_text_reading::@2 + // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) + // [2039] call printf_str + // [785] phi from display_action_text_reading::@2 to printf_str [phi:display_action_text_reading::@2->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:display_action_text_reading::@2->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s1 [phi:vera_verify::@17->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #s1 + lda #>s sta.z printf_str.s+1 jsr printf_str - // vera_verify::@18 - // sprintf(info_text, "Comparing: %05x differences between RAM:%02x:%04p <-> ROM:%05x", vera_different_bytes, vera_bram_bank, vera_bram_ptr, vera_address) - // [2783] printf_uchar::uvalue#0 = vera_verify::vera_bram_bank#10 -- vbum1=vbum2 - lda vera_bram_bank - sta printf_uchar.uvalue - // [2784] call printf_uchar - // [1346] phi from vera_verify::@18 to printf_uchar [phi:vera_verify::@18->printf_uchar] - // [1346] phi printf_uchar::format_zero_padding#18 = 1 [phi:vera_verify::@18->printf_uchar#0] -- vbum1=vbuc1 + // [2040] phi from display_action_text_reading::@2 to display_action_text_reading::@3 [phi:display_action_text_reading::@2->display_action_text_reading::@3] + // display_action_text_reading::@3 + // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) + // [2041] call printf_string + // [1308] phi from display_action_text_reading::@3 to printf_string [phi:display_action_text_reading::@3->printf_string] + // [1308] phi printf_string::putc#17 = &snputc [phi:display_action_text_reading::@3->printf_string#0] -- pprz1=pprc1 + lda #snputc + sta.z printf_string.putc+1 + // [1308] phi printf_string::str#17 = vera_read::path [phi:display_action_text_reading::@3->printf_string#1] -- pbuz1=pbuc1 + lda #vera_read.path + sta.z printf_string.str+1 + // [1308] phi printf_string::format_justify_left#17 = 0 [phi:display_action_text_reading::@3->printf_string#2] -- vbum1=vbuc1 + lda #0 + sta printf_string.format_justify_left + // [1308] phi printf_string::format_min_length#17 = 0 [phi:display_action_text_reading::@3->printf_string#3] -- vbum1=vbuc1 + sta printf_string.format_min_length + jsr printf_string + // [2042] phi from display_action_text_reading::@3 to display_action_text_reading::@4 [phi:display_action_text_reading::@3->display_action_text_reading::@4] + // display_action_text_reading::@4 + // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) + // [2043] call printf_str + // [785] phi from display_action_text_reading::@4 to printf_str [phi:display_action_text_reading::@4->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:display_action_text_reading::@4->printf_str#0] -- pprz1=pprc1 + lda #snputc + sta.z printf_str.putc+1 + // [785] phi printf_str::s#53 = s2 [phi:display_action_text_reading::@4->printf_str#1] -- pbuz1=pbuc1 + lda #<@s2 + sta.z printf_str.s + lda #>@s2 + sta.z printf_str.s+1 + jsr printf_str + // display_action_text_reading::@5 + // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) + // [2044] printf_ulong::uvalue#5 = display_action_text_reading::bytes#0 + // [2045] call printf_ulong + // [1633] phi from display_action_text_reading::@5 to printf_ulong [phi:display_action_text_reading::@5->printf_ulong] + // [1633] phi printf_ulong::format_zero_padding#10 = 1 [phi:display_action_text_reading::@5->printf_ulong#0] -- vbum1=vbuc1 + lda #1 + sta printf_ulong.format_zero_padding + // [1633] phi printf_ulong::format_min_length#10 = 5 [phi:display_action_text_reading::@5->printf_ulong#1] -- vbum1=vbuc1 + lda #5 + sta printf_ulong.format_min_length + // [1633] phi printf_ulong::format_radix#10 = HEXADECIMAL [phi:display_action_text_reading::@5->printf_ulong#2] -- vbum1=vbuc1 + lda #HEXADECIMAL + sta printf_ulong.format_radix + // [1633] phi printf_ulong::uvalue#10 = printf_ulong::uvalue#5 [phi:display_action_text_reading::@5->printf_ulong#3] -- register_copy + jsr printf_ulong + // [2046] phi from display_action_text_reading::@5 to display_action_text_reading::@6 [phi:display_action_text_reading::@5->display_action_text_reading::@6] + // display_action_text_reading::@6 + // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) + // [2047] call printf_str + // [785] phi from display_action_text_reading::@6 to printf_str [phi:display_action_text_reading::@6->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:display_action_text_reading::@6->printf_str#0] -- pprz1=pprc1 + lda #snputc + sta.z printf_str.putc+1 + // [785] phi printf_str::s#53 = display_action_text_reading::s2 [phi:display_action_text_reading::@6->printf_str#1] -- pbuz1=pbuc1 + lda #s2 + sta.z printf_str.s+1 + jsr printf_str + // [2048] phi from display_action_text_reading::@6 to display_action_text_reading::@7 [phi:display_action_text_reading::@6->display_action_text_reading::@7] + // display_action_text_reading::@7 + // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) + // [2049] call printf_ulong + // [1633] phi from display_action_text_reading::@7 to printf_ulong [phi:display_action_text_reading::@7->printf_ulong] + // [1633] phi printf_ulong::format_zero_padding#10 = 1 [phi:display_action_text_reading::@7->printf_ulong#0] -- vbum1=vbuc1 + lda #1 + sta printf_ulong.format_zero_padding + // [1633] phi printf_ulong::format_min_length#10 = 5 [phi:display_action_text_reading::@7->printf_ulong#1] -- vbum1=vbuc1 + lda #5 + sta printf_ulong.format_min_length + // [1633] phi printf_ulong::format_radix#10 = HEXADECIMAL [phi:display_action_text_reading::@7->printf_ulong#2] -- vbum1=vbuc1 + lda #HEXADECIMAL + sta printf_ulong.format_radix + // [1633] phi printf_ulong::uvalue#10 = vera_size [phi:display_action_text_reading::@7->printf_ulong#3] -- vdum1=vduc1 + lda #vera_size + sta printf_ulong.uvalue+1 + lda #>$10 + sta printf_ulong.uvalue+2 + lda #>vera_size>>$10 + sta printf_ulong.uvalue+3 + jsr printf_ulong + // [2050] phi from display_action_text_reading::@7 to display_action_text_reading::@8 [phi:display_action_text_reading::@7->display_action_text_reading::@8] + // display_action_text_reading::@8 + // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) + // [2051] call printf_str + // [785] phi from display_action_text_reading::@8 to printf_str [phi:display_action_text_reading::@8->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:display_action_text_reading::@8->printf_str#0] -- pprz1=pprc1 + lda #snputc + sta.z printf_str.putc+1 + // [785] phi printf_str::s#53 = display_action_text_reading::s3 [phi:display_action_text_reading::@8->printf_str#1] -- pbuz1=pbuc1 + lda #s3 + sta.z printf_str.s+1 + jsr printf_str + // display_action_text_reading::@9 + // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) + // [2052] printf_uchar::uvalue#6 = display_action_text_reading::bram_bank#0 + // [2053] call printf_uchar + // [834] phi from display_action_text_reading::@9 to printf_uchar [phi:display_action_text_reading::@9->printf_uchar] + // [834] phi printf_uchar::format_zero_padding#10 = 1 [phi:display_action_text_reading::@9->printf_uchar#0] -- vbum1=vbuc1 lda #1 sta printf_uchar.format_zero_padding - // [1346] phi printf_uchar::format_min_length#18 = 2 [phi:vera_verify::@18->printf_uchar#1] -- vbum1=vbuc1 + // [834] phi printf_uchar::format_min_length#10 = 2 [phi:display_action_text_reading::@9->printf_uchar#1] -- vbum1=vbuc1 lda #2 sta printf_uchar.format_min_length - // [1346] phi printf_uchar::putc#18 = &snputc [phi:vera_verify::@18->printf_uchar#2] -- pprz1=pprc1 + // [834] phi printf_uchar::putc#10 = &snputc [phi:display_action_text_reading::@9->printf_uchar#2] -- pprz1=pprc1 lda #snputc sta.z printf_uchar.putc+1 - // [1346] phi printf_uchar::format_radix#18 = HEXADECIMAL [phi:vera_verify::@18->printf_uchar#3] -- vbum1=vbuc1 + // [834] phi printf_uchar::format_radix#10 = HEXADECIMAL [phi:display_action_text_reading::@9->printf_uchar#3] -- vbum1=vbuc1 lda #HEXADECIMAL sta printf_uchar.format_radix - // [1346] phi printf_uchar::uvalue#18 = printf_uchar::uvalue#0 [phi:vera_verify::@18->printf_uchar#4] -- register_copy + // [834] phi printf_uchar::uvalue#10 = printf_uchar::uvalue#6 [phi:display_action_text_reading::@9->printf_uchar#4] -- register_copy jsr printf_uchar - // [2785] phi from vera_verify::@18 to vera_verify::@19 [phi:vera_verify::@18->vera_verify::@19] - // vera_verify::@19 - // sprintf(info_text, "Comparing: %05x differences between RAM:%02x:%04p <-> ROM:%05x", vera_different_bytes, vera_bram_bank, vera_bram_ptr, vera_address) - // [2786] call printf_str - // [1210] phi from vera_verify::@19 to printf_str [phi:vera_verify::@19->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:vera_verify::@19->printf_str#0] -- pprz1=pprc1 + // [2054] phi from display_action_text_reading::@9 to display_action_text_reading::@10 [phi:display_action_text_reading::@9->display_action_text_reading::@10] + // display_action_text_reading::@10 + // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) + // [2055] call printf_str + // [785] phi from display_action_text_reading::@10 to printf_str [phi:display_action_text_reading::@10->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:display_action_text_reading::@10->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s2 [phi:vera_verify::@19->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #<@s2 sta.z printf_str.s - lda #>s2 + lda #>@s2 sta.z printf_str.s+1 jsr printf_str - // vera_verify::@20 - // sprintf(info_text, "Comparing: %05x differences between RAM:%02x:%04p <-> ROM:%05x", vera_different_bytes, vera_bram_bank, vera_bram_ptr, vera_address) - // [2787] printf_uint::uvalue#0 = (unsigned int)vera_verify::vera_bram_ptr#11 -- vwum1=vwuz2 - lda.z vera_bram_ptr + // display_action_text_reading::@11 + // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) + // [2056] printf_uint::uvalue#3 = (unsigned int)display_action_text_reading::bram_ptr#0 -- vwum1=vwuz2 + lda.z bram_ptr sta printf_uint.uvalue - lda.z vera_bram_ptr+1 + lda.z bram_ptr+1 sta printf_uint.uvalue+1 - // [2788] call printf_uint - // [2086] phi from vera_verify::@20 to printf_uint [phi:vera_verify::@20->printf_uint] - // [2086] phi printf_uint::format_zero_padding#10 = 1 [phi:vera_verify::@20->printf_uint#0] -- vbum1=vbuc1 + // [2057] call printf_uint + // [1433] phi from display_action_text_reading::@11 to printf_uint [phi:display_action_text_reading::@11->printf_uint] + // [1433] phi printf_uint::format_zero_padding#4 = 1 [phi:display_action_text_reading::@11->printf_uint#0] -- vbum1=vbuc1 lda #1 sta printf_uint.format_zero_padding - // [2086] phi printf_uint::format_min_length#10 = 4 [phi:vera_verify::@20->printf_uint#1] -- vbum1=vbuc1 + // [1433] phi printf_uint::format_min_length#4 = 4 [phi:display_action_text_reading::@11->printf_uint#1] -- vbum1=vbuc1 lda #4 sta printf_uint.format_min_length - // [2086] phi printf_uint::putc#10 = &snputc [phi:vera_verify::@20->printf_uint#2] -- pprz1=pprc1 + // [1433] phi printf_uint::putc#4 = &snputc [phi:display_action_text_reading::@11->printf_uint#2] -- pprz1=pprc1 lda #snputc sta.z printf_uint.putc+1 - // [2086] phi printf_uint::format_radix#10 = HEXADECIMAL [phi:vera_verify::@20->printf_uint#3] -- vbum1=vbuc1 + // [1433] phi printf_uint::format_radix#4 = HEXADECIMAL [phi:display_action_text_reading::@11->printf_uint#3] -- vbum1=vbuc1 lda #HEXADECIMAL sta printf_uint.format_radix - // [2086] phi printf_uint::uvalue#10 = printf_uint::uvalue#0 [phi:vera_verify::@20->printf_uint#4] -- register_copy + // [1433] phi printf_uint::uvalue#4 = printf_uint::uvalue#3 [phi:display_action_text_reading::@11->printf_uint#4] -- register_copy jsr printf_uint - // [2789] phi from vera_verify::@20 to vera_verify::@21 [phi:vera_verify::@20->vera_verify::@21] - // vera_verify::@21 - // sprintf(info_text, "Comparing: %05x differences between RAM:%02x:%04p <-> ROM:%05x", vera_different_bytes, vera_bram_bank, vera_bram_ptr, vera_address) - // [2790] call printf_str - // [1210] phi from vera_verify::@21 to printf_str [phi:vera_verify::@21->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:vera_verify::@21->printf_str#0] -- pprz1=pprc1 + // [2058] phi from display_action_text_reading::@11 to display_action_text_reading::@12 [phi:display_action_text_reading::@11->display_action_text_reading::@12] + // display_action_text_reading::@12 + // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) + // [2059] call printf_str + // [785] phi from display_action_text_reading::@12 to printf_str [phi:display_action_text_reading::@12->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:display_action_text_reading::@12->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s3 [phi:vera_verify::@21->printf_str#1] -- pbuz1=pbuc1 - lda #printf_str#1] -- pbuz1=pbuc1 + lda #s3 + lda #>s5 sta.z printf_str.s+1 jsr printf_str - // vera_verify::@22 - // sprintf(info_text, "Comparing: %05x differences between RAM:%02x:%04p <-> ROM:%05x", vera_different_bytes, vera_bram_bank, vera_bram_ptr, vera_address) - // [2791] printf_ulong::uvalue#1 = vera_verify::vera_address#1 -- vdum1=vdum2 - lda vera_address - sta printf_ulong.uvalue - lda vera_address+1 - sta printf_ulong.uvalue+1 - lda vera_address+2 - sta printf_ulong.uvalue+2 - lda vera_address+3 - sta printf_ulong.uvalue+3 - // [2792] call printf_ulong - // [1741] phi from vera_verify::@22 to printf_ulong [phi:vera_verify::@22->printf_ulong] - // [1741] phi printf_ulong::format_zero_padding#15 = 1 [phi:vera_verify::@22->printf_ulong#0] -- vbum1=vbuc1 - lda #1 - sta printf_ulong.format_zero_padding - // [1741] phi printf_ulong::format_min_length#15 = 5 [phi:vera_verify::@22->printf_ulong#1] -- vbum1=vbuc1 - lda #5 - sta printf_ulong.format_min_length - // [1741] phi printf_ulong::format_radix#15 = HEXADECIMAL [phi:vera_verify::@22->printf_ulong#2] -- vbum1=vbuc1 - lda #HEXADECIMAL - sta printf_ulong.format_radix - // [1741] phi printf_ulong::uvalue#15 = printf_ulong::uvalue#1 [phi:vera_verify::@22->printf_ulong#3] -- register_copy - jsr printf_ulong - // vera_verify::@23 - // sprintf(info_text, "Comparing: %05x differences between RAM:%02x:%04p <-> ROM:%05x", vera_different_bytes, vera_bram_bank, vera_bram_ptr, vera_address) - // [2793] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 + // display_action_text_reading::@13 + // sprintf(info_text, "%s %s:%05x/%05x -> RAM:%02x:%04p ...", action, file, bytes, size, bram_bank, bram_ptr) + // [2060] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 lda #0 pha - // [2794] callexecute snputc -- call_vprc1 + // [2061] callexecute snputc -- call_vprc1 jsr snputc // sideeffect stackpullpadding(1) -- _stackpullpadding_1 pla // display_action_text(info_text) - // [2796] call display_action_text - // [1357] phi from vera_verify::@23 to display_action_text [phi:vera_verify::@23->display_action_text] - // [1357] phi display_action_text::info_text#25 = info_text [phi:vera_verify::@23->display_action_text#0] -- pbuz1=pbuc1 - lda #<@info_text + // [2063] call display_action_text + // [845] phi from display_action_text_reading::@13 to display_action_text [phi:display_action_text_reading::@13->display_action_text] + // [845] phi display_action_text::info_text#17 = info_text [phi:display_action_text_reading::@13->display_action_text#0] -- pbuz1=pbuc1 + lda #@info_text + lda #>info_text sta.z display_action_text.info_text+1 jsr display_action_text - // [2748] phi from vera_verify::@23 to vera_verify::@1 [phi:vera_verify::@23->vera_verify::@1] - // [2748] phi vera_verify::y#3 = vera_verify::y#10 [phi:vera_verify::@23->vera_verify::@1#0] -- register_copy - // [2748] phi vera_verify::progress_row_current#3 = vera_verify::progress_row_current#11 [phi:vera_verify::@23->vera_verify::@1#1] -- register_copy - // [2748] phi vera_verify::vera_different_bytes#11 = vera_verify::vera_different_bytes#1 [phi:vera_verify::@23->vera_verify::@1#2] -- register_copy - // [2748] phi vera_verify::vera_bram_ptr#10 = vera_verify::vera_bram_ptr#11 [phi:vera_verify::@23->vera_verify::@1#3] -- register_copy - // [2748] phi vera_verify::vera_bram_bank#11 = vera_verify::vera_bram_bank#10 [phi:vera_verify::@23->vera_verify::@1#4] -- register_copy - // [2748] phi vera_verify::vera_address#11 = vera_verify::vera_address#1 [phi:vera_verify::@23->vera_verify::@1#5] -- register_copy - jmp __b1 - // vera_verify::@4 - __b4: - // cputc('*') - // [2797] stackpush(char) = '*' -- _stackpushbyte_=vbuc1 - lda #'*' - pha - // [2798] callexecute cputc -- call_vprc1 - jsr cputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - jmp __b5 - .segment DataVera - info_text: .text "Comparing VERA ..." + // display_action_text_reading::@return + // } + // [2064] return + rts + .segment Data + s2: .text "/" .byte 0 - vera_boundary: .dword 0 - .label equal_bytes = vera_compare.equal_bytes - y: .byte 0 - vera_address: .dword 0 - vera_bram_bank: .byte 0 - vera_different_bytes: .dword 0 - .label return = vera_different_bytes - progress_row_current: .word 0 + s3: .text " -> RAM:" + .byte 0 + s5: .text " ..." + .byte 0 + .label bytes = printf_ulong.uvalue + .label bram_bank = printf_uchar.uvalue } -.segment CodeVera - // vera_erase -vera_erase: { - .label vera_erase__0 = $cc - // BYTE2(vera_file_size) - // [2800] vera_erase::$0 = byte2 vera_file_size#1 -- vbuz1=_byte2_vdum2 - lda vera_file_size+2 - sta.z vera_erase__0 - // unsigned char vera_total_64k_blocks = BYTE2(vera_file_size)+1 - // [2801] vera_erase::vera_total_64k_blocks#0 = vera_erase::$0 + 1 -- vbum1=vbuz2_plus_1 - inc - sta vera_total_64k_blocks - // [2802] phi from vera_erase to vera_erase::@1 [phi:vera_erase->vera_erase::@1] - // [2802] phi vera_erase::vera_current_64k_block#2 = 0 [phi:vera_erase->vera_erase::@1#0] -- vbum1=vbuc1 +.segment Code + // fgets +/** + * @brief Load a file to ram or (banked ram located between address 0xA000 and 0xBFFF), incrementing the banks. + * This function uses the new CX16 macptr kernal API at address $FF44. + * + * @param sptr The pointer between 0xA000 and 0xBFFF in banked ram. + * @param size The amount of bytes to be read. + * @param filename Name of the file to be loaded. + * @return ptr the pointer advanced to the point where the stream ends. + */ +// __mem() unsigned int fgets(__zp($49) char *ptr, unsigned int size, __zp($4b) struct $2 *stream) +fgets: { + .label fgets__1 = $38 + .label fgets__8 = $39 + .label fgets__9 = $3a + .label fgets__13 = $4d + .label ptr = $49 + .label stream = $4b + // unsigned char sp = (unsigned char)stream + // [2065] fgets::sp#0 = (char)fgets::stream#0 -- vbum1=_byte_pssz2 + lda.z stream + sta sp + // cbm_k_chkin(__logical) + // [2066] fgets::cbm_k_chkin1_channel = ((char *)&__stdio_file+$40)[fgets::sp#0] -- vbum1=pbuc1_derefidx_vbum2 + tay + lda __stdio_file+$40,y + sta cbm_k_chkin1_channel + // fgets::cbm_k_chkin1 + // char status + // [2067] fgets::cbm_k_chkin1_status = 0 -- vbum1=vbuc1 lda #0 - sta vera_current_64k_block - // vera_erase::@1 - __b1: - // while(vera_current_64k_block < vera_total_64k_blocks) - // [2803] if(vera_erase::vera_current_64k_block#2vera_erase::@1] - // [2802] phi vera_erase::vera_current_64k_block#2 = vera_erase::vera_current_64k_block#1 [phi:vera_erase::@2->vera_erase::@1#0] -- register_copy - jmp __b1 - .segment DataVera - vera_total_64k_blocks: .byte 0 - vera_current_64k_block: .byte 0 -} -.segment CodeVera - // vera_flash -vera_flash: { - .label vera_flash__18 = $ac - .label vera_bram_ptr = $7d - // display_action_progress("Flashing ... (-) equal, (+) flashed, (!) error.") - // [2807] call display_action_progress - // Now we compare the RAM with the actual ROM contents. - // [904] phi from vera_flash to display_action_progress [phi:vera_flash->display_action_progress] - // [904] phi display_action_progress::info_text#27 = string_0 [phi:vera_flash->display_action_progress#0] -- pbuz1=pbuc1 - lda #string_0 - sta.z display_action_progress.info_text+1 - jsr display_action_progress - // vera_flash::@14 - // [2808] spi_manufacturer#596 = spi_read::return#0 -- vbum1=vbum2 - lda spi_read.return - sta spi_manufacturer - // [2809] spi_memory_type#597 = spi_read::return#1 -- vbum1=vbum2 - lda spi_read.return_1 - sta spi_memory_type - // [2810] spi_memory_capacity#598 = spi_read::return#2 -- vbum1=vbum2 - lda spi_read.return_2 - sta spi_memory_capacity - // display_info_vera(STATUS_FLASHING, "Flashing ...") - // [2811] call display_info_vera - // [998] phi from vera_flash::@14 to display_info_vera [phi:vera_flash::@14->display_info_vera] - // [998] phi display_info_vera::info_text#19 = info_text1 [phi:vera_flash::@14->display_info_vera#0] -- pbuz1=pbuc1 - lda #info_text1 - sta.z display_info_vera.info_text+1 - // [998] phi spi_memory_capacity#106 = spi_memory_capacity#598 [phi:vera_flash::@14->display_info_vera#1] -- register_copy - // [998] phi spi_memory_type#107 = spi_memory_type#597 [phi:vera_flash::@14->display_info_vera#2] -- register_copy - // [998] phi spi_manufacturer#108 = spi_manufacturer#596 [phi:vera_flash::@14->display_info_vera#3] -- register_copy - // [998] phi display_info_vera::info_status#19 = STATUS_FLASHING [phi:vera_flash::@14->display_info_vera#4] -- vbum1=vbuc1 - lda #STATUS_FLASHING - sta display_info_vera.info_status - jsr display_info_vera - // [2812] phi from vera_flash::@14 to vera_flash::@1 [phi:vera_flash::@14->vera_flash::@1] - // [2812] phi vera_flash::vera_bram_ptr#10 = (char *)$a000 [phi:vera_flash::@14->vera_flash::@1#0] -- pbuz1=pbuc1 - lda #<$a000 - sta.z vera_bram_ptr - lda #>$a000 - sta.z vera_bram_ptr+1 - // [2812] phi vera_flash::vera_bram_bank#11 = 1 [phi:vera_flash::@14->vera_flash::@1#1] -- vbum1=vbuc1 - lda #1 - sta vera_bram_bank - // [2812] phi vera_flash::y_sector#14 = PROGRESS_Y [phi:vera_flash::@14->vera_flash::@1#2] -- vbum1=vbuc1 - lda #PROGRESS_Y - sta y_sector - // [2812] phi vera_flash::x_sector#14 = PROGRESS_X [phi:vera_flash::@14->vera_flash::@1#3] -- vbum1=vbuc1 - lda #PROGRESS_X - sta x_sector - // [2812] phi vera_flash::return#2 = 0 [phi:vera_flash::@14->vera_flash::@1#4] -- vdum1=vduc1 + // [2072] fgets::cbm_k_readst1_return#1 = fgets::cbm_k_readst1_return#0 + // fgets::@9 + // cbm_k_readst() + // [2073] fgets::$1 = fgets::cbm_k_readst1_return#1 -- vbuz1=vbum2 + sta.z fgets__1 + // __status = cbm_k_readst() + // [2074] ((char *)&__stdio_file+$46)[fgets::sp#0] = fgets::$1 -- pbuc1_derefidx_vbum1=vbuz2 + ldy sp + sta __stdio_file+$46,y + // if (__status) + // [2075] if(0==((char *)&__stdio_file+$46)[fgets::sp#0]) goto fgets::@1 -- 0_eq_pbuc1_derefidx_vbum1_then_la1 + lda __stdio_file+$46,y + cmp #0 + beq __b8 + // [2076] phi from fgets::@10 fgets::@3 fgets::@9 to fgets::@return [phi:fgets::@10/fgets::@3/fgets::@9->fgets::@return] + __b1: + // [2076] phi fgets::return#1 = 0 [phi:fgets::@10/fgets::@3/fgets::@9->fgets::@return#0] -- vwum1=vbuc1 lda #<0 sta return sta return+1 - lda #<0>>$10 - sta return+2 - lda #>0>>$10 - sta return+3 - // [2812] phi from vera_flash::@11 to vera_flash::@1 [phi:vera_flash::@11->vera_flash::@1] - // [2812] phi vera_flash::vera_bram_ptr#10 = vera_flash::vera_bram_ptr#18 [phi:vera_flash::@11->vera_flash::@1#0] -- register_copy - // [2812] phi vera_flash::vera_bram_bank#11 = vera_flash::vera_bram_bank#14 [phi:vera_flash::@11->vera_flash::@1#1] -- register_copy - // [2812] phi vera_flash::y_sector#14 = vera_flash::y_sector#14 [phi:vera_flash::@11->vera_flash::@1#2] -- register_copy - // [2812] phi vera_flash::x_sector#14 = vera_flash::x_sector#1 [phi:vera_flash::@11->vera_flash::@1#3] -- register_copy - // [2812] phi vera_flash::return#2 = vera_flash::vera_address_page#12 [phi:vera_flash::@11->vera_flash::@1#4] -- register_copy - // vera_flash::@1 - __b1: - // while (vera_address_page < vera_file_size) - // [2813] if(vera_flash::return#2display_action_text_flashed] - // [2926] phi display_action_text_flashed::chip#3 = vera_flash::chip [phi:vera_flash::@3->display_action_text_flashed#0] -- pbuz1=pbuc1 - lda #chip - sta.z display_action_text_flashed.chip+1 - // [2926] phi display_action_text_flashed::bytes#3 = display_action_text_flashed::bytes#0 [phi:vera_flash::@3->display_action_text_flashed#1] -- register_copy - jsr display_action_text_flashed - // [2816] phi from vera_flash::@3 to vera_flash::@16 [phi:vera_flash::@3->vera_flash::@16] - // vera_flash::@16 - // wait_moment(32) - // [2817] call wait_moment - // [1310] phi from vera_flash::@16 to wait_moment [phi:vera_flash::@16->wait_moment] - // [1310] phi wait_moment::w#13 = $20 [phi:vera_flash::@16->wait_moment#0] -- vbum1=vbuc1 - lda #$20 - sta wait_moment.w - jsr wait_moment - // vera_flash::@return + // fgets::@return // } - // [2818] return + // [2077] return rts - // vera_flash::@2 - __b2: - // unsigned long vera_page_boundary = vera_address_page + VERA_PROGRESS_PAGE - // [2819] vera_flash::vera_page_boundary#0 = vera_flash::return#2 + VERA_PROGRESS_PAGE -- vdum1=vdum2_plus_vwuc1 - // {asm{.byte $db}} - clc - lda return - adc #VERA_PROGRESS_PAGE - sta vera_page_boundary+1 - lda return+2 - adc #0 - sta vera_page_boundary+2 - lda return+3 - adc #0 - sta vera_page_boundary+3 - // cputcxy(x,y,'.') - // [2820] cputcxy::x#0 = vera_flash::x_sector#14 -- vbum1=vbum2 - lda x_sector - sta cputcxy.x - // [2821] cputcxy::y#0 = vera_flash::y_sector#14 -- vbum1=vbum2 - lda y_sector - sta cputcxy.y - // [2822] call cputcxy - // [2293] phi from vera_flash::@2 to cputcxy [phi:vera_flash::@2->cputcxy] - // [2293] phi cputcxy::c#17 = '.' [phi:vera_flash::@2->cputcxy#0] -- vbum1=vbuc1 - lda #'.' - sta cputcxy.c - // [2293] phi cputcxy::y#17 = cputcxy::y#0 [phi:vera_flash::@2->cputcxy#1] -- register_copy - // [2293] phi cputcxy::x#17 = cputcxy::x#0 [phi:vera_flash::@2->cputcxy#2] -- register_copy - jsr cputcxy - // vera_flash::@15 - // cputc('.') - // [2823] stackpush(char) = '.' -- _stackpushbyte_=vbuc1 - lda #'.' - pha - // [2824] callexecute cputc -- call_vprc1 - jsr cputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // vera_flash::bank_set_bram1 - // BRAM = bank - // [2826] BRAM = vera_flash::vera_bram_bank#11 -- vbuz1=vbum2 - lda vera_bram_bank - sta.z BRAM - // [2827] vera_flash::vera_address#13 = vera_flash::return#2 -- vdum1=vdum2 - lda return - sta vera_address - lda return+1 - sta vera_address+1 - lda return+2 - sta vera_address+2 - lda return+3 - sta vera_address+3 - // [2828] phi from vera_flash::@17 vera_flash::bank_set_bram1 to vera_flash::@5 [phi:vera_flash::@17/vera_flash::bank_set_bram1->vera_flash::@5] - // [2828] phi vera_flash::vera_address_page#12 = vera_flash::vera_address_page#1 [phi:vera_flash::@17/vera_flash::bank_set_bram1->vera_flash::@5#0] -- register_copy - // [2828] phi vera_flash::vera_bram_ptr#13 = vera_flash::vera_bram_ptr#1 [phi:vera_flash::@17/vera_flash::bank_set_bram1->vera_flash::@5#1] -- register_copy - // [2828] phi vera_flash::vera_address#10 = vera_flash::vera_address#1 [phi:vera_flash::@17/vera_flash::bank_set_bram1->vera_flash::@5#2] -- register_copy - // vera_flash::@5 - __b5: - // while (vera_address < vera_page_boundary) - // [2829] if(vera_flash::vera_address#10$c000 - bne __b10 - lda.z vera_bram_ptr - cmp #<$c000 - bne __b10 - // vera_flash::@12 - // vera_bram_bank++; - // [2831] vera_flash::vera_bram_bank#1 = ++ vera_flash::vera_bram_bank#11 -- vbum1=_inc_vbum1 - inc vera_bram_bank - // [2832] phi from vera_flash::@12 to vera_flash::@10 [phi:vera_flash::@12->vera_flash::@10] - // [2832] phi vera_flash::vera_bram_bank#21 = vera_flash::vera_bram_bank#1 [phi:vera_flash::@12->vera_flash::@10#0] -- register_copy - // [2832] phi vera_flash::vera_bram_ptr#7 = (char *)$a000 [phi:vera_flash::@12->vera_flash::@10#1] -- pbuz1=pbuc1 - lda #<$a000 - sta.z vera_bram_ptr - lda #>$a000 - sta.z vera_bram_ptr+1 - // [2832] phi from vera_flash::@4 to vera_flash::@10 [phi:vera_flash::@4->vera_flash::@10] - // [2832] phi vera_flash::vera_bram_bank#21 = vera_flash::vera_bram_bank#11 [phi:vera_flash::@4->vera_flash::@10#0] -- register_copy - // [2832] phi vera_flash::vera_bram_ptr#7 = vera_flash::vera_bram_ptr#13 [phi:vera_flash::@4->vera_flash::@10#1] -- register_copy - // vera_flash::@10 - __b10: - // if (vera_bram_ptr == RAM_HIGH) - // [2833] if(vera_flash::vera_bram_ptr#7!=$9800) goto vera_flash::@18 -- pbuz1_neq_vwuc1_then_la1 - lda.z vera_bram_ptr+1 - cmp #>$9800 - bne __b11 - lda.z vera_bram_ptr - cmp #<$9800 - bne __b11 - // [2835] phi from vera_flash::@10 to vera_flash::@11 [phi:vera_flash::@10->vera_flash::@11] - // [2835] phi vera_flash::vera_bram_ptr#18 = (char *)$a000 [phi:vera_flash::@10->vera_flash::@11#0] -- pbuz1=pbuc1 - lda #<$a000 - sta.z vera_bram_ptr - lda #>$a000 - sta.z vera_bram_ptr+1 - // [2835] phi vera_flash::vera_bram_bank#14 = 1 [phi:vera_flash::@10->vera_flash::@11#1] -- vbum1=vbuc1 - lda #1 - sta vera_bram_bank - // [2834] phi from vera_flash::@10 to vera_flash::@18 [phi:vera_flash::@10->vera_flash::@18] - // vera_flash::@18 - // [2835] phi from vera_flash::@18 to vera_flash::@11 [phi:vera_flash::@18->vera_flash::@11] - // [2835] phi vera_flash::vera_bram_ptr#18 = vera_flash::vera_bram_ptr#7 [phi:vera_flash::@18->vera_flash::@11#0] -- register_copy - // [2835] phi vera_flash::vera_bram_bank#14 = vera_flash::vera_bram_bank#21 [phi:vera_flash::@18->vera_flash::@11#1] -- register_copy - // vera_flash::@11 - __b11: - // x_sector += 2 - // [2836] vera_flash::x_sector#1 = vera_flash::x_sector#14 + 2 -- vbum1=vbum1_plus_2 - lda x_sector - clc - adc #2 - sta x_sector - // vera_address_page % VERA_PROGRESS_ROW - // [2837] vera_flash::$18 = vera_flash::vera_address_page#12 & VERA_PROGRESS_ROW-1 -- vduz1=vdum2_band_vduc1 - lda vera_address_page - and #VERA_PROGRESS_ROW-1 - sta.z vera_flash__18+1 - lda vera_address_page+2 - and #>$10 - sta.z vera_flash__18+2 - lda vera_address_page+3 - and #>VERA_PROGRESS_ROW-1>>$10 - sta.z vera_flash__18+3 - // if (!(vera_address_page % VERA_PROGRESS_ROW)) - // [2838] if(0!=vera_flash::$18) goto vera_flash::@1 -- 0_neq_vduz1_then_la1 - lda.z vera_flash__18 - ora.z vera_flash__18+1 - ora.z vera_flash__18+2 - ora.z vera_flash__18+3 - beq !__b1+ - jmp __b1 - !__b1: - // vera_flash::@13 - // y_sector++; - // [2839] vera_flash::y_sector#1 = ++ vera_flash::y_sector#14 -- vbum1=_inc_vbum1 - inc y_sector - // [2812] phi from vera_flash::@13 to vera_flash::@1 [phi:vera_flash::@13->vera_flash::@1] - // [2812] phi vera_flash::vera_bram_ptr#10 = vera_flash::vera_bram_ptr#18 [phi:vera_flash::@13->vera_flash::@1#0] -- register_copy - // [2812] phi vera_flash::vera_bram_bank#11 = vera_flash::vera_bram_bank#14 [phi:vera_flash::@13->vera_flash::@1#1] -- register_copy - // [2812] phi vera_flash::y_sector#14 = vera_flash::y_sector#1 [phi:vera_flash::@13->vera_flash::@1#2] -- register_copy - // [2812] phi vera_flash::x_sector#14 = PROGRESS_X [phi:vera_flash::@13->vera_flash::@1#3] -- vbum1=vbuc1 - lda #PROGRESS_X - sta x_sector - // [2812] phi vera_flash::return#2 = vera_flash::vera_address_page#12 [phi:vera_flash::@13->vera_flash::@1#4] -- register_copy - jmp __b1 - // vera_flash::@6 - __b6: - // display_action_text_flashing(VERA_PROGRESS_PAGE, "VERA", vera_bram_bank, vera_bram_ptr, vera_address) - // [2840] display_action_text_flashing::bram_bank#0 = vera_flash::vera_bram_bank#11 -- vbum1=vbum2 - lda vera_bram_bank - sta display_action_text_flashing.bram_bank - // [2841] display_action_text_flashing::bram_ptr#0 = vera_flash::vera_bram_ptr#13 -- pbuz1=pbuz2 - lda.z vera_bram_ptr - sta.z display_action_text_flashing.bram_ptr - lda.z vera_bram_ptr+1 - sta.z display_action_text_flashing.bram_ptr+1 - // [2842] display_action_text_flashing::address#0 = vera_flash::vera_address#10 -- vdum1=vdum2 - lda vera_address - sta display_action_text_flashing.address - lda vera_address+1 - sta display_action_text_flashing.address+1 - lda vera_address+2 - sta display_action_text_flashing.address+2 - lda vera_address+3 - sta display_action_text_flashing.address+3 - // [2843] call display_action_text_flashing - // [2955] phi from vera_flash::@6 to display_action_text_flashing [phi:vera_flash::@6->display_action_text_flashing] - // [2955] phi display_action_text_flashing::address#10 = display_action_text_flashing::address#0 [phi:vera_flash::@6->display_action_text_flashing#0] -- register_copy - // [2955] phi display_action_text_flashing::chip#10 = vera_flash::chip [phi:vera_flash::@6->display_action_text_flashing#1] -- pbuz1=pbuc1 - lda #chip - sta.z display_action_text_flashing.chip+1 - // [2955] phi display_action_text_flashing::bram_ptr#3 = display_action_text_flashing::bram_ptr#0 [phi:vera_flash::@6->display_action_text_flashing#2] -- register_copy - // [2955] phi display_action_text_flashing::bram_bank#3 = display_action_text_flashing::bram_bank#0 [phi:vera_flash::@6->display_action_text_flashing#3] -- register_copy - // [2955] phi display_action_text_flashing::bytes#3 = VERA_PROGRESS_PAGE [phi:vera_flash::@6->display_action_text_flashing#4] -- vdum1=vduc1 - lda #VERA_PROGRESS_PAGE - sta display_action_text_flashing.bytes+1 - lda #>$10 - sta display_action_text_flashing.bytes+2 - lda #>VERA_PROGRESS_PAGE>>$10 - sta display_action_text_flashing.bytes+3 - jsr display_action_text_flashing - // [2844] phi from vera_flash::@6 to vera_flash::@7 [phi:vera_flash::@6->vera_flash::@7] - // [2844] phi vera_flash::i#2 = 0 [phi:vera_flash::@6->vera_flash::@7#0] -- vwum1=vwuc1 + // [2078] phi from fgets::@13 to fgets::@1 [phi:fgets::@13->fgets::@1] + // [2078] phi fgets::read#10 = fgets::read#1 [phi:fgets::@13->fgets::@1#0] -- register_copy + // [2078] phi fgets::remaining#11 = fgets::remaining#1 [phi:fgets::@13->fgets::@1#1] -- register_copy + // [2078] phi fgets::ptr#10 = fgets::ptr#12 [phi:fgets::@13->fgets::@1#2] -- register_copy + // [2078] phi from fgets::@9 to fgets::@1 [phi:fgets::@9->fgets::@1] + __b8: + // [2078] phi fgets::read#10 = 0 [phi:fgets::@9->fgets::@1#0] -- vwum1=vwuc1 lda #<0 - sta i - sta i+1 - // vera_flash::@7 - __b7: - // for(unsigned int i=0; i<=255; i++) - // [2845] if(vera_flash::i#2<=$ff) goto vera_flash::@8 -- vwum1_le_vbuc1_then_la1 - lda #$ff - cmp i + sta read + sta read+1 + // [2078] phi fgets::remaining#11 = VERA_PROGRESS_CELL [phi:fgets::@9->fgets::@1#1] -- vwum1=vbuc1 + lda #VERA_PROGRESS_CELL + sta remaining+1 + // [2078] phi fgets::ptr#10 = fgets::ptr#2 [phi:fgets::@9->fgets::@1#2] -- register_copy + // fgets::@1 + // fgets::@6 + __b6: + // if (remaining >= 512) + // [2079] if(fgets::remaining#11>=$200) goto fgets::@2 -- vwum1_ge_vwuc1_then_la1 + lda remaining+1 + cmp #>$200 bcc !+ - lda i+1 - beq __b8 - !: - // vera_flash::@9 - // cputcxy(x,y,'+') - // [2846] cputcxy::x#1 = vera_flash::x_sector#14 -- vbum1=vbum2 - lda x_sector - sta cputcxy.x - // [2847] cputcxy::y#1 = vera_flash::y_sector#14 -- vbum1=vbum2 - lda y_sector - sta cputcxy.y - // [2848] call cputcxy - // [2293] phi from vera_flash::@9 to cputcxy [phi:vera_flash::@9->cputcxy] - // [2293] phi cputcxy::c#17 = '+' [phi:vera_flash::@9->cputcxy#0] -- vbum1=vbuc1 - lda #'+' - sta cputcxy.c - // [2293] phi cputcxy::y#17 = cputcxy::y#1 [phi:vera_flash::@9->cputcxy#1] -- register_copy - // [2293] phi cputcxy::x#17 = cputcxy::x#1 [phi:vera_flash::@9->cputcxy#2] -- register_copy - jsr cputcxy - // vera_flash::@17 - // cputc('+') - // [2849] stackpush(char) = '+' -- _stackpushbyte_=vbuc1 - lda #'+' - pha - // [2850] callexecute cputc -- call_vprc1 - jsr cputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // vera_bram_ptr += VERA_PROGRESS_PAGE - // [2852] vera_flash::vera_bram_ptr#1 = vera_flash::vera_bram_ptr#13 + VERA_PROGRESS_PAGE -- pbuz1=pbuz1_plus_vwuc1 - lda.z vera_bram_ptr - clc - adc #VERA_PROGRESS_PAGE - sta.z vera_bram_ptr+1 - // vera_address += VERA_PROGRESS_PAGE - // [2853] vera_flash::vera_address#1 = vera_flash::vera_address#10 + VERA_PROGRESS_PAGE -- vdum1=vdum1_plus_vwuc1 - clc - lda vera_address - adc #VERA_PROGRESS_PAGE - sta vera_address+1 - lda vera_address+2 - adc #0 - sta vera_address+2 - lda vera_address+3 - adc #0 - sta vera_address+3 - // vera_address_page += VERA_PROGRESS_PAGE - // [2854] vera_flash::vera_address_page#1 = vera_flash::vera_address_page#12 + VERA_PROGRESS_PAGE -- vdum1=vdum1_plus_vwuc1 - clc - lda vera_address_page - adc #VERA_PROGRESS_PAGE - sta vera_address_page+1 - lda vera_address_page+2 - adc #0 - sta vera_address_page+2 - lda vera_address_page+3 - adc #0 - sta vera_address_page+3 - jmp __b5 - // vera_flash::@8 - __b8: - // for(unsigned int i=0; i<=255; i++) - // [2855] vera_flash::i#1 = ++ vera_flash::i#2 -- vwum1=_inc_vwum1 - inc i - bne !+ - inc i+1 + beq !__b2+ + jmp __b2 + !__b2: + lda remaining + cmp #<$200 + bcc !__b2+ + jmp __b2 + !__b2: !: - // [2844] phi from vera_flash::@8 to vera_flash::@7 [phi:vera_flash::@8->vera_flash::@7] - // [2844] phi vera_flash::i#2 = vera_flash::i#1 [phi:vera_flash::@8->vera_flash::@7#0] -- register_copy - jmp __b7 - .segment DataVera - chip: .text "VERA" - .byte 0 - vera_page_boundary: .dword 0 - // TODO: ERROR!!! - return: .dword 0 - i: .word 0 - vera_address: .dword 0 - .label vera_address_page = return - vera_bram_bank: .byte 0 - x_sector: .byte 0 - y_sector: .byte 0 -} -.segment Code - // display_info_roms -/** - * @brief Display all the ROM statuses. - * - * @param info_status The status. - * @param info_text The status text. - */ -// void display_info_roms(char info_status, char *info_text) -display_info_roms: { - .label info_text = 0 - // [2857] phi from display_info_roms to display_info_roms::@1 [phi:display_info_roms->display_info_roms::@1] - // [2857] phi display_info_roms::rom_chip#2 = 0 [phi:display_info_roms->display_info_roms::@1#0] -- vbum1=vbuc1 + // fgets::@7 + // cx16_k_macptr(remaining, ptr) + // [2080] cx16_k_macptr::bytes = fgets::remaining#11 -- vbum1=vwum2 + lda remaining + sta cx16_k_macptr.bytes + // [2081] cx16_k_macptr::buffer = (void *)fgets::ptr#10 -- pvoz1=pvoz2 + lda.z ptr + sta.z cx16_k_macptr.buffer + lda.z ptr+1 + sta.z cx16_k_macptr.buffer+1 + // [2082] call cx16_k_macptr + jsr cx16_k_macptr + // [2083] cx16_k_macptr::return#4 = cx16_k_macptr::return#1 + // fgets::@12 + __b12: + // bytes = cx16_k_macptr(remaining, ptr) + // [2084] fgets::bytes#3 = cx16_k_macptr::return#4 + // [2085] phi from fgets::@11 fgets::@12 to fgets::cbm_k_readst2 [phi:fgets::@11/fgets::@12->fgets::cbm_k_readst2] + // [2085] phi fgets::bytes#10 = fgets::bytes#2 [phi:fgets::@11/fgets::@12->fgets::cbm_k_readst2#0] -- register_copy + // fgets::cbm_k_readst2 + // char status + // [2086] fgets::cbm_k_readst2_status = 0 -- vbum1=vbuc1 lda #0 - sta rom_chip - // display_info_roms::@1 - __b1: - // for(unsigned char rom_chip=0; rom_chip<8; rom_chip++) - // [2858] if(display_info_roms::rom_chip#2<8) goto display_info_roms::@2 -- vbum1_lt_vbuc1_then_la1 - lda rom_chip - cmp #8 - bcc __b2 - // display_info_roms::@return + sta cbm_k_readst2_status + // asm + // asm { jsrCBM_READST stastatus } + jsr CBM_READST + sta cbm_k_readst2_status + // return status; + // [2088] fgets::cbm_k_readst2_return#0 = fgets::cbm_k_readst2_status -- vbum1=vbum2 + sta cbm_k_readst2_return + // fgets::cbm_k_readst2_@return // } - // [2859] return - rts - // display_info_roms::@2 - __b2: - // display_info_rom(rom_chip, info_status, info_text) - // [2860] display_info_rom::rom_chip#4 = display_info_roms::rom_chip#2 -- vbum1=vbum2 - lda rom_chip - sta display_info_rom.rom_chip - // [2861] call display_info_rom - // [1546] phi from display_info_roms::@2 to display_info_rom [phi:display_info_roms::@2->display_info_rom] - // [1546] phi display_info_rom::info_text#17 = display_info_roms::info_text#1 [phi:display_info_roms::@2->display_info_rom#0] -- pbuz1=pbuc1 - lda #info_text - sta.z display_info_rom.info_text+1 - // [1546] phi display_info_rom::rom_chip#17 = display_info_rom::rom_chip#4 [phi:display_info_roms::@2->display_info_rom#1] -- register_copy - // [1546] phi display_info_rom::info_status#17 = STATUS_ERROR [phi:display_info_roms::@2->display_info_rom#2] -- vbum1=vbuc1 - lda #STATUS_ERROR - sta display_info_rom.info_status - jsr display_info_rom - // display_info_roms::@3 - // for(unsigned char rom_chip=0; rom_chip<8; rom_chip++) - // [2862] display_info_roms::rom_chip#1 = ++ display_info_roms::rom_chip#2 -- vbum1=_inc_vbum1 - inc rom_chip - // [2857] phi from display_info_roms::@3 to display_info_roms::@1 [phi:display_info_roms::@3->display_info_roms::@1] - // [2857] phi display_info_roms::rom_chip#2 = display_info_roms::rom_chip#1 [phi:display_info_roms::@3->display_info_roms::@1#0] -- register_copy + // [2089] fgets::cbm_k_readst2_return#1 = fgets::cbm_k_readst2_return#0 + // fgets::@10 + // cbm_k_readst() + // [2090] fgets::$8 = fgets::cbm_k_readst2_return#1 -- vbuz1=vbum2 + sta.z fgets__8 + // __status = cbm_k_readst() + // [2091] ((char *)&__stdio_file+$46)[fgets::sp#0] = fgets::$8 -- pbuc1_derefidx_vbum1=vbuz2 + ldy sp + sta __stdio_file+$46,y + // __status & 0xBF + // [2092] fgets::$9 = ((char *)&__stdio_file+$46)[fgets::sp#0] & $bf -- vbuz1=pbuc1_derefidx_vbum2_band_vbuc2 + lda #$bf + and __stdio_file+$46,y + sta.z fgets__9 + // if (__status & 0xBF) + // [2093] if(0==fgets::$9) goto fgets::@3 -- 0_eq_vbuz1_then_la1 + beq __b3 + jmp __b1 + // fgets::@3 + __b3: + // if (bytes == 0xFFFF) + // [2094] if(fgets::bytes#10!=$ffff) goto fgets::@4 -- vwum1_neq_vwuc1_then_la1 + lda bytes+1 + cmp #>$ffff + bne __b4 + lda bytes + cmp #<$ffff + bne __b4 jmp __b1 + // fgets::@4 + __b4: + // read += bytes + // [2095] fgets::read#1 = fgets::read#10 + fgets::bytes#10 -- vwum1=vwum1_plus_vwum2 + clc + lda read + adc bytes + sta read + lda read+1 + adc bytes+1 + sta read+1 + // ptr += bytes + // [2096] fgets::ptr#0 = fgets::ptr#10 + fgets::bytes#10 -- pbuz1=pbuz1_plus_vwum2 + clc + lda.z ptr + adc bytes + sta.z ptr + lda.z ptr+1 + adc bytes+1 + sta.z ptr+1 + // BYTE1(ptr) + // [2097] fgets::$13 = byte1 fgets::ptr#0 -- vbuz1=_byte1_pbuz2 + sta.z fgets__13 + // if (BYTE1(ptr) == 0xC0) + // [2098] if(fgets::$13!=$c0) goto fgets::@5 -- vbuz1_neq_vbuc1_then_la1 + lda #$c0 + cmp.z fgets__13 + bne __b5 + // fgets::@8 + // ptr -= 0x2000 + // [2099] fgets::ptr#1 = fgets::ptr#0 - $2000 -- pbuz1=pbuz1_minus_vwuc1 + lda.z ptr + sec + sbc #<$2000 + sta.z ptr + lda.z ptr+1 + sbc #>$2000 + sta.z ptr+1 + // [2100] phi from fgets::@4 fgets::@8 to fgets::@5 [phi:fgets::@4/fgets::@8->fgets::@5] + // [2100] phi fgets::ptr#12 = fgets::ptr#0 [phi:fgets::@4/fgets::@8->fgets::@5#0] -- register_copy + // fgets::@5 + __b5: + // remaining -= bytes + // [2101] fgets::remaining#1 = fgets::remaining#11 - fgets::bytes#10 -- vwum1=vwum1_minus_vwum2 + lda remaining + sec + sbc bytes + sta remaining + lda remaining+1 + sbc bytes+1 + sta remaining+1 + // while ((__status == 0) && ((size && remaining) || !size)) + // [2102] if(((char *)&__stdio_file+$46)[fgets::sp#0]==0) goto fgets::@13 -- pbuc1_derefidx_vbum1_eq_0_then_la1 + ldy sp + lda __stdio_file+$46,y + cmp #0 + beq __b13 + // [2076] phi from fgets::@13 fgets::@5 to fgets::@return [phi:fgets::@13/fgets::@5->fgets::@return] + // [2076] phi fgets::return#1 = fgets::read#1 [phi:fgets::@13/fgets::@5->fgets::@return#0] -- register_copy + rts + // fgets::@13 + __b13: + // while ((__status == 0) && ((size && remaining) || !size)) + // [2103] if(0!=fgets::remaining#1) goto fgets::@1 -- 0_neq_vwum1_then_la1 + lda remaining + ora remaining+1 + beq !__b6+ + jmp __b6 + !__b6: + rts + // fgets::@2 + __b2: + // cx16_k_macptr(512, ptr) + // [2104] cx16_k_macptr::bytes = $200 -- vbum1=vwuc1 + lda #<$200 + sta cx16_k_macptr.bytes + // [2105] cx16_k_macptr::buffer = (void *)fgets::ptr#10 -- pvoz1=pvoz2 + lda.z ptr + sta.z cx16_k_macptr.buffer + lda.z ptr+1 + sta.z cx16_k_macptr.buffer+1 + // [2106] call cx16_k_macptr + jsr cx16_k_macptr + // [2107] cx16_k_macptr::return#3 = cx16_k_macptr::return#1 + // fgets::@11 + // bytes = cx16_k_macptr(512, ptr) + // [2108] fgets::bytes#2 = cx16_k_macptr::return#3 + jmp __b12 .segment Data - rom_chip: .byte 0 + cbm_k_chkin1_channel: .byte 0 + cbm_k_chkin1_status: .byte 0 + cbm_k_readst1_status: .byte 0 + cbm_k_readst2_status: .byte 0 + sp: .byte 0 + cbm_k_readst1_return: .byte 0 + .label return = read + bytes: .word 0 + cbm_k_readst2_return: .byte 0 + read: .word 0 + remaining: .word 0 } -.segment CodeVera - // spi_deselect -spi_deselect: { - // *vera_reg_SPICtrl &= 0xfe - // [2863] *vera_reg_SPICtrl = *vera_reg_SPICtrl & $fe -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 - /* -.proc spi_deselect - lda Vera::Reg::SPICtrl - and #$fe - sta Vera::Reg::SPICtrl - jsr spi_read - rts -.endproc -*/ - lda #$fe - and vera_reg_SPICtrl - sta vera_reg_SPICtrl - // unsigned char value = spi_read() - // [2864] call spi_read - jsr spi_read - // spi_deselect::@return +.segment Code + // uctoa_append +// Used to convert a single digit of an unsigned number value to a string representation +// Counts a single digit up from '0' as long as the value is larger than sub. +// Each time the digit is increased sub is subtracted from value. +// - buffer : pointer to the char that receives the digit +// - value : The value where the digit will be derived from +// - sub : the value of a '1' in the digit. Subtracted continually while the digit is increased. +// (For decimal the subs used are 10000, 1000, 100, 10, 1) +// returns : the value reduced by sub * digit so that it is less than sub. +// __mem() char uctoa_append(__zp($45) char *buffer, __mem() char value, __mem() char sub) +uctoa_append: { + .label buffer = $45 + // [2110] phi from uctoa_append to uctoa_append::@1 [phi:uctoa_append->uctoa_append::@1] + // [2110] phi uctoa_append::digit#2 = 0 [phi:uctoa_append->uctoa_append::@1#0] -- vbum1=vbuc1 + lda #0 + sta digit + // [2110] phi uctoa_append::value#2 = uctoa_append::value#0 [phi:uctoa_append->uctoa_append::@1#1] -- register_copy + // uctoa_append::@1 + __b1: + // while (value >= sub) + // [2111] if(uctoa_append::value#2>=uctoa_append::sub#0) goto uctoa_append::@2 -- vbum1_ge_vbum2_then_la1 + lda value + cmp sub + bcs __b2 + // uctoa_append::@3 + // *buffer = DIGITS[digit] + // [2112] *uctoa_append::buffer#0 = DIGITS[uctoa_append::digit#2] -- _deref_pbuz1=pbuc1_derefidx_vbum2 + ldy digit + lda DIGITS,y + ldy #0 + sta (buffer),y + // uctoa_append::@return // } - // [2865] return + // [2113] return rts + // uctoa_append::@2 + __b2: + // digit++; + // [2114] uctoa_append::digit#1 = ++ uctoa_append::digit#2 -- vbum1=_inc_vbum1 + inc digit + // value -= sub + // [2115] uctoa_append::value#1 = uctoa_append::value#2 - uctoa_append::sub#0 -- vbum1=vbum1_minus_vbum2 + lda value + sec + sbc sub + sta value + // [2110] phi from uctoa_append::@2 to uctoa_append::@1 [phi:uctoa_append::@2->uctoa_append::@1] + // [2110] phi uctoa_append::digit#2 = uctoa_append::digit#1 [phi:uctoa_append::@2->uctoa_append::@1#0] -- register_copy + // [2110] phi uctoa_append::value#2 = uctoa_append::value#1 [phi:uctoa_append::@2->uctoa_append::@1#1] -- register_copy + jmp __b1 + .segment Data + .label value = printf_uchar.uvalue + .label sub = uctoa.digit_value + .label return = printf_uchar.uvalue + digit: .byte 0 } -.segment Code - // rom_address_from_bank -/** - * @brief Calculates the 22 bit ROM address from the 8 bit ROM bank. - * The ROM bank number is calcuated by taking the 8 bits and shifing those 14 bits to the left (bit 21-14). - * - * @param rom_bank The 8 bit ROM address. - * @return unsigned long The 22 bit ROM address. +.segment CodeVera + // spi_read_flash +// void spi_read_flash(unsigned long spi_data) +spi_read_flash: { + // spi_select() + // [2117] call spi_select + /* +; .X [7:0] +; .Y [15:8] +; .A [23:16] +.proc spi_read_flash + pha + + jsr spi_select + lda #$03 + jsr spi_write + pla + jsr spi_write + tya + jsr spi_write + txa + jsr spi_write + + rts +.endproc */ -/* inline */ -// __mem() unsigned long rom_address_from_bank(__mem() char rom_bank) -rom_address_from_bank: { - .label rom_address_from_bank__1 = $bc - // ((unsigned long)(rom_bank)) << 14 - // [2867] rom_address_from_bank::$1 = (unsigned long)rom_address_from_bank::rom_bank#3 -- vduz1=_dword_vbum2 - lda rom_bank - sta.z rom_address_from_bank__1 + // [2251] phi from spi_read_flash to spi_select [phi:spi_read_flash->spi_select] + jsr spi_select + // spi_read_flash::@1 + // spi_write(0x03) + // [2118] spi_write::data = 3 -- vbum1=vbuc1 + lda #3 + sta spi_write.data + // [2119] call spi_write + jsr spi_write + // spi_read_flash::@2 + // spi_write(BYTE2(spi_data)) + // [2120] spi_write::data = 0 -- vbum1=vbuc1 lda #0 - sta.z rom_address_from_bank__1+1 - sta.z rom_address_from_bank__1+2 - sta.z rom_address_from_bank__1+3 - // [2868] rom_address_from_bank::return#0 = rom_address_from_bank::$1 << $e -- vdum1=vduz2_rol_vbuc1 - ldy #$e - lda.z rom_address_from_bank__1 - sta return - lda.z rom_address_from_bank__1+1 - sta return+1 - lda.z rom_address_from_bank__1+2 - sta return+2 - lda.z rom_address_from_bank__1+3 - sta return+3 - cpy #0 - beq !e+ - !: - asl return - rol return+1 - rol return+2 - rol return+3 - dey - bne !- - !e: - // rom_address_from_bank::@return + sta spi_write.data + // [2121] call spi_write + jsr spi_write + // spi_read_flash::@3 + // spi_write(BYTE1(spi_data)) + // [2122] spi_write::data = 0 -- vbum1=vbuc1 + lda #0 + sta spi_write.data + // [2123] call spi_write + jsr spi_write + // spi_read_flash::@4 + // spi_write(BYTE0(spi_data)) + // [2124] spi_write::data = 0 -- vbum1=vbuc1 + lda #0 + sta spi_write.data + // [2125] call spi_write + jsr spi_write + // spi_read_flash::@return // } - // [2869] return + // [2126] return rts - .segment Data - .label return = rom_read.rom_address - rom_bank: .byte 0 - .label return_1 = rom_verify.rom_address - .label return_2 = rom_flash.rom_address_sector } -.segment Code - // rom_compare -// __mem() unsigned int rom_compare(__mem() char bank_ram, __zp($56) char *ptr_ram, __mem() unsigned long rom_compare_address, __mem() unsigned int rom_compare_size) -rom_compare: { - .label rom_compare__5 = $41 - .label rom_bank1_rom_compare__0 = $29 - .label rom_bank1_rom_compare__1 = $42 - .label rom_bank1_rom_compare__2 = $50 - .label rom_ptr1_rom_compare__0 = $4c - .label rom_ptr1_rom_compare__2 = $4c - .label rom_ptr1_return = $4c - .label ptr_rom = $4c - .label ptr_ram = $56 - // rom_compare::bank_set_bram1 + // vera_compare +// __mem() unsigned int vera_compare(__mem() char bank_ram, __zp($5b) char *bram_ptr, unsigned int vera_compare_size) +vera_compare: { + .label bram_ptr = $5b + // vera_compare::bank_set_bram1 // BRAM = bank - // [2871] BRAM = rom_compare::bank_set_bram1_bank#0 -- vbuz1=vbum2 - lda bank_set_bram1_bank + // [2128] BRAM = vera_compare::bank_ram#0 -- vbuz1=vbum2 + lda bank_ram sta.z BRAM - // rom_compare::rom_bank1 - // BYTE2(address) - // [2872] rom_compare::rom_bank1_$0 = byte2 rom_compare::rom_compare_address#3 -- vbuz1=_byte2_vdum2 - lda rom_compare_address+2 - sta.z rom_bank1_rom_compare__0 - // BYTE1(address) - // [2873] rom_compare::rom_bank1_$1 = byte1 rom_compare::rom_compare_address#3 -- vbuz1=_byte1_vdum2 - lda rom_compare_address+1 - sta.z rom_bank1_rom_compare__1 - // MAKEWORD(BYTE2(address),BYTE1(address)) - // [2874] rom_compare::rom_bank1_$2 = rom_compare::rom_bank1_$0 w= rom_compare::rom_bank1_$1 -- vwuz1=vbuz2_word_vbuz3 - lda.z rom_bank1_rom_compare__0 - sta.z rom_bank1_rom_compare__2+1 - lda.z rom_bank1_rom_compare__1 - sta.z rom_bank1_rom_compare__2 - // unsigned int bank_unshifted = MAKEWORD(BYTE2(address),BYTE1(address)) << 2 - // [2875] rom_compare::rom_bank1_bank_unshifted#0 = rom_compare::rom_bank1_$2 << 2 -- vwum1=vwuz2_rol_2 - asl - sta rom_bank1_bank_unshifted - lda.z rom_bank1_rom_compare__2+1 - rol - sta rom_bank1_bank_unshifted+1 - asl rom_bank1_bank_unshifted - rol rom_bank1_bank_unshifted+1 - // unsigned char bank = BYTE1(bank_unshifted) - // [2876] rom_compare::rom_bank1_return#0 = byte1 rom_compare::rom_bank1_bank_unshifted#0 -- vbum1=_byte1_vwum2 - lda rom_bank1_bank_unshifted+1 - sta rom_bank1_return - // rom_compare::rom_ptr1 - // (unsigned int)(address) & ROM_PTR_MASK - // [2877] rom_compare::rom_ptr1_$2 = (unsigned int)rom_compare::rom_compare_address#3 -- vwuz1=_word_vdum2 - lda rom_compare_address - sta.z rom_ptr1_rom_compare__2 - lda rom_compare_address+1 - sta.z rom_ptr1_rom_compare__2+1 - // [2878] rom_compare::rom_ptr1_$0 = rom_compare::rom_ptr1_$2 & $3fff -- vwuz1=vwuz1_band_vwuc1 - lda.z rom_ptr1_rom_compare__0 - and #<$3fff - sta.z rom_ptr1_rom_compare__0 - lda.z rom_ptr1_rom_compare__0+1 - and #>$3fff - sta.z rom_ptr1_rom_compare__0+1 - // ((unsigned int)(address) & ROM_PTR_MASK) + ROM_BASE - // [2879] rom_compare::rom_ptr1_return#0 = rom_compare::rom_ptr1_$0 + $c000 -- vwuz1=vwuz1_plus_vwuc1 - lda.z rom_ptr1_return - clc - adc #<$c000 - sta.z rom_ptr1_return - lda.z rom_ptr1_return+1 - adc #>$c000 - sta.z rom_ptr1_return+1 - // rom_compare::bank_set_brom1 - // BROM = bank - // [2880] BROM = rom_compare::rom_bank1_return#0 -- vbuz1=vbum2 - lda rom_bank1_return - sta.z BROM - // [2881] rom_compare::ptr_rom#9 = (char *)rom_compare::rom_ptr1_return#0 - // [2882] phi from rom_compare::bank_set_brom1 to rom_compare::@1 [phi:rom_compare::bank_set_brom1->rom_compare::@1] - // [2882] phi rom_compare::equal_bytes#2 = 0 [phi:rom_compare::bank_set_brom1->rom_compare::@1#0] -- vwum1=vwuc1 + // [2129] phi from vera_compare::bank_set_bram1 to vera_compare::@1 [phi:vera_compare::bank_set_bram1->vera_compare::@1] + // [2129] phi vera_compare::bram_ptr#2 = vera_compare::bram_ptr#0 [phi:vera_compare::bank_set_bram1->vera_compare::@1#0] -- register_copy + // [2129] phi vera_compare::equal_bytes#2 = 0 [phi:vera_compare::bank_set_bram1->vera_compare::@1#1] -- vwum1=vwuc1 lda #<0 sta equal_bytes sta equal_bytes+1 - // [2882] phi rom_compare::ptr_ram#4 = rom_compare::ptr_ram#10 [phi:rom_compare::bank_set_brom1->rom_compare::@1#1] -- register_copy - // [2882] phi rom_compare::ptr_rom#2 = rom_compare::ptr_rom#9 [phi:rom_compare::bank_set_brom1->rom_compare::@1#2] -- register_copy - // [2882] phi rom_compare::compared_bytes#2 = 0 [phi:rom_compare::bank_set_brom1->rom_compare::@1#3] -- vwum1=vwuc1 + // [2129] phi vera_compare::compared_bytes#2 = 0 [phi:vera_compare::bank_set_bram1->vera_compare::@1#2] -- vwum1=vwuc1 sta compared_bytes sta compared_bytes+1 - // rom_compare::@1 + // vera_compare::@1 __b1: - // while (compared_bytes < rom_compare_size) - // [2883] if(rom_compare::compared_bytes#2vera_compare::@2] + // vera_compare::@2 __b2: - // rom_byte_compare(ptr_rom, *ptr_ram) - // [2885] rom_byte_compare::ptr_rom#0 = rom_compare::ptr_rom#2 - // [2886] rom_byte_compare::value#0 = *rom_compare::ptr_ram#4 -- vbum1=_deref_pbuz2 + // unsigned char vera_byte = spi_read() + // [2133] call spi_read + jsr spi_read + // [2134] spi_read::return#12 = spi_read::return#4 + // vera_compare::@5 + // [2135] vera_compare::vera_byte#0 = spi_read::return#12 + // if (vera_byte == *bram_ptr) + // [2136] if(vera_compare::vera_byte#0!=*vera_compare::bram_ptr#2) goto vera_compare::@3 -- vbum1_neq__deref_pbuz2_then_la1 ldy #0 - lda (ptr_ram),y - sta rom_byte_compare.value - // [2887] call rom_byte_compare - jsr rom_byte_compare - // [2888] rom_byte_compare::return#2 = rom_byte_compare::return#0 - // rom_compare::@5 - // [2889] rom_compare::$5 = rom_byte_compare::return#2 -- vbuz1=vbum2 - lda rom_byte_compare.return - sta.z rom_compare__5 - // if (rom_byte_compare(ptr_rom, *ptr_ram)) - // [2890] if(0==rom_compare::$5) goto rom_compare::@3 -- 0_eq_vbuz1_then_la1 - beq __b3 - // rom_compare::@4 + lda (bram_ptr),y + cmp vera_byte + bne __b3 + // vera_compare::@4 // equal_bytes++; - // [2891] rom_compare::equal_bytes#1 = ++ rom_compare::equal_bytes#2 -- vwum1=_inc_vwum1 + // [2137] vera_compare::equal_bytes#1 = ++ vera_compare::equal_bytes#2 -- vwum1=_inc_vwum1 inc equal_bytes bne !+ inc equal_bytes+1 !: - // [2892] phi from rom_compare::@4 rom_compare::@5 to rom_compare::@3 [phi:rom_compare::@4/rom_compare::@5->rom_compare::@3] - // [2892] phi rom_compare::equal_bytes#6 = rom_compare::equal_bytes#1 [phi:rom_compare::@4/rom_compare::@5->rom_compare::@3#0] -- register_copy - // rom_compare::@3 + // [2138] phi from vera_compare::@4 vera_compare::@5 to vera_compare::@3 [phi:vera_compare::@4/vera_compare::@5->vera_compare::@3] + // [2138] phi vera_compare::equal_bytes#6 = vera_compare::equal_bytes#1 [phi:vera_compare::@4/vera_compare::@5->vera_compare::@3#0] -- register_copy + // vera_compare::@3 __b3: - // ptr_rom++; - // [2893] rom_compare::ptr_rom#1 = ++ rom_compare::ptr_rom#2 -- pbuz1=_inc_pbuz1 - inc.z ptr_rom + // bram_ptr++; + // [2139] vera_compare::bram_ptr#1 = ++ vera_compare::bram_ptr#2 -- pbuz1=_inc_pbuz1 + inc.z bram_ptr bne !+ - inc.z ptr_rom+1 - !: - // ptr_ram++; - // [2894] rom_compare::ptr_ram#0 = ++ rom_compare::ptr_ram#4 -- pbuz1=_inc_pbuz1 - inc.z ptr_ram - bne !+ - inc.z ptr_ram+1 + inc.z bram_ptr+1 !: // compared_bytes++; - // [2895] rom_compare::compared_bytes#1 = ++ rom_compare::compared_bytes#2 -- vwum1=_inc_vwum1 + // [2140] vera_compare::compared_bytes#1 = ++ vera_compare::compared_bytes#2 -- vwum1=_inc_vwum1 inc compared_bytes bne !+ inc compared_bytes+1 !: - // [2882] phi from rom_compare::@3 to rom_compare::@1 [phi:rom_compare::@3->rom_compare::@1] - // [2882] phi rom_compare::equal_bytes#2 = rom_compare::equal_bytes#6 [phi:rom_compare::@3->rom_compare::@1#0] -- register_copy - // [2882] phi rom_compare::ptr_ram#4 = rom_compare::ptr_ram#0 [phi:rom_compare::@3->rom_compare::@1#1] -- register_copy - // [2882] phi rom_compare::ptr_rom#2 = rom_compare::ptr_rom#1 [phi:rom_compare::@3->rom_compare::@1#2] -- register_copy - // [2882] phi rom_compare::compared_bytes#2 = rom_compare::compared_bytes#1 [phi:rom_compare::@3->rom_compare::@1#3] -- register_copy + // [2129] phi from vera_compare::@3 to vera_compare::@1 [phi:vera_compare::@3->vera_compare::@1] + // [2129] phi vera_compare::bram_ptr#2 = vera_compare::bram_ptr#1 [phi:vera_compare::@3->vera_compare::@1#0] -- register_copy + // [2129] phi vera_compare::equal_bytes#2 = vera_compare::equal_bytes#6 [phi:vera_compare::@3->vera_compare::@1#1] -- register_copy + // [2129] phi vera_compare::compared_bytes#2 = vera_compare::compared_bytes#1 [phi:vera_compare::@3->vera_compare::@1#2] -- register_copy jmp __b1 - .segment Data - bank_set_bram1_bank: .byte 0 - rom_bank1_bank_unshifted: .word 0 - rom_bank1_return: .byte 0 + .segment DataVera + bank_ram: .byte 0 + .label return = equal_bytes + .label vera_byte = spi_read.return_3 compared_bytes: .word 0 - /// Holds the amount of bytes actually verified between the ROM and the RAM. + /// Holds the amount of bytes actually verified between the VERA and the RAM. equal_bytes: .word 0 - .label bank_ram = bank_set_bram1_bank - rom_compare_address: .dword 0 - .label return = equal_bytes - rom_compare_size: .word 0 } .segment Code // ultoa @@ -19322,143 +13461,143 @@ rom_compare: { // - value : The number to be converted to RADIX // - buffer : receives the string representing the number and zero-termination. // - radix : The radix to convert the number to (from the enum RADIX) -// void ultoa(__mem() unsigned long value, __zp($38) char *buffer, __mem() char radix) +// void ultoa(__mem() unsigned long value, __zp($34) char *buffer, __mem() char radix) ultoa: { - .label ultoa__4 = $42 - .label ultoa__10 = $3a - .label ultoa__11 = $41 - .label buffer = $38 - .label digit_values = $4a + .label ultoa__4 = $3a + .label ultoa__10 = $39 + .label ultoa__11 = $4d + .label buffer = $34 + .label digit_values = $40 // if(radix==DECIMAL) - // [2896] if(ultoa::radix#0==DECIMAL) goto ultoa::@1 -- vbum1_eq_vbuc1_then_la1 + // [2141] if(ultoa::radix#0==DECIMAL) goto ultoa::@1 -- vbum1_eq_vbuc1_then_la1 lda #DECIMAL cmp radix beq __b2 // ultoa::@2 // if(radix==HEXADECIMAL) - // [2897] if(ultoa::radix#0==HEXADECIMAL) goto ultoa::@1 -- vbum1_eq_vbuc1_then_la1 + // [2142] if(ultoa::radix#0==HEXADECIMAL) goto ultoa::@1 -- vbum1_eq_vbuc1_then_la1 lda #HEXADECIMAL cmp radix beq __b3 // ultoa::@3 // if(radix==OCTAL) - // [2898] if(ultoa::radix#0==OCTAL) goto ultoa::@1 -- vbum1_eq_vbuc1_then_la1 + // [2143] if(ultoa::radix#0==OCTAL) goto ultoa::@1 -- vbum1_eq_vbuc1_then_la1 lda #OCTAL cmp radix beq __b4 // ultoa::@4 // if(radix==BINARY) - // [2899] if(ultoa::radix#0==BINARY) goto ultoa::@1 -- vbum1_eq_vbuc1_then_la1 + // [2144] if(ultoa::radix#0==BINARY) goto ultoa::@1 -- vbum1_eq_vbuc1_then_la1 lda #BINARY cmp radix beq __b5 // ultoa::@5 // *buffer++ = 'e' - // [2900] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS) = 'e' -- _deref_pbuc1=vbuc2 + // [2145] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS) = 'e' -- _deref_pbuc1=vbuc2 // Unknown radix lda #'e' sta printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS // *buffer++ = 'r' - // [2901] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+1) = 'r' -- _deref_pbuc1=vbuc2 + // [2146] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+1) = 'r' -- _deref_pbuc1=vbuc2 lda #'r' sta printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+1 - // [2902] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+2) = 'r' -- _deref_pbuc1=vbuc2 + // [2147] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+2) = 'r' -- _deref_pbuc1=vbuc2 sta printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+2 // *buffer = 0 - // [2903] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+3) = 0 -- _deref_pbuc1=vbuc2 + // [2148] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+3) = 0 -- _deref_pbuc1=vbuc2 lda #0 sta printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+3 // ultoa::@return // } - // [2904] return + // [2149] return rts - // [2905] phi from ultoa to ultoa::@1 [phi:ultoa->ultoa::@1] + // [2150] phi from ultoa to ultoa::@1 [phi:ultoa->ultoa::@1] __b2: - // [2905] phi ultoa::digit_values#8 = RADIX_DECIMAL_VALUES_LONG [phi:ultoa->ultoa::@1#0] -- pduz1=pduc1 + // [2150] phi ultoa::digit_values#8 = RADIX_DECIMAL_VALUES_LONG [phi:ultoa->ultoa::@1#0] -- pduz1=pduc1 lda #RADIX_DECIMAL_VALUES_LONG sta.z digit_values+1 - // [2905] phi ultoa::max_digits#7 = $a [phi:ultoa->ultoa::@1#1] -- vbum1=vbuc1 + // [2150] phi ultoa::max_digits#7 = $a [phi:ultoa->ultoa::@1#1] -- vbum1=vbuc1 lda #$a sta max_digits jmp __b1 - // [2905] phi from ultoa::@2 to ultoa::@1 [phi:ultoa::@2->ultoa::@1] + // [2150] phi from ultoa::@2 to ultoa::@1 [phi:ultoa::@2->ultoa::@1] __b3: - // [2905] phi ultoa::digit_values#8 = RADIX_HEXADECIMAL_VALUES_LONG [phi:ultoa::@2->ultoa::@1#0] -- pduz1=pduc1 + // [2150] phi ultoa::digit_values#8 = RADIX_HEXADECIMAL_VALUES_LONG [phi:ultoa::@2->ultoa::@1#0] -- pduz1=pduc1 lda #RADIX_HEXADECIMAL_VALUES_LONG sta.z digit_values+1 - // [2905] phi ultoa::max_digits#7 = 8 [phi:ultoa::@2->ultoa::@1#1] -- vbum1=vbuc1 + // [2150] phi ultoa::max_digits#7 = 8 [phi:ultoa::@2->ultoa::@1#1] -- vbum1=vbuc1 lda #8 sta max_digits jmp __b1 - // [2905] phi from ultoa::@3 to ultoa::@1 [phi:ultoa::@3->ultoa::@1] + // [2150] phi from ultoa::@3 to ultoa::@1 [phi:ultoa::@3->ultoa::@1] __b4: - // [2905] phi ultoa::digit_values#8 = RADIX_OCTAL_VALUES_LONG [phi:ultoa::@3->ultoa::@1#0] -- pduz1=pduc1 + // [2150] phi ultoa::digit_values#8 = RADIX_OCTAL_VALUES_LONG [phi:ultoa::@3->ultoa::@1#0] -- pduz1=pduc1 lda #RADIX_OCTAL_VALUES_LONG sta.z digit_values+1 - // [2905] phi ultoa::max_digits#7 = $b [phi:ultoa::@3->ultoa::@1#1] -- vbum1=vbuc1 + // [2150] phi ultoa::max_digits#7 = $b [phi:ultoa::@3->ultoa::@1#1] -- vbum1=vbuc1 lda #$b sta max_digits jmp __b1 - // [2905] phi from ultoa::@4 to ultoa::@1 [phi:ultoa::@4->ultoa::@1] + // [2150] phi from ultoa::@4 to ultoa::@1 [phi:ultoa::@4->ultoa::@1] __b5: - // [2905] phi ultoa::digit_values#8 = RADIX_BINARY_VALUES_LONG [phi:ultoa::@4->ultoa::@1#0] -- pduz1=pduc1 + // [2150] phi ultoa::digit_values#8 = RADIX_BINARY_VALUES_LONG [phi:ultoa::@4->ultoa::@1#0] -- pduz1=pduc1 lda #RADIX_BINARY_VALUES_LONG sta.z digit_values+1 - // [2905] phi ultoa::max_digits#7 = $20 [phi:ultoa::@4->ultoa::@1#1] -- vbum1=vbuc1 + // [2150] phi ultoa::max_digits#7 = $20 [phi:ultoa::@4->ultoa::@1#1] -- vbum1=vbuc1 lda #$20 sta max_digits // ultoa::@1 __b1: - // [2906] phi from ultoa::@1 to ultoa::@6 [phi:ultoa::@1->ultoa::@6] - // [2906] phi ultoa::buffer#11 = (char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS [phi:ultoa::@1->ultoa::@6#0] -- pbuz1=pbuc1 + // [2151] phi from ultoa::@1 to ultoa::@6 [phi:ultoa::@1->ultoa::@6] + // [2151] phi ultoa::buffer#11 = (char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS [phi:ultoa::@1->ultoa::@6#0] -- pbuz1=pbuc1 lda #printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS sta.z buffer+1 - // [2906] phi ultoa::started#2 = 0 [phi:ultoa::@1->ultoa::@6#1] -- vbum1=vbuc1 + // [2151] phi ultoa::started#2 = 0 [phi:ultoa::@1->ultoa::@6#1] -- vbum1=vbuc1 lda #0 sta started - // [2906] phi ultoa::value#2 = ultoa::value#1 [phi:ultoa::@1->ultoa::@6#2] -- register_copy - // [2906] phi ultoa::digit#2 = 0 [phi:ultoa::@1->ultoa::@6#3] -- vbum1=vbuc1 + // [2151] phi ultoa::value#2 = ultoa::value#1 [phi:ultoa::@1->ultoa::@6#2] -- register_copy + // [2151] phi ultoa::digit#2 = 0 [phi:ultoa::@1->ultoa::@6#3] -- vbum1=vbuc1 sta digit // ultoa::@6 __b6: // max_digits-1 - // [2907] ultoa::$4 = ultoa::max_digits#7 - 1 -- vbuz1=vbum2_minus_1 + // [2152] ultoa::$4 = ultoa::max_digits#7 - 1 -- vbuz1=vbum2_minus_1 ldx max_digits dex stx.z ultoa__4 // for( char digit=0; digit= digit_value) - // [2915] if(0!=ultoa::started#2) goto ultoa::@10 -- 0_neq_vbum1_then_la1 + // [2160] if(0!=ultoa::started#2) goto ultoa::@10 -- 0_neq_vbum1_then_la1 lda started bne __b10 // ultoa::@12 - // [2916] if(ultoa::value#2>=ultoa::digit_value#0) goto ultoa::@10 -- vdum1_ge_vdum2_then_la1 + // [2161] if(ultoa::value#2>=ultoa::digit_value#0) goto ultoa::@10 -- vdum1_ge_vdum2_then_la1 lda value+3 cmp digit_value+3 bcc !+ @@ -19506,51 +13645,51 @@ ultoa: { cmp digit_value bcs __b10 !: - // [2917] phi from ultoa::@12 to ultoa::@9 [phi:ultoa::@12->ultoa::@9] - // [2917] phi ultoa::buffer#14 = ultoa::buffer#11 [phi:ultoa::@12->ultoa::@9#0] -- register_copy - // [2917] phi ultoa::started#4 = ultoa::started#2 [phi:ultoa::@12->ultoa::@9#1] -- register_copy - // [2917] phi ultoa::value#6 = ultoa::value#2 [phi:ultoa::@12->ultoa::@9#2] -- register_copy + // [2162] phi from ultoa::@12 to ultoa::@9 [phi:ultoa::@12->ultoa::@9] + // [2162] phi ultoa::buffer#14 = ultoa::buffer#11 [phi:ultoa::@12->ultoa::@9#0] -- register_copy + // [2162] phi ultoa::started#4 = ultoa::started#2 [phi:ultoa::@12->ultoa::@9#1] -- register_copy + // [2162] phi ultoa::value#6 = ultoa::value#2 [phi:ultoa::@12->ultoa::@9#2] -- register_copy // ultoa::@9 __b9: // for( char digit=0; digitultoa::@6] - // [2906] phi ultoa::buffer#11 = ultoa::buffer#14 [phi:ultoa::@9->ultoa::@6#0] -- register_copy - // [2906] phi ultoa::started#2 = ultoa::started#4 [phi:ultoa::@9->ultoa::@6#1] -- register_copy - // [2906] phi ultoa::value#2 = ultoa::value#6 [phi:ultoa::@9->ultoa::@6#2] -- register_copy - // [2906] phi ultoa::digit#2 = ultoa::digit#1 [phi:ultoa::@9->ultoa::@6#3] -- register_copy + // [2151] phi from ultoa::@9 to ultoa::@6 [phi:ultoa::@9->ultoa::@6] + // [2151] phi ultoa::buffer#11 = ultoa::buffer#14 [phi:ultoa::@9->ultoa::@6#0] -- register_copy + // [2151] phi ultoa::started#2 = ultoa::started#4 [phi:ultoa::@9->ultoa::@6#1] -- register_copy + // [2151] phi ultoa::value#2 = ultoa::value#6 [phi:ultoa::@9->ultoa::@6#2] -- register_copy + // [2151] phi ultoa::digit#2 = ultoa::digit#1 [phi:ultoa::@9->ultoa::@6#3] -- register_copy jmp __b6 // ultoa::@10 __b10: // ultoa_append(buffer++, value, digit_value) - // [2919] ultoa_append::buffer#0 = ultoa::buffer#11 -- pbuz1=pbuz2 + // [2164] ultoa_append::buffer#0 = ultoa::buffer#11 -- pbuz1=pbuz2 lda.z buffer sta.z ultoa_append.buffer lda.z buffer+1 sta.z ultoa_append.buffer+1 - // [2920] ultoa_append::value#0 = ultoa::value#2 - // [2921] ultoa_append::sub#0 = ultoa::digit_value#0 - // [2922] call ultoa_append - // [3340] phi from ultoa::@10 to ultoa_append [phi:ultoa::@10->ultoa_append] + // [2165] ultoa_append::value#0 = ultoa::value#2 + // [2166] ultoa_append::sub#0 = ultoa::digit_value#0 + // [2167] call ultoa_append + // [2332] phi from ultoa::@10 to ultoa_append [phi:ultoa::@10->ultoa_append] jsr ultoa_append // ultoa_append(buffer++, value, digit_value) - // [2923] ultoa_append::return#0 = ultoa_append::value#2 + // [2168] ultoa_append::return#0 = ultoa_append::value#2 // ultoa::@11 // value = ultoa_append(buffer++, value, digit_value) - // [2924] ultoa::value#0 = ultoa_append::return#0 + // [2169] ultoa::value#0 = ultoa_append::return#0 // value = ultoa_append(buffer++, value, digit_value); - // [2925] ultoa::buffer#4 = ++ ultoa::buffer#11 -- pbuz1=_inc_pbuz1 + // [2170] ultoa::buffer#4 = ++ ultoa::buffer#11 -- pbuz1=_inc_pbuz1 inc.z buffer bne !+ inc.z buffer+1 !: - // [2917] phi from ultoa::@11 to ultoa::@9 [phi:ultoa::@11->ultoa::@9] - // [2917] phi ultoa::buffer#14 = ultoa::buffer#4 [phi:ultoa::@11->ultoa::@9#0] -- register_copy - // [2917] phi ultoa::started#4 = 1 [phi:ultoa::@11->ultoa::@9#1] -- vbum1=vbuc1 + // [2162] phi from ultoa::@11 to ultoa::@9 [phi:ultoa::@11->ultoa::@9] + // [2162] phi ultoa::buffer#14 = ultoa::buffer#4 [phi:ultoa::@11->ultoa::@9#0] -- register_copy + // [2162] phi ultoa::started#4 = 1 [phi:ultoa::@11->ultoa::@9#1] -- vbum1=vbuc1 lda #1 sta started - // [2917] phi ultoa::value#6 = ultoa::value#0 [phi:ultoa::@11->ultoa::@9#2] -- register_copy + // [2162] phi ultoa::value#6 = ultoa::value#0 [phi:ultoa::@11->ultoa::@9#2] -- register_copy jmp __b9 .segment Data digit_value: .dword 0 @@ -19562,29 +13701,22 @@ ultoa: { } .segment Code // display_action_text_flashed -// void display_action_text_flashed(__mem() unsigned long bytes, __zp($4e) char *chip) +// void display_action_text_flashed(__mem() unsigned long bytes, char *chip) display_action_text_flashed: { - .label chip = $4e // sprintf(info_text, "Flashed %u bytes from RAM -> %s ... ", bytes, chip) - // [2927] call snprintf_init - // [1205] phi from display_action_text_flashed to snprintf_init [phi:display_action_text_flashed->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:display_action_text_flashed->snprintf_init#0] -- pbuz1=pbuc1 - lda #info_text - sta.z snprintf_init.s+1 + // [2172] call snprintf_init jsr snprintf_init - // [2928] phi from display_action_text_flashed to display_action_text_flashed::@1 [phi:display_action_text_flashed->display_action_text_flashed::@1] + // [2173] phi from display_action_text_flashed to display_action_text_flashed::@1 [phi:display_action_text_flashed->display_action_text_flashed::@1] // display_action_text_flashed::@1 // sprintf(info_text, "Flashed %u bytes from RAM -> %s ... ", bytes, chip) - // [2929] call printf_str - // [1210] phi from display_action_text_flashed::@1 to printf_str [phi:display_action_text_flashed::@1->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:display_action_text_flashed::@1->printf_str#0] -- pprz1=pprc1 + // [2174] call printf_str + // [785] phi from display_action_text_flashed::@1 to printf_str [phi:display_action_text_flashed::@1->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:display_action_text_flashed::@1->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = display_action_text_flashed::s [phi:display_action_text_flashed::@1->printf_str#1] -- pbuz1=pbuc1 + // [785] phi printf_str::s#53 = display_action_text_flashed::s [phi:display_action_text_flashed::@1->printf_str#1] -- pbuz1=pbuc1 lda #s @@ -19592,7 +13724,7 @@ display_action_text_flashed: { jsr printf_str // display_action_text_flashed::@2 // sprintf(info_text, "Flashed %u bytes from RAM -> %s ... ", bytes, chip) - // [2930] printf_ulong::uvalue#4 = display_action_text_flashed::bytes#3 -- vdum1=vdum2 + // [2175] printf_ulong::uvalue#4 = display_action_text_flashed::bytes#0 -- vdum1=vdum2 lda bytes sta printf_ulong.uvalue lda bytes+1 @@ -19601,66 +13733,66 @@ display_action_text_flashed: { sta printf_ulong.uvalue+2 lda bytes+3 sta printf_ulong.uvalue+3 - // [2931] call printf_ulong - // [1741] phi from display_action_text_flashed::@2 to printf_ulong [phi:display_action_text_flashed::@2->printf_ulong] - // [1741] phi printf_ulong::format_zero_padding#15 = 0 [phi:display_action_text_flashed::@2->printf_ulong#0] -- vbum1=vbuc1 + // [2176] call printf_ulong + // [1633] phi from display_action_text_flashed::@2 to printf_ulong [phi:display_action_text_flashed::@2->printf_ulong] + // [1633] phi printf_ulong::format_zero_padding#10 = 0 [phi:display_action_text_flashed::@2->printf_ulong#0] -- vbum1=vbuc1 lda #0 sta printf_ulong.format_zero_padding - // [1741] phi printf_ulong::format_min_length#15 = 0 [phi:display_action_text_flashed::@2->printf_ulong#1] -- vbum1=vbuc1 + // [1633] phi printf_ulong::format_min_length#10 = 0 [phi:display_action_text_flashed::@2->printf_ulong#1] -- vbum1=vbuc1 sta printf_ulong.format_min_length - // [1741] phi printf_ulong::format_radix#15 = DECIMAL [phi:display_action_text_flashed::@2->printf_ulong#2] -- vbum1=vbuc1 + // [1633] phi printf_ulong::format_radix#10 = DECIMAL [phi:display_action_text_flashed::@2->printf_ulong#2] -- vbum1=vbuc1 lda #DECIMAL sta printf_ulong.format_radix - // [1741] phi printf_ulong::uvalue#15 = printf_ulong::uvalue#4 [phi:display_action_text_flashed::@2->printf_ulong#3] -- register_copy + // [1633] phi printf_ulong::uvalue#10 = printf_ulong::uvalue#4 [phi:display_action_text_flashed::@2->printf_ulong#3] -- register_copy jsr printf_ulong - // [2932] phi from display_action_text_flashed::@2 to display_action_text_flashed::@3 [phi:display_action_text_flashed::@2->display_action_text_flashed::@3] + // [2177] phi from display_action_text_flashed::@2 to display_action_text_flashed::@3 [phi:display_action_text_flashed::@2->display_action_text_flashed::@3] // display_action_text_flashed::@3 // sprintf(info_text, "Flashed %u bytes from RAM -> %s ... ", bytes, chip) - // [2933] call printf_str - // [1210] phi from display_action_text_flashed::@3 to printf_str [phi:display_action_text_flashed::@3->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:display_action_text_flashed::@3->printf_str#0] -- pprz1=pprc1 + // [2178] call printf_str + // [785] phi from display_action_text_flashed::@3 to printf_str [phi:display_action_text_flashed::@3->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:display_action_text_flashed::@3->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = display_action_text_flashed::s1 [phi:display_action_text_flashed::@3->printf_str#1] -- pbuz1=pbuc1 + // [785] phi printf_str::s#53 = display_action_text_flashed::s1 [phi:display_action_text_flashed::@3->printf_str#1] -- pbuz1=pbuc1 lda #s1 sta.z printf_str.s+1 jsr printf_str + // [2179] phi from display_action_text_flashed::@3 to display_action_text_flashed::@4 [phi:display_action_text_flashed::@3->display_action_text_flashed::@4] // display_action_text_flashed::@4 // sprintf(info_text, "Flashed %u bytes from RAM -> %s ... ", bytes, chip) - // [2934] printf_string::str#13 = display_action_text_flashed::chip#3 -- pbuz1=pbuz2 - lda.z chip - sta.z printf_string.str - lda.z chip+1 - sta.z printf_string.str+1 - // [2935] call printf_string - // [1219] phi from display_action_text_flashed::@4 to printf_string [phi:display_action_text_flashed::@4->printf_string] - // [1219] phi printf_string::putc#26 = &snputc [phi:display_action_text_flashed::@4->printf_string#0] -- pprz1=pprc1 + // [2180] call printf_string + // [1308] phi from display_action_text_flashed::@4 to printf_string [phi:display_action_text_flashed::@4->printf_string] + // [1308] phi printf_string::putc#17 = &snputc [phi:display_action_text_flashed::@4->printf_string#0] -- pprz1=pprc1 lda #snputc sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#13 [phi:display_action_text_flashed::@4->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 0 [phi:display_action_text_flashed::@4->printf_string#2] -- vbum1=vbuc1 + // [1308] phi printf_string::str#17 = vera_flash::chip [phi:display_action_text_flashed::@4->printf_string#1] -- pbuz1=pbuc1 + lda #vera_flash.chip + sta.z printf_string.str+1 + // [1308] phi printf_string::format_justify_left#17 = 0 [phi:display_action_text_flashed::@4->printf_string#2] -- vbum1=vbuc1 lda #0 sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = 0 [phi:display_action_text_flashed::@4->printf_string#3] -- vbum1=vbuc1 + // [1308] phi printf_string::format_min_length#17 = 0 [phi:display_action_text_flashed::@4->printf_string#3] -- vbum1=vbuc1 sta printf_string.format_min_length jsr printf_string - // [2936] phi from display_action_text_flashed::@4 to display_action_text_flashed::@5 [phi:display_action_text_flashed::@4->display_action_text_flashed::@5] + // [2181] phi from display_action_text_flashed::@4 to display_action_text_flashed::@5 [phi:display_action_text_flashed::@4->display_action_text_flashed::@5] // display_action_text_flashed::@5 // sprintf(info_text, "Flashed %u bytes from RAM -> %s ... ", bytes, chip) - // [2937] call printf_str - // [1210] phi from display_action_text_flashed::@5 to printf_str [phi:display_action_text_flashed::@5->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:display_action_text_flashed::@5->printf_str#0] -- pprz1=pprc1 + // [2182] call printf_str + // [785] phi from display_action_text_flashed::@5 to printf_str [phi:display_action_text_flashed::@5->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:display_action_text_flashed::@5->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s5 [phi:display_action_text_flashed::@5->printf_str#1] -- pbuz1=pbuc1 + // [785] phi printf_str::s#53 = s5 [phi:display_action_text_flashed::@5->printf_str#1] -- pbuz1=pbuc1 lda #s5 @@ -19668,17 +13800,17 @@ display_action_text_flashed: { jsr printf_str // display_action_text_flashed::@6 // sprintf(info_text, "Flashed %u bytes from RAM -> %s ... ", bytes, chip) - // [2938] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 + // [2183] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 lda #0 pha - // [2939] callexecute snputc -- call_vprc1 + // [2184] callexecute snputc -- call_vprc1 jsr snputc // sideeffect stackpullpadding(1) -- _stackpullpadding_1 pla // display_action_text(info_text) - // [2941] call display_action_text - // [1357] phi from display_action_text_flashed::@6 to display_action_text [phi:display_action_text_flashed::@6->display_action_text] - // [1357] phi display_action_text::info_text#25 = info_text [phi:display_action_text_flashed::@6->display_action_text#0] -- pbuz1=pbuc1 + // [2186] call display_action_text + // [845] phi from display_action_text_flashed::@6 to display_action_text [phi:display_action_text_flashed::@6->display_action_text] + // [845] phi display_action_text::info_text#17 = info_text [phi:display_action_text_flashed::@6->display_action_text#0] -- pbuz1=pbuc1 lda #info_text @@ -19686,7 +13818,7 @@ display_action_text_flashed: { jsr display_action_text // display_action_text_flashed::@return // } - // [2942] return + // [2187] return rts .segment Data s: .text "Flashed " @@ -19695,200 +13827,64 @@ display_action_text_flashed: { .byte 0 bytes: .dword 0 } -.segment Code - // rom_sector_erase -/** - * @brief Erases a 1KB sector of the ROM using the 22 bit address. - * This is required before any new bytes can be flashed into the ROM. - * Erasing a sector of the ROM requires an erase sector sequence to be initiated, which has the following steps: - * - * 1. Write byte $AA into ROM address $005555. - * 2. Write byte $55 into ROM address $002AAA. - * 3. Write byte $80 into ROM address $005555. - * 4. Write byte $AA into ROM address $005555. - * 5. Write byte $55 into ROM address $002AAA. - * - * Once this write sequence is finished, the ROM sector is erased by writing byte $30 into the 22 bit ROM sector address. - * Then it waits until the chip has correctly flashed the ROM erasure. - * - * Note that a ROM sector is 1KB (not 4KB), so the most 7 significant bits (18-12) are used. - * The remainder 12 low bits are ignored. - * - * +---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+ - * | 2 | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - * | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | - * +---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+ - * SECTOR 0x37F000 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - * +---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+ - * IGNORED 0x000FFF | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | - * +---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+ - * - * @param address The 22 bit ROM address. - */ -/* inline */ -// void rom_sector_erase(__mem() unsigned long address) -rom_sector_erase: { - .label rom_ptr1_rom_sector_erase__0 = $2d - .label rom_ptr1_rom_sector_erase__2 = $2d - .label rom_ptr1_return = $2d - // rom_sector_erase::rom_ptr1 - // (unsigned int)(address) & ROM_PTR_MASK - // [2944] rom_sector_erase::rom_ptr1_$2 = (unsigned int)rom_sector_erase::address#0 -- vwuz1=_word_vdum2 - lda address - sta.z rom_ptr1_rom_sector_erase__2 - lda address+1 - sta.z rom_ptr1_rom_sector_erase__2+1 - // [2945] rom_sector_erase::rom_ptr1_$0 = rom_sector_erase::rom_ptr1_$2 & $3fff -- vwuz1=vwuz1_band_vwuc1 - lda.z rom_ptr1_rom_sector_erase__0 - and #<$3fff - sta.z rom_ptr1_rom_sector_erase__0 - lda.z rom_ptr1_rom_sector_erase__0+1 - and #>$3fff - sta.z rom_ptr1_rom_sector_erase__0+1 - // ((unsigned int)(address) & ROM_PTR_MASK) + ROM_BASE - // [2946] rom_sector_erase::rom_ptr1_return#0 = rom_sector_erase::rom_ptr1_$0 + $c000 -- vwuz1=vwuz1_plus_vwuc1 - lda.z rom_ptr1_return - clc - adc #<$c000 - sta.z rom_ptr1_return - lda.z rom_ptr1_return+1 - adc #>$c000 - sta.z rom_ptr1_return+1 - // rom_sector_erase::@1 - // unsigned long rom_chip_address = address & ROM_CHIP_MASK - // [2947] rom_sector_erase::rom_chip_address#0 = rom_sector_erase::address#0 & $380000 -- vdum1=vdum2_band_vduc1 - lda address - and #<$380000 - sta rom_chip_address - lda address+1 - and #>$380000 - sta rom_chip_address+1 - lda address+2 - and #<$380000>>$10 - sta rom_chip_address+2 - lda address+3 - and #>$380000>>$10 - sta rom_chip_address+3 - // rom_unlock(rom_chip_address + 0x05555, 0x80) - // [2948] rom_unlock::address#0 = rom_sector_erase::rom_chip_address#0 + $5555 -- vdum1=vdum1_plus_vwuc1 - clc - lda rom_unlock.address - adc #<$5555 - sta rom_unlock.address - lda rom_unlock.address+1 - adc #>$5555 - sta rom_unlock.address+1 - lda rom_unlock.address+2 - adc #0 - sta rom_unlock.address+2 - lda rom_unlock.address+3 - adc #0 - sta rom_unlock.address+3 - // [2949] call rom_unlock - // [2394] phi from rom_sector_erase::@1 to rom_unlock [phi:rom_sector_erase::@1->rom_unlock] - // [2394] phi rom_unlock::unlock_code#5 = $80 [phi:rom_sector_erase::@1->rom_unlock#0] -- vbum1=vbuc1 - lda #$80 - sta rom_unlock.unlock_code - // [2394] phi rom_unlock::address#5 = rom_unlock::address#0 [phi:rom_sector_erase::@1->rom_unlock#1] -- register_copy - jsr rom_unlock - // rom_sector_erase::@2 - // rom_unlock(address, 0x30) - // [2950] rom_unlock::address#1 = rom_sector_erase::address#0 -- vdum1=vdum2 - lda address - sta rom_unlock.address - lda address+1 - sta rom_unlock.address+1 - lda address+2 - sta rom_unlock.address+2 - lda address+3 - sta rom_unlock.address+3 - // [2951] call rom_unlock - // [2394] phi from rom_sector_erase::@2 to rom_unlock [phi:rom_sector_erase::@2->rom_unlock] - // [2394] phi rom_unlock::unlock_code#5 = $30 [phi:rom_sector_erase::@2->rom_unlock#0] -- vbum1=vbuc1 - lda #$30 - sta rom_unlock.unlock_code - // [2394] phi rom_unlock::address#5 = rom_unlock::address#1 [phi:rom_sector_erase::@2->rom_unlock#1] -- register_copy - jsr rom_unlock - // rom_sector_erase::@3 - // rom_wait(ptr_rom) - // [2952] rom_wait::ptr_rom#0 = (char *)rom_sector_erase::rom_ptr1_return#0 - // [2953] call rom_wait - // [3347] phi from rom_sector_erase::@3 to rom_wait [phi:rom_sector_erase::@3->rom_wait] - // [3347] phi rom_wait::ptr_rom#3 = rom_wait::ptr_rom#0 [phi:rom_sector_erase::@3->rom_wait#0] -- register_copy - jsr rom_wait - // rom_sector_erase::@return - // } - // [2954] return - rts - .segment Data - .label rom_chip_address = rom_unlock.address - address: .dword 0 -} .segment Code // display_action_text_flashing -// void display_action_text_flashing(__mem() unsigned long bytes, __zp($69) char *chip, __mem() char bram_bank, __zp($66) char *bram_ptr, __mem() unsigned long address) +// void display_action_text_flashing(unsigned long bytes, char *chip, __mem() char bram_bank, __zp($51) char *bram_ptr, __mem() unsigned long address) display_action_text_flashing: { - .label bram_ptr = $66 - .label chip = $69 + .label bram_ptr = $51 // sprintf(info_text, "Flashing %u bytes from RAM:%02x:%04p -> %s:%05x ... ", bytes, bram_bank, bram_ptr, chip, address) - // [2956] call snprintf_init - // [1205] phi from display_action_text_flashing to snprintf_init [phi:display_action_text_flashing->snprintf_init] - // [1205] phi snprintf_init::s#31 = info_text [phi:display_action_text_flashing->snprintf_init#0] -- pbuz1=pbuc1 - lda #info_text - sta.z snprintf_init.s+1 + // [2189] call snprintf_init jsr snprintf_init - // [2957] phi from display_action_text_flashing to display_action_text_flashing::@1 [phi:display_action_text_flashing->display_action_text_flashing::@1] + // [2190] phi from display_action_text_flashing to display_action_text_flashing::@1 [phi:display_action_text_flashing->display_action_text_flashing::@1] // display_action_text_flashing::@1 // sprintf(info_text, "Flashing %u bytes from RAM:%02x:%04p -> %s:%05x ... ", bytes, bram_bank, bram_ptr, chip, address) - // [2958] call printf_str - // [1210] phi from display_action_text_flashing::@1 to printf_str [phi:display_action_text_flashing::@1->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:display_action_text_flashing::@1->printf_str#0] -- pprz1=pprc1 + // [2191] call printf_str + // [785] phi from display_action_text_flashing::@1 to printf_str [phi:display_action_text_flashing::@1->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:display_action_text_flashing::@1->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = display_action_text_flashing::s [phi:display_action_text_flashing::@1->printf_str#1] -- pbuz1=pbuc1 + // [785] phi printf_str::s#53 = display_action_text_flashing::s [phi:display_action_text_flashing::@1->printf_str#1] -- pbuz1=pbuc1 lda #s sta.z printf_str.s+1 jsr printf_str + // [2192] phi from display_action_text_flashing::@1 to display_action_text_flashing::@2 [phi:display_action_text_flashing::@1->display_action_text_flashing::@2] // display_action_text_flashing::@2 // sprintf(info_text, "Flashing %u bytes from RAM:%02x:%04p -> %s:%05x ... ", bytes, bram_bank, bram_ptr, chip, address) - // [2959] printf_ulong::uvalue#2 = display_action_text_flashing::bytes#3 -- vdum1=vdum2 - lda bytes - sta printf_ulong.uvalue - lda bytes+1 - sta printf_ulong.uvalue+1 - lda bytes+2 - sta printf_ulong.uvalue+2 - lda bytes+3 - sta printf_ulong.uvalue+3 - // [2960] call printf_ulong - // [1741] phi from display_action_text_flashing::@2 to printf_ulong [phi:display_action_text_flashing::@2->printf_ulong] - // [1741] phi printf_ulong::format_zero_padding#15 = 0 [phi:display_action_text_flashing::@2->printf_ulong#0] -- vbum1=vbuc1 + // [2193] call printf_ulong + // [1633] phi from display_action_text_flashing::@2 to printf_ulong [phi:display_action_text_flashing::@2->printf_ulong] + // [1633] phi printf_ulong::format_zero_padding#10 = 0 [phi:display_action_text_flashing::@2->printf_ulong#0] -- vbum1=vbuc1 lda #0 sta printf_ulong.format_zero_padding - // [1741] phi printf_ulong::format_min_length#15 = 0 [phi:display_action_text_flashing::@2->printf_ulong#1] -- vbum1=vbuc1 + // [1633] phi printf_ulong::format_min_length#10 = 0 [phi:display_action_text_flashing::@2->printf_ulong#1] -- vbum1=vbuc1 sta printf_ulong.format_min_length - // [1741] phi printf_ulong::format_radix#15 = DECIMAL [phi:display_action_text_flashing::@2->printf_ulong#2] -- vbum1=vbuc1 + // [1633] phi printf_ulong::format_radix#10 = DECIMAL [phi:display_action_text_flashing::@2->printf_ulong#2] -- vbum1=vbuc1 lda #DECIMAL sta printf_ulong.format_radix - // [1741] phi printf_ulong::uvalue#15 = printf_ulong::uvalue#2 [phi:display_action_text_flashing::@2->printf_ulong#3] -- register_copy + // [1633] phi printf_ulong::uvalue#10 = VERA_PROGRESS_PAGE [phi:display_action_text_flashing::@2->printf_ulong#3] -- vdum1=vduc1 + lda #VERA_PROGRESS_PAGE + sta printf_ulong.uvalue+1 + lda #>$10 + sta printf_ulong.uvalue+2 + lda #>VERA_PROGRESS_PAGE>>$10 + sta printf_ulong.uvalue+3 jsr printf_ulong - // [2961] phi from display_action_text_flashing::@2 to display_action_text_flashing::@3 [phi:display_action_text_flashing::@2->display_action_text_flashing::@3] + // [2194] phi from display_action_text_flashing::@2 to display_action_text_flashing::@3 [phi:display_action_text_flashing::@2->display_action_text_flashing::@3] // display_action_text_flashing::@3 // sprintf(info_text, "Flashing %u bytes from RAM:%02x:%04p -> %s:%05x ... ", bytes, bram_bank, bram_ptr, chip, address) - // [2962] call printf_str - // [1210] phi from display_action_text_flashing::@3 to printf_str [phi:display_action_text_flashing::@3->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:display_action_text_flashing::@3->printf_str#0] -- pprz1=pprc1 + // [2195] call printf_str + // [785] phi from display_action_text_flashing::@3 to printf_str [phi:display_action_text_flashing::@3->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:display_action_text_flashing::@3->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = display_action_text_flashing::s1 [phi:display_action_text_flashing::@3->printf_str#1] -- pbuz1=pbuc1 + // [785] phi printf_str::s#53 = display_action_text_flashing::s1 [phi:display_action_text_flashing::@3->printf_str#1] -- pbuz1=pbuc1 lda #s1 @@ -19896,38 +13892,38 @@ display_action_text_flashing: { jsr printf_str // display_action_text_flashing::@4 // sprintf(info_text, "Flashing %u bytes from RAM:%02x:%04p -> %s:%05x ... ", bytes, bram_bank, bram_ptr, chip, address) - // [2963] printf_uchar::uvalue#5 = display_action_text_flashing::bram_bank#3 -- vbum1=vbum2 + // [2196] printf_uchar::uvalue#5 = display_action_text_flashing::bram_bank#0 -- vbum1=vbum2 lda bram_bank sta printf_uchar.uvalue - // [2964] call printf_uchar - // [1346] phi from display_action_text_flashing::@4 to printf_uchar [phi:display_action_text_flashing::@4->printf_uchar] - // [1346] phi printf_uchar::format_zero_padding#18 = 1 [phi:display_action_text_flashing::@4->printf_uchar#0] -- vbum1=vbuc1 + // [2197] call printf_uchar + // [834] phi from display_action_text_flashing::@4 to printf_uchar [phi:display_action_text_flashing::@4->printf_uchar] + // [834] phi printf_uchar::format_zero_padding#10 = 1 [phi:display_action_text_flashing::@4->printf_uchar#0] -- vbum1=vbuc1 lda #1 sta printf_uchar.format_zero_padding - // [1346] phi printf_uchar::format_min_length#18 = 2 [phi:display_action_text_flashing::@4->printf_uchar#1] -- vbum1=vbuc1 + // [834] phi printf_uchar::format_min_length#10 = 2 [phi:display_action_text_flashing::@4->printf_uchar#1] -- vbum1=vbuc1 lda #2 sta printf_uchar.format_min_length - // [1346] phi printf_uchar::putc#18 = &snputc [phi:display_action_text_flashing::@4->printf_uchar#2] -- pprz1=pprc1 + // [834] phi printf_uchar::putc#10 = &snputc [phi:display_action_text_flashing::@4->printf_uchar#2] -- pprz1=pprc1 lda #snputc sta.z printf_uchar.putc+1 - // [1346] phi printf_uchar::format_radix#18 = HEXADECIMAL [phi:display_action_text_flashing::@4->printf_uchar#3] -- vbum1=vbuc1 + // [834] phi printf_uchar::format_radix#10 = HEXADECIMAL [phi:display_action_text_flashing::@4->printf_uchar#3] -- vbum1=vbuc1 lda #HEXADECIMAL sta printf_uchar.format_radix - // [1346] phi printf_uchar::uvalue#18 = printf_uchar::uvalue#5 [phi:display_action_text_flashing::@4->printf_uchar#4] -- register_copy + // [834] phi printf_uchar::uvalue#10 = printf_uchar::uvalue#5 [phi:display_action_text_flashing::@4->printf_uchar#4] -- register_copy jsr printf_uchar - // [2965] phi from display_action_text_flashing::@4 to display_action_text_flashing::@5 [phi:display_action_text_flashing::@4->display_action_text_flashing::@5] + // [2198] phi from display_action_text_flashing::@4 to display_action_text_flashing::@5 [phi:display_action_text_flashing::@4->display_action_text_flashing::@5] // display_action_text_flashing::@5 // sprintf(info_text, "Flashing %u bytes from RAM:%02x:%04p -> %s:%05x ... ", bytes, bram_bank, bram_ptr, chip, address) - // [2966] call printf_str - // [1210] phi from display_action_text_flashing::@5 to printf_str [phi:display_action_text_flashing::@5->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:display_action_text_flashing::@5->printf_str#0] -- pprz1=pprc1 + // [2199] call printf_str + // [785] phi from display_action_text_flashing::@5 to printf_str [phi:display_action_text_flashing::@5->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:display_action_text_flashing::@5->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s2 [phi:display_action_text_flashing::@5->printf_str#1] -- pbuz1=pbuc1 + // [785] phi printf_str::s#53 = s2 [phi:display_action_text_flashing::@5->printf_str#1] -- pbuz1=pbuc1 lda #s2 @@ -19935,77 +13931,77 @@ display_action_text_flashing: { jsr printf_str // display_action_text_flashing::@6 // sprintf(info_text, "Flashing %u bytes from RAM:%02x:%04p -> %s:%05x ... ", bytes, bram_bank, bram_ptr, chip, address) - // [2967] printf_uint::uvalue#2 = (unsigned int)display_action_text_flashing::bram_ptr#3 -- vwum1=vwuz2 + // [2200] printf_uint::uvalue#2 = (unsigned int)display_action_text_flashing::bram_ptr#0 -- vwum1=vwuz2 lda.z bram_ptr sta printf_uint.uvalue lda.z bram_ptr+1 sta printf_uint.uvalue+1 - // [2968] call printf_uint - // [2086] phi from display_action_text_flashing::@6 to printf_uint [phi:display_action_text_flashing::@6->printf_uint] - // [2086] phi printf_uint::format_zero_padding#10 = 1 [phi:display_action_text_flashing::@6->printf_uint#0] -- vbum1=vbuc1 + // [2201] call printf_uint + // [1433] phi from display_action_text_flashing::@6 to printf_uint [phi:display_action_text_flashing::@6->printf_uint] + // [1433] phi printf_uint::format_zero_padding#4 = 1 [phi:display_action_text_flashing::@6->printf_uint#0] -- vbum1=vbuc1 lda #1 sta printf_uint.format_zero_padding - // [2086] phi printf_uint::format_min_length#10 = 4 [phi:display_action_text_flashing::@6->printf_uint#1] -- vbum1=vbuc1 + // [1433] phi printf_uint::format_min_length#4 = 4 [phi:display_action_text_flashing::@6->printf_uint#1] -- vbum1=vbuc1 lda #4 sta printf_uint.format_min_length - // [2086] phi printf_uint::putc#10 = &snputc [phi:display_action_text_flashing::@6->printf_uint#2] -- pprz1=pprc1 + // [1433] phi printf_uint::putc#4 = &snputc [phi:display_action_text_flashing::@6->printf_uint#2] -- pprz1=pprc1 lda #snputc sta.z printf_uint.putc+1 - // [2086] phi printf_uint::format_radix#10 = HEXADECIMAL [phi:display_action_text_flashing::@6->printf_uint#3] -- vbum1=vbuc1 + // [1433] phi printf_uint::format_radix#4 = HEXADECIMAL [phi:display_action_text_flashing::@6->printf_uint#3] -- vbum1=vbuc1 lda #HEXADECIMAL sta printf_uint.format_radix - // [2086] phi printf_uint::uvalue#10 = printf_uint::uvalue#2 [phi:display_action_text_flashing::@6->printf_uint#4] -- register_copy + // [1433] phi printf_uint::uvalue#4 = printf_uint::uvalue#2 [phi:display_action_text_flashing::@6->printf_uint#4] -- register_copy jsr printf_uint - // [2969] phi from display_action_text_flashing::@6 to display_action_text_flashing::@7 [phi:display_action_text_flashing::@6->display_action_text_flashing::@7] + // [2202] phi from display_action_text_flashing::@6 to display_action_text_flashing::@7 [phi:display_action_text_flashing::@6->display_action_text_flashing::@7] // display_action_text_flashing::@7 // sprintf(info_text, "Flashing %u bytes from RAM:%02x:%04p -> %s:%05x ... ", bytes, bram_bank, bram_ptr, chip, address) - // [2970] call printf_str - // [1210] phi from display_action_text_flashing::@7 to printf_str [phi:display_action_text_flashing::@7->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:display_action_text_flashing::@7->printf_str#0] -- pprz1=pprc1 + // [2203] call printf_str + // [785] phi from display_action_text_flashing::@7 to printf_str [phi:display_action_text_flashing::@7->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:display_action_text_flashing::@7->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = display_action_text_flashing::s3 [phi:display_action_text_flashing::@7->printf_str#1] -- pbuz1=pbuc1 + // [785] phi printf_str::s#53 = display_action_text_flashing::s3 [phi:display_action_text_flashing::@7->printf_str#1] -- pbuz1=pbuc1 lda #s3 sta.z printf_str.s+1 jsr printf_str + // [2204] phi from display_action_text_flashing::@7 to display_action_text_flashing::@8 [phi:display_action_text_flashing::@7->display_action_text_flashing::@8] // display_action_text_flashing::@8 // sprintf(info_text, "Flashing %u bytes from RAM:%02x:%04p -> %s:%05x ... ", bytes, bram_bank, bram_ptr, chip, address) - // [2971] printf_string::str#12 = display_action_text_flashing::chip#10 -- pbuz1=pbuz2 - lda.z chip - sta.z printf_string.str - lda.z chip+1 - sta.z printf_string.str+1 - // [2972] call printf_string - // [1219] phi from display_action_text_flashing::@8 to printf_string [phi:display_action_text_flashing::@8->printf_string] - // [1219] phi printf_string::putc#26 = &snputc [phi:display_action_text_flashing::@8->printf_string#0] -- pprz1=pprc1 + // [2205] call printf_string + // [1308] phi from display_action_text_flashing::@8 to printf_string [phi:display_action_text_flashing::@8->printf_string] + // [1308] phi printf_string::putc#17 = &snputc [phi:display_action_text_flashing::@8->printf_string#0] -- pprz1=pprc1 lda #snputc sta.z printf_string.putc+1 - // [1219] phi printf_string::str#26 = printf_string::str#12 [phi:display_action_text_flashing::@8->printf_string#1] -- register_copy - // [1219] phi printf_string::format_justify_left#26 = 0 [phi:display_action_text_flashing::@8->printf_string#2] -- vbum1=vbuc1 + // [1308] phi printf_string::str#17 = vera_flash::chip [phi:display_action_text_flashing::@8->printf_string#1] -- pbuz1=pbuc1 + lda #vera_flash.chip + sta.z printf_string.str+1 + // [1308] phi printf_string::format_justify_left#17 = 0 [phi:display_action_text_flashing::@8->printf_string#2] -- vbum1=vbuc1 lda #0 sta printf_string.format_justify_left - // [1219] phi printf_string::format_min_length#26 = 0 [phi:display_action_text_flashing::@8->printf_string#3] -- vbum1=vbuc1 + // [1308] phi printf_string::format_min_length#17 = 0 [phi:display_action_text_flashing::@8->printf_string#3] -- vbum1=vbuc1 sta printf_string.format_min_length jsr printf_string - // [2973] phi from display_action_text_flashing::@8 to display_action_text_flashing::@9 [phi:display_action_text_flashing::@8->display_action_text_flashing::@9] + // [2206] phi from display_action_text_flashing::@8 to display_action_text_flashing::@9 [phi:display_action_text_flashing::@8->display_action_text_flashing::@9] // display_action_text_flashing::@9 // sprintf(info_text, "Flashing %u bytes from RAM:%02x:%04p -> %s:%05x ... ", bytes, bram_bank, bram_ptr, chip, address) - // [2974] call printf_str - // [1210] phi from display_action_text_flashing::@9 to printf_str [phi:display_action_text_flashing::@9->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:display_action_text_flashing::@9->printf_str#0] -- pprz1=pprc1 + // [2207] call printf_str + // [785] phi from display_action_text_flashing::@9 to printf_str [phi:display_action_text_flashing::@9->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:display_action_text_flashing::@9->printf_str#0] -- pprz1=pprc1 lda #snputc sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s2 [phi:display_action_text_flashing::@9->printf_str#1] -- pbuz1=pbuc1 + // [785] phi printf_str::s#53 = s2 [phi:display_action_text_flashing::@9->printf_str#1] -- pbuz1=pbuc1 lda #s2 @@ -20013,7 +14009,7 @@ display_action_text_flashing: { jsr printf_str // display_action_text_flashing::@10 // sprintf(info_text, "Flashing %u bytes from RAM:%02x:%04p -> %s:%05x ... ", bytes, bram_bank, bram_ptr, chip, address) - // [2975] printf_ulong::uvalue#3 = display_action_text_flashing::address#10 -- vdum1=vdum2 + // [2208] printf_ulong::uvalue#3 = display_action_text_flashing::address#0 -- vdum1=vdum2 lda address sta printf_ulong.uvalue lda address+1 @@ -20022,1672 +14018,359 @@ display_action_text_flashing: { sta printf_ulong.uvalue+2 lda address+3 sta printf_ulong.uvalue+3 - // [2976] call printf_ulong - // [1741] phi from display_action_text_flashing::@10 to printf_ulong [phi:display_action_text_flashing::@10->printf_ulong] - // [1741] phi printf_ulong::format_zero_padding#15 = 1 [phi:display_action_text_flashing::@10->printf_ulong#0] -- vbum1=vbuc1 + // [2209] call printf_ulong + // [1633] phi from display_action_text_flashing::@10 to printf_ulong [phi:display_action_text_flashing::@10->printf_ulong] + // [1633] phi printf_ulong::format_zero_padding#10 = 1 [phi:display_action_text_flashing::@10->printf_ulong#0] -- vbum1=vbuc1 lda #1 sta printf_ulong.format_zero_padding - // [1741] phi printf_ulong::format_min_length#15 = 5 [phi:display_action_text_flashing::@10->printf_ulong#1] -- vbum1=vbuc1 + // [1633] phi printf_ulong::format_min_length#10 = 5 [phi:display_action_text_flashing::@10->printf_ulong#1] -- vbum1=vbuc1 lda #5 sta printf_ulong.format_min_length - // [1741] phi printf_ulong::format_radix#15 = HEXADECIMAL [phi:display_action_text_flashing::@10->printf_ulong#2] -- vbum1=vbuc1 + // [1633] phi printf_ulong::format_radix#10 = HEXADECIMAL [phi:display_action_text_flashing::@10->printf_ulong#2] -- vbum1=vbuc1 lda #HEXADECIMAL sta printf_ulong.format_radix - // [1741] phi printf_ulong::uvalue#15 = printf_ulong::uvalue#3 [phi:display_action_text_flashing::@10->printf_ulong#3] -- register_copy + // [1633] phi printf_ulong::uvalue#10 = printf_ulong::uvalue#3 [phi:display_action_text_flashing::@10->printf_ulong#3] -- register_copy jsr printf_ulong - // [2977] phi from display_action_text_flashing::@10 to display_action_text_flashing::@11 [phi:display_action_text_flashing::@10->display_action_text_flashing::@11] + // [2210] phi from display_action_text_flashing::@10 to display_action_text_flashing::@11 [phi:display_action_text_flashing::@10->display_action_text_flashing::@11] // display_action_text_flashing::@11 // sprintf(info_text, "Flashing %u bytes from RAM:%02x:%04p -> %s:%05x ... ", bytes, bram_bank, bram_ptr, chip, address) - // [2978] call printf_str - // [1210] phi from display_action_text_flashing::@11 to printf_str [phi:display_action_text_flashing::@11->printf_str] - // [1210] phi printf_str::putc#84 = &snputc [phi:display_action_text_flashing::@11->printf_str#0] -- pprz1=pprc1 + // [2211] call printf_str + // [785] phi from display_action_text_flashing::@11 to printf_str [phi:display_action_text_flashing::@11->printf_str] + // [785] phi printf_str::putc#53 = &snputc [phi:display_action_text_flashing::@11->printf_str#0] -- pprz1=pprc1 lda #snputc - sta.z printf_str.putc+1 - // [1210] phi printf_str::s#84 = s5 [phi:display_action_text_flashing::@11->printf_str#1] -- pbuz1=pbuc1 - lda #s5 - sta.z printf_str.s+1 - jsr printf_str - // display_action_text_flashing::@12 - // sprintf(info_text, "Flashing %u bytes from RAM:%02x:%04p -> %s:%05x ... ", bytes, bram_bank, bram_ptr, chip, address) - // [2979] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 - lda #0 - pha - // [2980] callexecute snputc -- call_vprc1 - jsr snputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // display_action_text(info_text) - // [2982] call display_action_text - // [1357] phi from display_action_text_flashing::@12 to display_action_text [phi:display_action_text_flashing::@12->display_action_text] - // [1357] phi display_action_text::info_text#25 = info_text [phi:display_action_text_flashing::@12->display_action_text#0] -- pbuz1=pbuc1 - lda #info_text - sta.z display_action_text.info_text+1 - jsr display_action_text - // display_action_text_flashing::@return - // } - // [2983] return - rts - .segment Data - s: .text "Flashing " - .byte 0 - s1: .text " bytes from RAM:" - .byte 0 - s3: .text " -> " - .byte 0 - bram_bank: .byte 0 - address: .dword 0 - bytes: .dword 0 -} -.segment Code - // rom_write -/* inline */ -// unsigned long rom_write(__mem() char flash_ram_bank, __zp($54) char *flash_ram_address, __mem() unsigned long flash_rom_address, unsigned int flash_rom_size) -rom_write: { - .label flash_ram_address = $54 - // unsigned long rom_chip_address = flash_rom_address & ROM_CHIP_MASK - // [2984] rom_write::rom_chip_address#0 = rom_write::flash_rom_address#1 & $380000 -- vdum1=vdum2_band_vduc1 - /// Holds the amount of bytes actually flashed in the ROM. - lda flash_rom_address - and #<$380000 - sta rom_chip_address - lda flash_rom_address+1 - and #>$380000 - sta rom_chip_address+1 - lda flash_rom_address+2 - and #<$380000>>$10 - sta rom_chip_address+2 - lda flash_rom_address+3 - and #>$380000>>$10 - sta rom_chip_address+3 - // rom_write::bank_set_bram1 - // BRAM = bank - // [2985] BRAM = rom_write::flash_ram_bank#0 -- vbuz1=vbum2 - lda flash_ram_bank - sta.z BRAM - // [2986] phi from rom_write::bank_set_bram1 to rom_write::@1 [phi:rom_write::bank_set_bram1->rom_write::@1] - // [2986] phi rom_write::flash_ram_address#2 = rom_write::flash_ram_address#1 [phi:rom_write::bank_set_bram1->rom_write::@1#0] -- register_copy - // [2986] phi rom_write::flash_rom_address#3 = rom_write::flash_rom_address#1 [phi:rom_write::bank_set_bram1->rom_write::@1#1] -- register_copy - // [2986] phi rom_write::flashed_bytes#2 = 0 [phi:rom_write::bank_set_bram1->rom_write::@1#2] -- vdum1=vduc1 - lda #<0 - sta flashed_bytes - sta flashed_bytes+1 - lda #<0>>$10 - sta flashed_bytes+2 - lda #>0>>$10 - sta flashed_bytes+3 - // rom_write::@1 - __b1: - // while (flashed_bytes < flash_rom_size) - // [2987] if(rom_write::flashed_bytes#2ROM_PROGRESS_CELL>>$10 - bcc __b2 - bne !+ - lda flashed_bytes+2 - cmp #>$10 - bcc __b2 - bne !+ - lda flashed_bytes+1 - cmp #>ROM_PROGRESS_CELL - bcc __b2 - bne !+ - lda flashed_bytes - cmp #$5555 - sta rom_unlock.address+1 - lda rom_chip_address+2 - adc #0 - sta rom_unlock.address+2 - lda rom_chip_address+3 - adc #0 - sta rom_unlock.address+3 - // [2990] call rom_unlock - // [2394] phi from rom_write::@2 to rom_unlock [phi:rom_write::@2->rom_unlock] - // [2394] phi rom_unlock::unlock_code#5 = $a0 [phi:rom_write::@2->rom_unlock#0] -- vbum1=vbuc1 - lda #$a0 - sta rom_unlock.unlock_code - // [2394] phi rom_unlock::address#5 = rom_unlock::address#4 [phi:rom_write::@2->rom_unlock#1] -- register_copy - jsr rom_unlock - // rom_write::@3 - // rom_byte_program(flash_rom_address, *flash_ram_address) - // [2991] rom_byte_program::address#0 = rom_write::flash_rom_address#3 -- vdum1=vdum2 - lda flash_rom_address - sta rom_byte_program.address - lda flash_rom_address+1 - sta rom_byte_program.address+1 - lda flash_rom_address+2 - sta rom_byte_program.address+2 - lda flash_rom_address+3 - sta rom_byte_program.address+3 - // [2992] rom_byte_program::value#0 = *rom_write::flash_ram_address#2 -- vbum1=_deref_pbuz2 - ldy #0 - lda (flash_ram_address),y - sta rom_byte_program.value - // [2993] call rom_byte_program - // [3354] phi from rom_write::@3 to rom_byte_program [phi:rom_write::@3->rom_byte_program] - jsr rom_byte_program - // rom_write::@4 - // flash_rom_address++; - // [2994] rom_write::flash_rom_address#0 = ++ rom_write::flash_rom_address#3 -- vdum1=_inc_vdum1 - inc flash_rom_address - bne !+ - inc flash_rom_address+1 - bne !+ - inc flash_rom_address+2 - bne !+ - inc flash_rom_address+3 - !: - // flash_ram_address++; - // [2995] rom_write::flash_ram_address#0 = ++ rom_write::flash_ram_address#2 -- pbuz1=_inc_pbuz1 - inc.z flash_ram_address - bne !+ - inc.z flash_ram_address+1 - !: - // flashed_bytes++; - // [2996] rom_write::flashed_bytes#1 = ++ rom_write::flashed_bytes#2 -- vdum1=_inc_vdum1 - inc flashed_bytes - bne !+ - inc flashed_bytes+1 - bne !+ - inc flashed_bytes+2 - bne !+ - inc flashed_bytes+3 - !: - // [2986] phi from rom_write::@4 to rom_write::@1 [phi:rom_write::@4->rom_write::@1] - // [2986] phi rom_write::flash_ram_address#2 = rom_write::flash_ram_address#0 [phi:rom_write::@4->rom_write::@1#0] -- register_copy - // [2986] phi rom_write::flash_rom_address#3 = rom_write::flash_rom_address#0 [phi:rom_write::@4->rom_write::@1#1] -- register_copy - // [2986] phi rom_write::flashed_bytes#2 = rom_write::flashed_bytes#1 [phi:rom_write::@4->rom_write::@1#2] -- register_copy - jmp __b1 - .segment Data - rom_chip_address: .dword 0 - flash_rom_address: .dword 0 - flashed_bytes: .dword 0 - flash_ram_bank: .byte 0 -} -.segment Code - // cbm_k_getin -/** - * @brief Scan a character from keyboard without pressing enter. - * - * @return char The character read. - */ -cbm_k_getin: { - // __mem unsigned char ch - // [2997] cbm_k_getin::ch = 0 -- vbum1=vbuc1 - lda #0 - sta ch - // asm - // asm { jsrCBM_GETIN stach } - jsr CBM_GETIN - sta ch - // return ch; - // [2999] cbm_k_getin::return#0 = cbm_k_getin::ch -- vbum1=vbum2 - sta return - // cbm_k_getin::@return - // } - // [3000] cbm_k_getin::return#1 = cbm_k_getin::return#0 - // [3001] return - rts - .segment Data - ch: .byte 0 - return: .byte 0 -} -.segment Code - // strncpy -/// Copies up to n characters from the string pointed to, by src to dst. -/// In a case where the length of src is less than that of n, the remainder of dst will be padded with null bytes. -/// @param dst ? This is the pointer to the destination array where the content is to be copied. -/// @param src ? This is the string to be copied. -/// @param n ? The number of characters to be copied from source. -/// @return The destination -// char * strncpy(__zp($47) char *dst, __zp($3f) const char *src, __mem() unsigned int n) -strncpy: { - .label dst = $47 - .label src = $3f - // [3003] phi from strncpy to strncpy::@1 [phi:strncpy->strncpy::@1] - // [3003] phi strncpy::dst#3 = strncpy::dst#8 [phi:strncpy->strncpy::@1#0] -- register_copy - // [3003] phi strncpy::src#3 = strncpy::src#6 [phi:strncpy->strncpy::@1#1] -- register_copy - // [3003] phi strncpy::i#2 = 0 [phi:strncpy->strncpy::@1#2] -- vwum1=vwuc1 - lda #<0 - sta i - sta i+1 - // strncpy::@1 - __b1: - // for(size_t i = 0;istrncpy::@3] - // [3009] phi strncpy::src#7 = strncpy::src#3 [phi:strncpy::@2/strncpy::@4->strncpy::@3#0] -- register_copy - // strncpy::@3 - __b3: - // *dst++ = c - // [3010] *strncpy::dst#3 = strncpy::c#0 -- _deref_pbuz1=vbum2 - lda c - ldy #0 - sta (dst),y - // *dst++ = c; - // [3011] strncpy::dst#0 = ++ strncpy::dst#3 -- pbuz1=_inc_pbuz1 - inc.z dst - bne !+ - inc.z dst+1 - !: - // for(size_t i = 0;istrncpy::@1] - // [3003] phi strncpy::dst#3 = strncpy::dst#0 [phi:strncpy::@3->strncpy::@1#0] -- register_copy - // [3003] phi strncpy::src#3 = strncpy::src#7 [phi:strncpy::@3->strncpy::@1#1] -- register_copy - // [3003] phi strncpy::i#2 = strncpy::i#1 [phi:strncpy::@3->strncpy::@1#2] -- register_copy - jmp __b1 - .segment Data - c: .byte 0 - i: .word 0 - n: .word 0 -} -.segment Code - // utoa -// Converts unsigned number value to a string representing it in RADIX format. -// If the leading digits are zero they are not included in the string. -// - value : The number to be converted to RADIX -// - buffer : receives the string representing the number and zero-termination. -// - radix : The radix to convert the number to (from the enum RADIX) -// void utoa(__mem() unsigned int value, __zp($3d) char *buffer, __mem() char radix) -utoa: { - .label utoa__4 = $3a - .label utoa__10 = $41 - .label utoa__11 = $42 - .label buffer = $3d - .label digit_values = $4e - // if(radix==DECIMAL) - // [3013] if(utoa::radix#0==DECIMAL) goto utoa::@1 -- vbum1_eq_vbuc1_then_la1 - lda #DECIMAL - cmp radix - beq __b2 - // utoa::@2 - // if(radix==HEXADECIMAL) - // [3014] if(utoa::radix#0==HEXADECIMAL) goto utoa::@1 -- vbum1_eq_vbuc1_then_la1 - lda #HEXADECIMAL - cmp radix - beq __b3 - // utoa::@3 - // if(radix==OCTAL) - // [3015] if(utoa::radix#0==OCTAL) goto utoa::@1 -- vbum1_eq_vbuc1_then_la1 - lda #OCTAL - cmp radix - beq __b4 - // utoa::@4 - // if(radix==BINARY) - // [3016] if(utoa::radix#0==BINARY) goto utoa::@1 -- vbum1_eq_vbuc1_then_la1 - lda #BINARY - cmp radix - beq __b5 - // utoa::@5 - // *buffer++ = 'e' - // [3017] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS) = 'e' -- _deref_pbuc1=vbuc2 - // Unknown radix - lda #'e' - sta printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS - // *buffer++ = 'r' - // [3018] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+1) = 'r' -- _deref_pbuc1=vbuc2 - lda #'r' - sta printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+1 - // [3019] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+2) = 'r' -- _deref_pbuc1=vbuc2 - sta printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+2 - // *buffer = 0 - // [3020] *((char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+3) = 0 -- _deref_pbuc1=vbuc2 - lda #0 - sta printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS+3 - // utoa::@return - // } - // [3021] return - rts - // [3022] phi from utoa to utoa::@1 [phi:utoa->utoa::@1] - __b2: - // [3022] phi utoa::digit_values#8 = RADIX_DECIMAL_VALUES [phi:utoa->utoa::@1#0] -- pwuz1=pwuc1 - lda #RADIX_DECIMAL_VALUES - sta.z digit_values+1 - // [3022] phi utoa::max_digits#7 = 5 [phi:utoa->utoa::@1#1] -- vbum1=vbuc1 - lda #5 - sta max_digits - jmp __b1 - // [3022] phi from utoa::@2 to utoa::@1 [phi:utoa::@2->utoa::@1] - __b3: - // [3022] phi utoa::digit_values#8 = RADIX_HEXADECIMAL_VALUES [phi:utoa::@2->utoa::@1#0] -- pwuz1=pwuc1 - lda #RADIX_HEXADECIMAL_VALUES - sta.z digit_values+1 - // [3022] phi utoa::max_digits#7 = 4 [phi:utoa::@2->utoa::@1#1] -- vbum1=vbuc1 - lda #4 - sta max_digits - jmp __b1 - // [3022] phi from utoa::@3 to utoa::@1 [phi:utoa::@3->utoa::@1] - __b4: - // [3022] phi utoa::digit_values#8 = RADIX_OCTAL_VALUES [phi:utoa::@3->utoa::@1#0] -- pwuz1=pwuc1 - lda #RADIX_OCTAL_VALUES - sta.z digit_values+1 - // [3022] phi utoa::max_digits#7 = 6 [phi:utoa::@3->utoa::@1#1] -- vbum1=vbuc1 - lda #6 - sta max_digits - jmp __b1 - // [3022] phi from utoa::@4 to utoa::@1 [phi:utoa::@4->utoa::@1] - __b5: - // [3022] phi utoa::digit_values#8 = RADIX_BINARY_VALUES [phi:utoa::@4->utoa::@1#0] -- pwuz1=pwuc1 - lda #RADIX_BINARY_VALUES - sta.z digit_values+1 - // [3022] phi utoa::max_digits#7 = $10 [phi:utoa::@4->utoa::@1#1] -- vbum1=vbuc1 - lda #$10 - sta max_digits - // utoa::@1 - __b1: - // [3023] phi from utoa::@1 to utoa::@6 [phi:utoa::@1->utoa::@6] - // [3023] phi utoa::buffer#11 = (char *)&printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS [phi:utoa::@1->utoa::@6#0] -- pbuz1=pbuc1 - lda #printf_buffer+OFFSET_STRUCT_PRINTF_BUFFER_NUMBER_DIGITS - sta.z buffer+1 - // [3023] phi utoa::started#2 = 0 [phi:utoa::@1->utoa::@6#1] -- vbum1=vbuc1 - lda #0 - sta started - // [3023] phi utoa::value#2 = utoa::value#1 [phi:utoa::@1->utoa::@6#2] -- register_copy - // [3023] phi utoa::digit#2 = 0 [phi:utoa::@1->utoa::@6#3] -- vbum1=vbuc1 - sta digit - // utoa::@6 - __b6: - // max_digits-1 - // [3024] utoa::$4 = utoa::max_digits#7 - 1 -- vbuz1=vbum2_minus_1 - ldx max_digits - dex - stx.z utoa__4 - // for( char digit=0; digit= digit_value) - // [3032] if(0!=utoa::started#2) goto utoa::@10 -- 0_neq_vbum1_then_la1 - lda started - bne __b10 - // utoa::@12 - // [3033] if(utoa::value#2>=utoa::digit_value#0) goto utoa::@10 -- vwum1_ge_vwum2_then_la1 - lda digit_value+1 - cmp value+1 - bne !+ - lda digit_value - cmp value - beq __b10 - !: - bcc __b10 - // [3034] phi from utoa::@12 to utoa::@9 [phi:utoa::@12->utoa::@9] - // [3034] phi utoa::buffer#14 = utoa::buffer#11 [phi:utoa::@12->utoa::@9#0] -- register_copy - // [3034] phi utoa::started#4 = utoa::started#2 [phi:utoa::@12->utoa::@9#1] -- register_copy - // [3034] phi utoa::value#6 = utoa::value#2 [phi:utoa::@12->utoa::@9#2] -- register_copy - // utoa::@9 - __b9: - // for( char digit=0; digitutoa::@6] - // [3023] phi utoa::buffer#11 = utoa::buffer#14 [phi:utoa::@9->utoa::@6#0] -- register_copy - // [3023] phi utoa::started#2 = utoa::started#4 [phi:utoa::@9->utoa::@6#1] -- register_copy - // [3023] phi utoa::value#2 = utoa::value#6 [phi:utoa::@9->utoa::@6#2] -- register_copy - // [3023] phi utoa::digit#2 = utoa::digit#1 [phi:utoa::@9->utoa::@6#3] -- register_copy - jmp __b6 - // utoa::@10 - __b10: - // utoa_append(buffer++, value, digit_value) - // [3036] utoa_append::buffer#0 = utoa::buffer#11 -- pbuz1=pbuz2 - lda.z buffer - sta.z utoa_append.buffer - lda.z buffer+1 - sta.z utoa_append.buffer+1 - // [3037] utoa_append::value#0 = utoa::value#2 - // [3038] utoa_append::sub#0 = utoa::digit_value#0 - // [3039] call utoa_append - // [3364] phi from utoa::@10 to utoa_append [phi:utoa::@10->utoa_append] - jsr utoa_append - // utoa_append(buffer++, value, digit_value) - // [3040] utoa_append::return#0 = utoa_append::value#2 - // utoa::@11 - // value = utoa_append(buffer++, value, digit_value) - // [3041] utoa::value#0 = utoa_append::return#0 - // value = utoa_append(buffer++, value, digit_value); - // [3042] utoa::buffer#4 = ++ utoa::buffer#11 -- pbuz1=_inc_pbuz1 - inc.z buffer - bne !+ - inc.z buffer+1 - !: - // [3034] phi from utoa::@11 to utoa::@9 [phi:utoa::@11->utoa::@9] - // [3034] phi utoa::buffer#14 = utoa::buffer#4 [phi:utoa::@11->utoa::@9#0] -- register_copy - // [3034] phi utoa::started#4 = 1 [phi:utoa::@11->utoa::@9#1] -- vbum1=vbuc1 - lda #1 - sta started - // [3034] phi utoa::value#6 = utoa::value#0 [phi:utoa::@11->utoa::@9#2] -- register_copy - jmp __b9 - .segment Data - digit_value: .word 0 - digit: .byte 0 - .label value = smc_detect.return - .label radix = printf_uint.format_radix - started: .byte 0 - max_digits: .byte 0 -} -.segment Code - // insertup -// Insert a new line, and scroll the upper part of the screen up. -// void insertup(char rows) -insertup: { - .label insertup__0 = $36 - .label insertup__4 = $2a - .label insertup__6 = $2c - .label insertup__7 = $2a - // __conio.width+1 - // [3043] insertup::$0 = *((char *)&__conio+6) + 1 -- vbuz1=_deref_pbuc1_plus_1 - lda __conio+6 - inc - sta.z insertup__0 - // unsigned char width = (__conio.width+1) * 2 - // [3044] insertup::width#0 = insertup::$0 << 1 -- vbum1=vbuz2_rol_1 - // {asm{.byte $db}} - asl - sta width - // [3045] phi from insertup to insertup::@1 [phi:insertup->insertup::@1] - // [3045] phi insertup::y#2 = 0 [phi:insertup->insertup::@1#0] -- vbum1=vbuc1 - lda #0 - sta y - // insertup::@1 - __b1: - // for(unsigned char y=0; y<__conio.cursor_y; y++) - // [3046] if(insertup::y#2<*((char *)&__conio+1)) goto insertup::@2 -- vbum1_lt__deref_pbuc1_then_la1 - lda y - cmp __conio+1 - bcc __b2 - // [3047] phi from insertup::@1 to insertup::@3 [phi:insertup::@1->insertup::@3] - // insertup::@3 - // clearline() - // [3048] call clearline - jsr clearline - // insertup::@return - // } - // [3049] return - rts - // insertup::@2 - __b2: - // y+1 - // [3050] insertup::$4 = insertup::y#2 + 1 -- vbuz1=vbum2_plus_1 - lda y - inc - sta.z insertup__4 - // memcpy8_vram_vram(__conio.mapbase_bank, __conio.offsets[y], __conio.mapbase_bank, __conio.offsets[y+1], width) - // [3051] insertup::$6 = insertup::y#2 << 1 -- vbuz1=vbum2_rol_1 - lda y - asl - sta.z insertup__6 - // [3052] insertup::$7 = insertup::$4 << 1 -- vbuz1=vbuz1_rol_1 - asl.z insertup__7 - // [3053] memcpy8_vram_vram::dbank_vram#0 = *((char *)&__conio+5) -- vbum1=_deref_pbuc1 - lda __conio+5 - sta memcpy8_vram_vram.dbank_vram - // [3054] memcpy8_vram_vram::doffset_vram#0 = ((unsigned int *)&__conio+$15)[insertup::$6] -- vwum1=pwuc1_derefidx_vbuz2 - ldy.z insertup__6 - lda __conio+$15,y - sta memcpy8_vram_vram.doffset_vram - lda __conio+$15+1,y - sta memcpy8_vram_vram.doffset_vram+1 - // [3055] memcpy8_vram_vram::sbank_vram#0 = *((char *)&__conio+5) -- vbum1=_deref_pbuc1 - lda __conio+5 - sta memcpy8_vram_vram.sbank_vram - // [3056] memcpy8_vram_vram::soffset_vram#0 = ((unsigned int *)&__conio+$15)[insertup::$7] -- vwum1=pwuc1_derefidx_vbuz2 - ldy.z insertup__7 - lda __conio+$15,y - sta memcpy8_vram_vram.soffset_vram - lda __conio+$15+1,y - sta memcpy8_vram_vram.soffset_vram+1 - // [3057] memcpy8_vram_vram::num8#1 = insertup::width#0 -- vbum1=vbum2 - lda width - sta memcpy8_vram_vram.num8_1 - // [3058] call memcpy8_vram_vram - jsr memcpy8_vram_vram - // insertup::@4 - // for(unsigned char y=0; y<__conio.cursor_y; y++) - // [3059] insertup::y#1 = ++ insertup::y#2 -- vbum1=_inc_vbum1 - inc y - // [3045] phi from insertup::@4 to insertup::@1 [phi:insertup::@4->insertup::@1] - // [3045] phi insertup::y#2 = insertup::y#1 [phi:insertup::@4->insertup::@1#0] -- register_copy - jmp __b1 - .segment Data - width: .byte 0 - y: .byte 0 -} -.segment Code - // clearline -clearline: { - .label clearline__0 = $24 - .label clearline__1 = $25 - .label clearline__2 = $26 - .label clearline__3 = $23 - .label c = $22 - // unsigned int addr = __conio.offsets[__conio.cursor_y] - // [3060] clearline::$3 = *((char *)&__conio+1) << 1 -- vbuz1=_deref_pbuc1_rol_1 - lda __conio+1 - asl - sta.z clearline__3 - // [3061] clearline::addr#0 = ((unsigned int *)&__conio+$15)[clearline::$3] -- vwum1=pwuc1_derefidx_vbuz2 - tay - lda __conio+$15,y - sta addr - lda __conio+$15+1,y - sta addr+1 - // *VERA_CTRL &= ~VERA_ADDRSEL - // [3062] *VERA_CTRL = *VERA_CTRL & ~VERA_ADDRSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 - lda #VERA_ADDRSEL^$ff - and VERA_CTRL - sta VERA_CTRL - // BYTE0(addr) - // [3063] clearline::$0 = byte0 clearline::addr#0 -- vbuz1=_byte0_vwum2 - lda addr - sta.z clearline__0 - // *VERA_ADDRX_L = BYTE0(addr) - // [3064] *VERA_ADDRX_L = clearline::$0 -- _deref_pbuc1=vbuz1 - sta VERA_ADDRX_L - // BYTE1(addr) - // [3065] clearline::$1 = byte1 clearline::addr#0 -- vbuz1=_byte1_vwum2 - lda addr+1 - sta.z clearline__1 - // *VERA_ADDRX_M = BYTE1(addr) - // [3066] *VERA_ADDRX_M = clearline::$1 -- _deref_pbuc1=vbuz1 - sta VERA_ADDRX_M - // __conio.mapbase_bank | VERA_INC_1 - // [3067] clearline::$2 = *((char *)&__conio+5) | VERA_INC_1 -- vbuz1=_deref_pbuc1_bor_vbuc2 - lda #VERA_INC_1 - ora __conio+5 - sta.z clearline__2 - // *VERA_ADDRX_H = __conio.mapbase_bank | VERA_INC_1 - // [3068] *VERA_ADDRX_H = clearline::$2 -- _deref_pbuc1=vbuz1 - sta VERA_ADDRX_H - // register unsigned char c=__conio.width - // [3069] clearline::c#0 = *((char *)&__conio+6) -- vbuz1=_deref_pbuc1 - lda __conio+6 - sta.z c - // [3070] phi from clearline clearline::@1 to clearline::@1 [phi:clearline/clearline::@1->clearline::@1] - // [3070] phi clearline::c#2 = clearline::c#0 [phi:clearline/clearline::@1->clearline::@1#0] -- register_copy - // clearline::@1 - __b1: - // *VERA_DATA0 = ' ' - // [3071] *VERA_DATA0 = ' ' -- _deref_pbuc1=vbuc2 - lda #' ' - sta VERA_DATA0 - // *VERA_DATA0 = __conio.color - // [3072] *VERA_DATA0 = *((char *)&__conio+$d) -- _deref_pbuc1=_deref_pbuc2 - lda __conio+$d - sta VERA_DATA0 - // c--; - // [3073] clearline::c#1 = -- clearline::c#2 -- vbuz1=_dec_vbuz1 - dec.z c - // while(c) - // [3074] if(0!=clearline::c#1) goto clearline::@1 -- 0_neq_vbuz1_then_la1 - lda.z c - bne __b1 - // clearline::@return - // } - // [3075] return - rts - .segment Data - addr: .word 0 -} -.segment Code - // display_frame_maskxy -/** - * @brief - * - * @param x - * @param y - * @return unsigned char - */ -// __mem() char display_frame_maskxy(__mem() char x, __mem() char y) -display_frame_maskxy: { - .label cpeekcxy1_cpeekc1_display_frame_maskxy__0 = $42 - .label cpeekcxy1_cpeekc1_display_frame_maskxy__1 = $41 - .label cpeekcxy1_cpeekc1_display_frame_maskxy__2 = $3a - // display_frame_maskxy::cpeekcxy1 - // gotoxy(x,y) - // [3077] gotoxy::x#9 = display_frame_maskxy::cpeekcxy1_x#0 -- vbum1=vbum2 - lda cpeekcxy1_x - sta gotoxy.x - // [3078] gotoxy::y#9 = display_frame_maskxy::cpeekcxy1_y#0 -- vbum1=vbum2 - lda cpeekcxy1_y - sta gotoxy.y - // [3079] call gotoxy - // [802] phi from display_frame_maskxy::cpeekcxy1 to gotoxy [phi:display_frame_maskxy::cpeekcxy1->gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#9 [phi:display_frame_maskxy::cpeekcxy1->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = gotoxy::x#9 [phi:display_frame_maskxy::cpeekcxy1->gotoxy#1] -- register_copy - jsr gotoxy - // display_frame_maskxy::cpeekcxy1_cpeekc1 - // *VERA_CTRL &= ~VERA_ADDRSEL - // [3080] *VERA_CTRL = *VERA_CTRL & ~VERA_ADDRSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 - lda #VERA_ADDRSEL^$ff - and VERA_CTRL - sta VERA_CTRL - // BYTE0(__conio.offset) - // [3081] display_frame_maskxy::cpeekcxy1_cpeekc1_$0 = byte0 *((unsigned int *)&__conio+$13) -- vbuz1=_byte0__deref_pwuc1 - lda __conio+$13 - sta.z cpeekcxy1_cpeekc1_display_frame_maskxy__0 - // *VERA_ADDRX_L = BYTE0(__conio.offset) - // [3082] *VERA_ADDRX_L = display_frame_maskxy::cpeekcxy1_cpeekc1_$0 -- _deref_pbuc1=vbuz1 - sta VERA_ADDRX_L - // BYTE1(__conio.offset) - // [3083] display_frame_maskxy::cpeekcxy1_cpeekc1_$1 = byte1 *((unsigned int *)&__conio+$13) -- vbuz1=_byte1__deref_pwuc1 - lda __conio+$13+1 - sta.z cpeekcxy1_cpeekc1_display_frame_maskxy__1 - // *VERA_ADDRX_M = BYTE1(__conio.offset) - // [3084] *VERA_ADDRX_M = display_frame_maskxy::cpeekcxy1_cpeekc1_$1 -- _deref_pbuc1=vbuz1 - sta VERA_ADDRX_M - // __conio.mapbase_bank | VERA_INC_0 - // [3085] display_frame_maskxy::cpeekcxy1_cpeekc1_$2 = *((char *)&__conio+5) -- vbuz1=_deref_pbuc1 - lda __conio+5 - sta.z cpeekcxy1_cpeekc1_display_frame_maskxy__2 - // *VERA_ADDRX_H = __conio.mapbase_bank | VERA_INC_0 - // [3086] *VERA_ADDRX_H = display_frame_maskxy::cpeekcxy1_cpeekc1_$2 -- _deref_pbuc1=vbuz1 - sta VERA_ADDRX_H - // return *VERA_DATA0; - // [3087] display_frame_maskxy::c#0 = *VERA_DATA0 -- vbum1=_deref_pbuc1 - lda VERA_DATA0 - sta c - // display_frame_maskxy::@12 - // case 0x70: // DR corner. - // return 0b0110; - // [3088] if(display_frame_maskxy::c#0==$70) goto display_frame_maskxy::@return -- vbum1_eq_vbuc1_then_la1 - lda #$70 - cmp c - beq __b2 - // display_frame_maskxy::@1 - // case 0x6E: // DL corner. - // return 0b0011; - // [3089] if(display_frame_maskxy::c#0==$6e) goto display_frame_maskxy::@return -- vbum1_eq_vbuc1_then_la1 - lda #$6e - cmp c - beq __b1 - // display_frame_maskxy::@2 - // case 0x6D: // UR corner. - // return 0b1100; - // [3090] if(display_frame_maskxy::c#0==$6d) goto display_frame_maskxy::@return -- vbum1_eq_vbuc1_then_la1 - lda #$6d - cmp c - beq __b3 - // display_frame_maskxy::@3 - // case 0x7D: // UL corner. - // return 0b1001; - // [3091] if(display_frame_maskxy::c#0==$7d) goto display_frame_maskxy::@return -- vbum1_eq_vbuc1_then_la1 - lda #$7d - cmp c - beq __b4 - // display_frame_maskxy::@4 - // case 0x40: // HL line. - // return 0b0101; - // [3092] if(display_frame_maskxy::c#0==$40) goto display_frame_maskxy::@return -- vbum1_eq_vbuc1_then_la1 - lda #$40 - cmp c - beq __b5 - // display_frame_maskxy::@5 - // case 0x5D: // VL line. - // return 0b1010; - // [3093] if(display_frame_maskxy::c#0==$5d) goto display_frame_maskxy::@return -- vbum1_eq_vbuc1_then_la1 - lda #$5d - cmp c - beq __b6 - // display_frame_maskxy::@6 - // case 0x6B: // VR junction. - // return 0b1110; - // [3094] if(display_frame_maskxy::c#0==$6b) goto display_frame_maskxy::@return -- vbum1_eq_vbuc1_then_la1 - lda #$6b - cmp c - beq __b7 - // display_frame_maskxy::@7 - // case 0x73: // VL junction. - // return 0b1011; - // [3095] if(display_frame_maskxy::c#0==$73) goto display_frame_maskxy::@return -- vbum1_eq_vbuc1_then_la1 - lda #$73 - cmp c - beq __b8 - // display_frame_maskxy::@8 - // case 0x72: // HD junction. - // return 0b0111; - // [3096] if(display_frame_maskxy::c#0==$72) goto display_frame_maskxy::@return -- vbum1_eq_vbuc1_then_la1 - lda #$72 - cmp c - beq __b9 - // display_frame_maskxy::@9 - // case 0x71: // HU junction. - // return 0b1101; - // [3097] if(display_frame_maskxy::c#0==$71) goto display_frame_maskxy::@return -- vbum1_eq_vbuc1_then_la1 - lda #$71 - cmp c - beq __b10 - // display_frame_maskxy::@10 - // case 0x5B: // HV junction. - // return 0b1111; - // [3098] if(display_frame_maskxy::c#0==$5b) goto display_frame_maskxy::@11 -- vbum1_eq_vbuc1_then_la1 - lda #$5b - cmp c - beq __b11 - // [3100] phi from display_frame_maskxy::@10 to display_frame_maskxy::@return [phi:display_frame_maskxy::@10->display_frame_maskxy::@return] - // [3100] phi display_frame_maskxy::return#12 = 0 [phi:display_frame_maskxy::@10->display_frame_maskxy::@return#0] -- vbum1=vbuc1 - lda #0 - sta return - rts - // [3099] phi from display_frame_maskxy::@10 to display_frame_maskxy::@11 [phi:display_frame_maskxy::@10->display_frame_maskxy::@11] - // display_frame_maskxy::@11 - __b11: - // [3100] phi from display_frame_maskxy::@11 to display_frame_maskxy::@return [phi:display_frame_maskxy::@11->display_frame_maskxy::@return] - // [3100] phi display_frame_maskxy::return#12 = $f [phi:display_frame_maskxy::@11->display_frame_maskxy::@return#0] -- vbum1=vbuc1 - lda #$f - sta return - rts - // [3100] phi from display_frame_maskxy::@1 to display_frame_maskxy::@return [phi:display_frame_maskxy::@1->display_frame_maskxy::@return] - __b1: - // [3100] phi display_frame_maskxy::return#12 = 3 [phi:display_frame_maskxy::@1->display_frame_maskxy::@return#0] -- vbum1=vbuc1 - lda #3 - sta return - rts - // [3100] phi from display_frame_maskxy::@12 to display_frame_maskxy::@return [phi:display_frame_maskxy::@12->display_frame_maskxy::@return] - __b2: - // [3100] phi display_frame_maskxy::return#12 = 6 [phi:display_frame_maskxy::@12->display_frame_maskxy::@return#0] -- vbum1=vbuc1 - lda #6 - sta return - rts - // [3100] phi from display_frame_maskxy::@2 to display_frame_maskxy::@return [phi:display_frame_maskxy::@2->display_frame_maskxy::@return] - __b3: - // [3100] phi display_frame_maskxy::return#12 = $c [phi:display_frame_maskxy::@2->display_frame_maskxy::@return#0] -- vbum1=vbuc1 - lda #$c - sta return - rts - // [3100] phi from display_frame_maskxy::@3 to display_frame_maskxy::@return [phi:display_frame_maskxy::@3->display_frame_maskxy::@return] - __b4: - // [3100] phi display_frame_maskxy::return#12 = 9 [phi:display_frame_maskxy::@3->display_frame_maskxy::@return#0] -- vbum1=vbuc1 - lda #9 - sta return - rts - // [3100] phi from display_frame_maskxy::@4 to display_frame_maskxy::@return [phi:display_frame_maskxy::@4->display_frame_maskxy::@return] - __b5: - // [3100] phi display_frame_maskxy::return#12 = 5 [phi:display_frame_maskxy::@4->display_frame_maskxy::@return#0] -- vbum1=vbuc1 - lda #5 - sta return - rts - // [3100] phi from display_frame_maskxy::@5 to display_frame_maskxy::@return [phi:display_frame_maskxy::@5->display_frame_maskxy::@return] - __b6: - // [3100] phi display_frame_maskxy::return#12 = $a [phi:display_frame_maskxy::@5->display_frame_maskxy::@return#0] -- vbum1=vbuc1 - lda #$a - sta return - rts - // [3100] phi from display_frame_maskxy::@6 to display_frame_maskxy::@return [phi:display_frame_maskxy::@6->display_frame_maskxy::@return] - __b7: - // [3100] phi display_frame_maskxy::return#12 = $e [phi:display_frame_maskxy::@6->display_frame_maskxy::@return#0] -- vbum1=vbuc1 - lda #$e - sta return - rts - // [3100] phi from display_frame_maskxy::@7 to display_frame_maskxy::@return [phi:display_frame_maskxy::@7->display_frame_maskxy::@return] - __b8: - // [3100] phi display_frame_maskxy::return#12 = $b [phi:display_frame_maskxy::@7->display_frame_maskxy::@return#0] -- vbum1=vbuc1 - lda #$b - sta return - rts - // [3100] phi from display_frame_maskxy::@8 to display_frame_maskxy::@return [phi:display_frame_maskxy::@8->display_frame_maskxy::@return] - __b9: - // [3100] phi display_frame_maskxy::return#12 = 7 [phi:display_frame_maskxy::@8->display_frame_maskxy::@return#0] -- vbum1=vbuc1 - lda #7 - sta return - rts - // [3100] phi from display_frame_maskxy::@9 to display_frame_maskxy::@return [phi:display_frame_maskxy::@9->display_frame_maskxy::@return] - __b10: - // [3100] phi display_frame_maskxy::return#12 = $d [phi:display_frame_maskxy::@9->display_frame_maskxy::@return#0] -- vbum1=vbuc1 - lda #$d - sta return - // display_frame_maskxy::@return - // } - // [3101] return - rts - .segment Data - cpeekcxy1_x: .byte 0 - cpeekcxy1_y: .byte 0 - c: .byte 0 - // DR corner. - // DL corner. - // UR corner. - // UL corner. - // HL line. - // VL line. - // VR junction. - // VL junction. - // HD junction. - // HU junction. - // HV junction. - return: .byte 0 - .label x = cpeekcxy1_x - .label y = cpeekcxy1_y -} -.segment Code - // display_frame_char -/** - * @brief - * - * @param mask - * @return unsigned char - */ -// __mem() char display_frame_char(__mem() char mask) -display_frame_char: { - // case 0b0110: - // return 0x70; - // [3103] if(display_frame_char::mask#10==6) goto display_frame_char::@return -- vbum1_eq_vbuc1_then_la1 - lda #6 - cmp mask - beq __b1 - // display_frame_char::@1 - // case 0b0011: - // return 0x6E; - // [3104] if(display_frame_char::mask#10==3) goto display_frame_char::@return -- vbum1_eq_vbuc1_then_la1 - // DR corner. - lda #3 - cmp mask - beq __b2 - // display_frame_char::@2 - // case 0b1100: - // return 0x6D; - // [3105] if(display_frame_char::mask#10==$c) goto display_frame_char::@return -- vbum1_eq_vbuc1_then_la1 - // DL corner. - lda #$c - cmp mask - beq __b3 - // display_frame_char::@3 - // case 0b1001: - // return 0x7D; - // [3106] if(display_frame_char::mask#10==9) goto display_frame_char::@return -- vbum1_eq_vbuc1_then_la1 - // UR corner. - lda #9 - cmp mask - beq __b4 - // display_frame_char::@4 - // case 0b0101: - // return 0x40; - // [3107] if(display_frame_char::mask#10==5) goto display_frame_char::@return -- vbum1_eq_vbuc1_then_la1 - // UL corner. - lda #5 - cmp mask - beq __b5 - // display_frame_char::@5 - // case 0b1010: - // return 0x5D; - // [3108] if(display_frame_char::mask#10==$a) goto display_frame_char::@return -- vbum1_eq_vbuc1_then_la1 - // HL line. - lda #$a - cmp mask - beq __b6 - // display_frame_char::@6 - // case 0b1110: - // return 0x6B; - // [3109] if(display_frame_char::mask#10==$e) goto display_frame_char::@return -- vbum1_eq_vbuc1_then_la1 - // VL line. - lda #$e - cmp mask - beq __b7 - // display_frame_char::@7 - // case 0b1011: - // return 0x73; - // [3110] if(display_frame_char::mask#10==$b) goto display_frame_char::@return -- vbum1_eq_vbuc1_then_la1 - // VR junction. - lda #$b - cmp mask - beq __b8 - // display_frame_char::@8 - // case 0b0111: - // return 0x72; - // [3111] if(display_frame_char::mask#10==7) goto display_frame_char::@return -- vbum1_eq_vbuc1_then_la1 - // VL junction. - lda #7 - cmp mask - beq __b9 - // display_frame_char::@9 - // case 0b1101: - // return 0x71; - // [3112] if(display_frame_char::mask#10==$d) goto display_frame_char::@return -- vbum1_eq_vbuc1_then_la1 - // HD junction. - lda #$d - cmp mask - beq __b10 - // display_frame_char::@10 - // case 0b1111: - // return 0x5B; - // [3113] if(display_frame_char::mask#10==$f) goto display_frame_char::@11 -- vbum1_eq_vbuc1_then_la1 - // HU junction. - lda #$f - cmp mask - beq __b11 - // [3115] phi from display_frame_char::@10 to display_frame_char::@return [phi:display_frame_char::@10->display_frame_char::@return] - // [3115] phi display_frame_char::return#12 = $20 [phi:display_frame_char::@10->display_frame_char::@return#0] -- vbum1=vbuc1 - lda #$20 - sta return - rts - // [3114] phi from display_frame_char::@10 to display_frame_char::@11 [phi:display_frame_char::@10->display_frame_char::@11] - // display_frame_char::@11 - __b11: - // [3115] phi from display_frame_char::@11 to display_frame_char::@return [phi:display_frame_char::@11->display_frame_char::@return] - // [3115] phi display_frame_char::return#12 = $5b [phi:display_frame_char::@11->display_frame_char::@return#0] -- vbum1=vbuc1 - lda #$5b - sta return - rts - // [3115] phi from display_frame_char to display_frame_char::@return [phi:display_frame_char->display_frame_char::@return] - __b1: - // [3115] phi display_frame_char::return#12 = $70 [phi:display_frame_char->display_frame_char::@return#0] -- vbum1=vbuc1 - lda #$70 - sta return - rts - // [3115] phi from display_frame_char::@1 to display_frame_char::@return [phi:display_frame_char::@1->display_frame_char::@return] - __b2: - // [3115] phi display_frame_char::return#12 = $6e [phi:display_frame_char::@1->display_frame_char::@return#0] -- vbum1=vbuc1 - lda #$6e - sta return - rts - // [3115] phi from display_frame_char::@2 to display_frame_char::@return [phi:display_frame_char::@2->display_frame_char::@return] - __b3: - // [3115] phi display_frame_char::return#12 = $6d [phi:display_frame_char::@2->display_frame_char::@return#0] -- vbum1=vbuc1 - lda #$6d - sta return - rts - // [3115] phi from display_frame_char::@3 to display_frame_char::@return [phi:display_frame_char::@3->display_frame_char::@return] - __b4: - // [3115] phi display_frame_char::return#12 = $7d [phi:display_frame_char::@3->display_frame_char::@return#0] -- vbum1=vbuc1 - lda #$7d - sta return - rts - // [3115] phi from display_frame_char::@4 to display_frame_char::@return [phi:display_frame_char::@4->display_frame_char::@return] - __b5: - // [3115] phi display_frame_char::return#12 = $40 [phi:display_frame_char::@4->display_frame_char::@return#0] -- vbum1=vbuc1 - lda #$40 - sta return - rts - // [3115] phi from display_frame_char::@5 to display_frame_char::@return [phi:display_frame_char::@5->display_frame_char::@return] - __b6: - // [3115] phi display_frame_char::return#12 = $5d [phi:display_frame_char::@5->display_frame_char::@return#0] -- vbum1=vbuc1 - lda #$5d - sta return - rts - // [3115] phi from display_frame_char::@6 to display_frame_char::@return [phi:display_frame_char::@6->display_frame_char::@return] - __b7: - // [3115] phi display_frame_char::return#12 = $6b [phi:display_frame_char::@6->display_frame_char::@return#0] -- vbum1=vbuc1 - lda #$6b - sta return - rts - // [3115] phi from display_frame_char::@7 to display_frame_char::@return [phi:display_frame_char::@7->display_frame_char::@return] - __b8: - // [3115] phi display_frame_char::return#12 = $73 [phi:display_frame_char::@7->display_frame_char::@return#0] -- vbum1=vbuc1 - lda #$73 - sta return - rts - // [3115] phi from display_frame_char::@8 to display_frame_char::@return [phi:display_frame_char::@8->display_frame_char::@return] - __b9: - // [3115] phi display_frame_char::return#12 = $72 [phi:display_frame_char::@8->display_frame_char::@return#0] -- vbum1=vbuc1 - lda #$72 - sta return - rts - // [3115] phi from display_frame_char::@9 to display_frame_char::@return [phi:display_frame_char::@9->display_frame_char::@return] - __b10: - // [3115] phi display_frame_char::return#12 = $71 [phi:display_frame_char::@9->display_frame_char::@return#0] -- vbum1=vbuc1 - lda #$71 - sta return - // display_frame_char::@return + sta.z printf_str.putc + lda #>snputc + sta.z printf_str.putc+1 + // [785] phi printf_str::s#53 = s5 [phi:display_action_text_flashing::@11->printf_str#1] -- pbuz1=pbuc1 + lda #s5 + sta.z printf_str.s+1 + jsr printf_str + // display_action_text_flashing::@12 + // sprintf(info_text, "Flashing %u bytes from RAM:%02x:%04p -> %s:%05x ... ", bytes, bram_bank, bram_ptr, chip, address) + // [2212] stackpush(char) = 0 -- _stackpushbyte_=vbuc1 + lda #0 + pha + // [2213] callexecute snputc -- call_vprc1 + jsr snputc + // sideeffect stackpullpadding(1) -- _stackpullpadding_1 + pla + // display_action_text(info_text) + // [2215] call display_action_text + // [845] phi from display_action_text_flashing::@12 to display_action_text [phi:display_action_text_flashing::@12->display_action_text] + // [845] phi display_action_text::info_text#17 = info_text [phi:display_action_text_flashing::@12->display_action_text#0] -- pbuz1=pbuc1 + lda #info_text + sta.z display_action_text.info_text+1 + jsr display_action_text + // display_action_text_flashing::@return // } - // [3116] return + // [2216] return rts .segment Data - .label return = cputcxy.c - .label mask = display_frame_maskxy.return + s: .text "Flashing " + .byte 0 + s1: .text " bytes from RAM:" + .byte 0 + s3: .text " -> " + .byte 0 + bram_bank: .byte 0 + address: .dword 0 } -.segment Code - // display_chip_led -/** - * @brief Print the colored led of a chip figure. - * - * @param x Start X - * @param y Start Y - * @param w width - * @param tc Fore color - * @param bc Back color - */ -// void display_chip_led(__mem() char x, char y, __mem() char w, __mem() char tc, char bc) -display_chip_led: { - // textcolor(tc) - // [3118] textcolor::color#11 = display_chip_led::tc#3 -- vbum1=vbum2 - lda tc - sta textcolor.color - // [3119] call textcolor - // [784] phi from display_chip_led to textcolor [phi:display_chip_led->textcolor] - // [784] phi textcolor::color#23 = textcolor::color#11 [phi:display_chip_led->textcolor#0] -- register_copy - jsr textcolor - // [3120] phi from display_chip_led to display_chip_led::@3 [phi:display_chip_led->display_chip_led::@3] - // display_chip_led::@3 - // bgcolor(bc) - // [3121] call bgcolor - // [789] phi from display_chip_led::@3 to bgcolor [phi:display_chip_led::@3->bgcolor] - // [789] phi bgcolor::color#15 = BLUE [phi:display_chip_led::@3->bgcolor#0] -- vbum1=vbuc1 - lda #BLUE - sta bgcolor.color - jsr bgcolor - // [3122] phi from display_chip_led::@3 display_chip_led::@5 to display_chip_led::@1 [phi:display_chip_led::@3/display_chip_led::@5->display_chip_led::@1] - // [3122] phi display_chip_led::w#4 = display_chip_led::w#7 [phi:display_chip_led::@3/display_chip_led::@5->display_chip_led::@1#0] -- register_copy - // [3122] phi display_chip_led::x#4 = display_chip_led::x#7 [phi:display_chip_led::@3/display_chip_led::@5->display_chip_led::@1#1] -- register_copy - // display_chip_led::@1 - __b1: - // cputcxy(x, y, 0x6F) - // [3123] cputcxy::x#11 = display_chip_led::x#4 -- vbum1=vbum2 - lda x - sta cputcxy.x - // [3124] call cputcxy - // [2293] phi from display_chip_led::@1 to cputcxy [phi:display_chip_led::@1->cputcxy] - // [2293] phi cputcxy::c#17 = $6f [phi:display_chip_led::@1->cputcxy#0] -- vbum1=vbuc1 - lda #$6f - sta cputcxy.c - // [2293] phi cputcxy::y#17 = 3 [phi:display_chip_led::@1->cputcxy#1] -- vbum1=vbuc1 - lda #3 - sta cputcxy.y - // [2293] phi cputcxy::x#17 = cputcxy::x#11 [phi:display_chip_led::@1->cputcxy#2] -- register_copy - jsr cputcxy - // display_chip_led::@4 - // cputcxy(x, y+1, 0x77) - // [3125] cputcxy::x#12 = display_chip_led::x#4 -- vbum1=vbum2 - lda x - sta cputcxy.x - // [3126] call cputcxy - // [2293] phi from display_chip_led::@4 to cputcxy [phi:display_chip_led::@4->cputcxy] - // [2293] phi cputcxy::c#17 = $77 [phi:display_chip_led::@4->cputcxy#0] -- vbum1=vbuc1 - lda #$77 - sta cputcxy.c - // [2293] phi cputcxy::y#17 = 3+1 [phi:display_chip_led::@4->cputcxy#1] -- vbum1=vbuc1 - lda #3+1 - sta cputcxy.y - // [2293] phi cputcxy::x#17 = cputcxy::x#12 [phi:display_chip_led::@4->cputcxy#2] -- register_copy - jsr cputcxy - // display_chip_led::@5 - // x++; - // [3127] display_chip_led::x#0 = ++ display_chip_led::x#4 -- vbum1=_inc_vbum1 - inc x - // while(--w) - // [3128] display_chip_led::w#0 = -- display_chip_led::w#4 -- vbum1=_dec_vbum1 - dec w - // [3129] if(0!=display_chip_led::w#0) goto display_chip_led::@1 -- 0_neq_vbum1_then_la1 - lda w - bne __b1 - // [3130] phi from display_chip_led::@5 to display_chip_led::@2 [phi:display_chip_led::@5->display_chip_led::@2] - // display_chip_led::@2 - // textcolor(WHITE) - // [3131] call textcolor - // [784] phi from display_chip_led::@2 to textcolor [phi:display_chip_led::@2->textcolor] - // [784] phi textcolor::color#23 = WHITE [phi:display_chip_led::@2->textcolor#0] -- vbum1=vbuc1 - lda #WHITE - sta textcolor.color - jsr textcolor - // [3132] phi from display_chip_led::@2 to display_chip_led::@6 [phi:display_chip_led::@2->display_chip_led::@6] - // display_chip_led::@6 - // bgcolor(BLUE) - // [3133] call bgcolor - // [789] phi from display_chip_led::@6 to bgcolor [phi:display_chip_led::@6->bgcolor] - // [789] phi bgcolor::color#15 = BLUE [phi:display_chip_led::@6->bgcolor#0] -- vbum1=vbuc1 - lda #BLUE - sta bgcolor.color - jsr bgcolor - // display_chip_led::@return +.segment CodeVera + // spi_read +spi_read: { + // unsigned char SPIData + // [2217] spi_read::SPIData = 0 -- vbum1=vbuc1 + /* + .proc spi_read + stz Vera::Reg::SPIData +@1: bit Vera::Reg::SPICtrl + bmi @1 + lda Vera::Reg::SPIData + rts +.endproc +*/ + lda #0 + sta SPIData + // asm + // asm { stzvera_reg_SPIData !: bitvera_reg_SPICtrl bmi!- ldavera_reg_SPIData staSPIData } + stz vera_reg_SPIData + !: + bit vera_reg_SPICtrl + bmi !- + lda vera_reg_SPIData + sta SPIData + // return SPIData; + // [2219] spi_read::return#3 = spi_read::SPIData -- vbum1=vbum2 + sta return_3 + // spi_read::@return // } - // [3134] return + // [2220] spi_read::return#4 = spi_read::return#3 + // [2221] return rts - .segment Data - x: .byte 0 - w: .byte 0 - tc: .byte 0 + .segment DataVera + SPIData: .byte 0 + return: .byte 0 + return_1: .byte 0 + return_2: .byte 0 + return_3: .byte 0 } .segment Code - // display_chip_line + // memcpy8_vram_vram /** - * @brief Print one line of a chip figure. - * - * @param x Start X - * @param y Start Y - * @param w Width - * @param c Fore color + * @brief Copy a block of memory in VRAM from a source to a target destination. + * This function is designed to copy maximum 255 bytes of memory in one step. + * If more than 255 bytes need to be copied, use the memcpy_vram_vram function. + * + * @see memcpy_vram_vram + * + * @param dbank_vram Bank of the destination location in vram. + * @param doffset_vram Offset of the destination location in vram. + * @param sbank_vram Bank of the source location in vram. + * @param soffset_vram Offset of the source location in vram. + * @param num16 Specified the amount of bytes to be copied. */ -// void display_chip_line(__mem() char x, __mem() char y, __mem() char w, __mem() char c) -display_chip_line: { - // gotoxy(x, y) - // [3136] gotoxy::x#11 = display_chip_line::x#16 -- vbum1=vbum2 - lda x - sta gotoxy.x - // [3137] gotoxy::y#11 = display_chip_line::y#16 -- vbum1=vbum2 - lda y - sta gotoxy.y - // [3138] call gotoxy - // [802] phi from display_chip_line to gotoxy [phi:display_chip_line->gotoxy] - // [802] phi gotoxy::y#37 = gotoxy::y#11 [phi:display_chip_line->gotoxy#0] -- register_copy - // [802] phi gotoxy::x#37 = gotoxy::x#11 [phi:display_chip_line->gotoxy#1] -- register_copy - jsr gotoxy - // [3139] phi from display_chip_line to display_chip_line::@4 [phi:display_chip_line->display_chip_line::@4] - // display_chip_line::@4 - // textcolor(GREY) - // [3140] call textcolor - // [784] phi from display_chip_line::@4 to textcolor [phi:display_chip_line::@4->textcolor] - // [784] phi textcolor::color#23 = GREY [phi:display_chip_line::@4->textcolor#0] -- vbum1=vbuc1 - lda #GREY - sta textcolor.color - jsr textcolor - // [3141] phi from display_chip_line::@4 to display_chip_line::@5 [phi:display_chip_line::@4->display_chip_line::@5] - // display_chip_line::@5 - // bgcolor(BLUE) - // [3142] call bgcolor - // [789] phi from display_chip_line::@5 to bgcolor [phi:display_chip_line::@5->bgcolor] - // [789] phi bgcolor::color#15 = BLUE [phi:display_chip_line::@5->bgcolor#0] -- vbum1=vbuc1 - lda #BLUE - sta bgcolor.color - jsr bgcolor - // display_chip_line::@6 - // cputc(VERA_CHR_UR) - // [3143] stackpush(char) = $7c -- _stackpushbyte_=vbuc1 - lda #$7c - pha - // [3144] callexecute cputc -- call_vprc1 - jsr cputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // textcolor(WHITE) - // [3146] call textcolor - // [784] phi from display_chip_line::@6 to textcolor [phi:display_chip_line::@6->textcolor] - // [784] phi textcolor::color#23 = WHITE [phi:display_chip_line::@6->textcolor#0] -- vbum1=vbuc1 - lda #WHITE - sta textcolor.color - jsr textcolor - // [3147] phi from display_chip_line::@6 to display_chip_line::@7 [phi:display_chip_line::@6->display_chip_line::@7] - // display_chip_line::@7 - // bgcolor(BLACK) - // [3148] call bgcolor - // [789] phi from display_chip_line::@7 to bgcolor [phi:display_chip_line::@7->bgcolor] - // [789] phi bgcolor::color#15 = BLACK [phi:display_chip_line::@7->bgcolor#0] -- vbum1=vbuc1 - lda #BLACK - sta bgcolor.color - jsr bgcolor - // [3149] phi from display_chip_line::@7 to display_chip_line::@1 [phi:display_chip_line::@7->display_chip_line::@1] - // [3149] phi display_chip_line::i#2 = 0 [phi:display_chip_line::@7->display_chip_line::@1#0] -- vbum1=vbuc1 - lda #0 - sta i - // display_chip_line::@1 - __b1: - // for(char i=0; idisplay_chip_line::@3] - // display_chip_line::@3 - // textcolor(GREY) - // [3152] call textcolor - // [784] phi from display_chip_line::@3 to textcolor [phi:display_chip_line::@3->textcolor] - // [784] phi textcolor::color#23 = GREY [phi:display_chip_line::@3->textcolor#0] -- vbum1=vbuc1 - lda #GREY - sta textcolor.color - jsr textcolor - // [3153] phi from display_chip_line::@3 to display_chip_line::@8 [phi:display_chip_line::@3->display_chip_line::@8] - // display_chip_line::@8 - // bgcolor(BLUE) - // [3154] call bgcolor - // [789] phi from display_chip_line::@8 to bgcolor [phi:display_chip_line::@8->bgcolor] - // [789] phi bgcolor::color#15 = BLUE [phi:display_chip_line::@8->bgcolor#0] -- vbum1=vbuc1 - lda #BLUE - sta bgcolor.color - jsr bgcolor - // display_chip_line::@9 - // cputc(VERA_CHR_UL) - // [3155] stackpush(char) = $7e -- _stackpushbyte_=vbuc1 - lda #$7e - pha - // [3156] callexecute cputc -- call_vprc1 - jsr cputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // textcolor(WHITE) - // [3158] call textcolor - // [784] phi from display_chip_line::@9 to textcolor [phi:display_chip_line::@9->textcolor] - // [784] phi textcolor::color#23 = WHITE [phi:display_chip_line::@9->textcolor#0] -- vbum1=vbuc1 - lda #WHITE - sta textcolor.color - jsr textcolor - // [3159] phi from display_chip_line::@9 to display_chip_line::@10 [phi:display_chip_line::@9->display_chip_line::@10] - // display_chip_line::@10 - // bgcolor(BLACK) - // [3160] call bgcolor - // [789] phi from display_chip_line::@10 to bgcolor [phi:display_chip_line::@10->bgcolor] - // [789] phi bgcolor::color#15 = BLACK [phi:display_chip_line::@10->bgcolor#0] -- vbum1=vbuc1 - lda #BLACK - sta bgcolor.color - jsr bgcolor - // display_chip_line::@11 - // cputcxy(x+2, y, c) - // [3161] cputcxy::x#10 = display_chip_line::x#16 + 2 -- vbum1=vbum2_plus_2 - lda x - clc - adc #2 - sta cputcxy.x - // [3162] cputcxy::y#10 = display_chip_line::y#16 -- vbum1=vbum2 - lda y - sta cputcxy.y - // [3163] cputcxy::c#10 = display_chip_line::c#15 -- vbum1=vbum2 - lda c - sta cputcxy.c - // [3164] call cputcxy - // [2293] phi from display_chip_line::@11 to cputcxy [phi:display_chip_line::@11->cputcxy] - // [2293] phi cputcxy::c#17 = cputcxy::c#10 [phi:display_chip_line::@11->cputcxy#0] -- register_copy - // [2293] phi cputcxy::y#17 = cputcxy::y#10 [phi:display_chip_line::@11->cputcxy#1] -- register_copy - // [2293] phi cputcxy::x#17 = cputcxy::x#10 [phi:display_chip_line::@11->cputcxy#2] -- register_copy - jsr cputcxy - // display_chip_line::@return +// void memcpy8_vram_vram(__mem() char dbank_vram, __mem() unsigned int doffset_vram, __mem() char sbank_vram, __mem() unsigned int soffset_vram, __mem() char num8) +memcpy8_vram_vram: { + .label memcpy8_vram_vram__0 = $23 + .label memcpy8_vram_vram__1 = $24 + .label memcpy8_vram_vram__2 = $25 + .label memcpy8_vram_vram__3 = $26 + .label memcpy8_vram_vram__4 = $27 + .label memcpy8_vram_vram__5 = $28 + // *VERA_CTRL &= ~VERA_ADDRSEL + // [2222] *VERA_CTRL = *VERA_CTRL & ~VERA_ADDRSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 + lda #VERA_ADDRSEL^$ff + and VERA_CTRL + sta VERA_CTRL + // BYTE0(soffset_vram) + // [2223] memcpy8_vram_vram::$0 = byte0 memcpy8_vram_vram::soffset_vram#0 -- vbuz1=_byte0_vwum2 + lda soffset_vram + sta.z memcpy8_vram_vram__0 + // *VERA_ADDRX_L = BYTE0(soffset_vram) + // [2224] *VERA_ADDRX_L = memcpy8_vram_vram::$0 -- _deref_pbuc1=vbuz1 + sta VERA_ADDRX_L + // BYTE1(soffset_vram) + // [2225] memcpy8_vram_vram::$1 = byte1 memcpy8_vram_vram::soffset_vram#0 -- vbuz1=_byte1_vwum2 + lda soffset_vram+1 + sta.z memcpy8_vram_vram__1 + // *VERA_ADDRX_M = BYTE1(soffset_vram) + // [2226] *VERA_ADDRX_M = memcpy8_vram_vram::$1 -- _deref_pbuc1=vbuz1 + sta VERA_ADDRX_M + // sbank_vram | VERA_INC_1 + // [2227] memcpy8_vram_vram::$2 = memcpy8_vram_vram::sbank_vram#0 | VERA_INC_1 -- vbuz1=vbum2_bor_vbuc1 + lda #VERA_INC_1 + ora sbank_vram + sta.z memcpy8_vram_vram__2 + // *VERA_ADDRX_H = sbank_vram | VERA_INC_1 + // [2228] *VERA_ADDRX_H = memcpy8_vram_vram::$2 -- _deref_pbuc1=vbuz1 + sta VERA_ADDRX_H + // *VERA_CTRL |= VERA_ADDRSEL + // [2229] *VERA_CTRL = *VERA_CTRL | VERA_ADDRSEL -- _deref_pbuc1=_deref_pbuc1_bor_vbuc2 + lda #VERA_ADDRSEL + ora VERA_CTRL + sta VERA_CTRL + // BYTE0(doffset_vram) + // [2230] memcpy8_vram_vram::$3 = byte0 memcpy8_vram_vram::doffset_vram#0 -- vbuz1=_byte0_vwum2 + lda doffset_vram + sta.z memcpy8_vram_vram__3 + // *VERA_ADDRX_L = BYTE0(doffset_vram) + // [2231] *VERA_ADDRX_L = memcpy8_vram_vram::$3 -- _deref_pbuc1=vbuz1 + sta VERA_ADDRX_L + // BYTE1(doffset_vram) + // [2232] memcpy8_vram_vram::$4 = byte1 memcpy8_vram_vram::doffset_vram#0 -- vbuz1=_byte1_vwum2 + lda doffset_vram+1 + sta.z memcpy8_vram_vram__4 + // *VERA_ADDRX_M = BYTE1(doffset_vram) + // [2233] *VERA_ADDRX_M = memcpy8_vram_vram::$4 -- _deref_pbuc1=vbuz1 + sta VERA_ADDRX_M + // dbank_vram | VERA_INC_1 + // [2234] memcpy8_vram_vram::$5 = memcpy8_vram_vram::dbank_vram#0 | VERA_INC_1 -- vbuz1=vbum2_bor_vbuc1 + lda #VERA_INC_1 + ora dbank_vram + sta.z memcpy8_vram_vram__5 + // *VERA_ADDRX_H = dbank_vram | VERA_INC_1 + // [2235] *VERA_ADDRX_H = memcpy8_vram_vram::$5 -- _deref_pbuc1=vbuz1 + sta VERA_ADDRX_H + // [2236] phi from memcpy8_vram_vram memcpy8_vram_vram::@2 to memcpy8_vram_vram::@1 [phi:memcpy8_vram_vram/memcpy8_vram_vram::@2->memcpy8_vram_vram::@1] + __b1: + // [2236] phi memcpy8_vram_vram::num8#2 = memcpy8_vram_vram::num8#1 [phi:memcpy8_vram_vram/memcpy8_vram_vram::@2->memcpy8_vram_vram::@1#0] -- register_copy + // the size is only a byte, this is the fastest loop! + // memcpy8_vram_vram::@1 + // while (num8--) + // [2237] memcpy8_vram_vram::num8#0 = -- memcpy8_vram_vram::num8#2 -- vbum1=_dec_vbum2 + ldy num8_1 + dey + sty num8 + // [2238] if(0!=memcpy8_vram_vram::num8#2) goto memcpy8_vram_vram::@2 -- 0_neq_vbum1_then_la1 + lda num8_1 + bne __b2 + // memcpy8_vram_vram::@return // } - // [3165] return + // [2239] return rts - // display_chip_line::@2 + // memcpy8_vram_vram::@2 __b2: - // cputc(VERA_CHR_SPACE) - // [3166] stackpush(char) = $20 -- _stackpushbyte_=vbuc1 - lda #$20 - pha - // [3167] callexecute cputc -- call_vprc1 - jsr cputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // for(char i=0; idisplay_chip_line::@1] - // [3149] phi display_chip_line::i#2 = display_chip_line::i#1 [phi:display_chip_line::@2->display_chip_line::@1#0] -- register_copy + // *VERA_DATA1 = *VERA_DATA0 + // [2240] *VERA_DATA1 = *VERA_DATA0 -- _deref_pbuc1=_deref_pbuc2 + lda VERA_DATA0 + sta VERA_DATA1 + // [2241] memcpy8_vram_vram::num8#6 = memcpy8_vram_vram::num8#0 -- vbum1=vbum2 + lda num8 + sta num8_1 jmp __b1 .segment Data - i: .byte 0 - x: .byte 0 - w: .byte 0 - c: .byte 0 - y: .byte 0 + num8: .byte 0 + dbank_vram: .byte 0 + doffset_vram: .word 0 + sbank_vram: .byte 0 + soffset_vram: .word 0 + num8_1: .byte 0 } .segment Code - // display_chip_end -/** - * @brief Print last line of a chip figure. - * - * @param x Start X - * @param y Start Y - * @param w Width - */ -// void display_chip_end(__mem() char x, char y, __mem() char w) -display_chip_end: { - // gotoxy(x, y) - // [3170] gotoxy::x#12 = display_chip_end::x#0 -- vbum1=vbum2 - lda x - sta gotoxy.x - // [3171] call gotoxy - // [802] phi from display_chip_end to gotoxy [phi:display_chip_end->gotoxy] - // [802] phi gotoxy::y#37 = display_print_chip::y#21 [phi:display_chip_end->gotoxy#0] -- vbum1=vbuc1 - lda #display_print_chip.y - sta gotoxy.y - // [802] phi gotoxy::x#37 = gotoxy::x#12 [phi:display_chip_end->gotoxy#1] -- register_copy - jsr gotoxy - // [3172] phi from display_chip_end to display_chip_end::@4 [phi:display_chip_end->display_chip_end::@4] - // display_chip_end::@4 - // textcolor(GREY) - // [3173] call textcolor - // [784] phi from display_chip_end::@4 to textcolor [phi:display_chip_end::@4->textcolor] - // [784] phi textcolor::color#23 = GREY [phi:display_chip_end::@4->textcolor#0] -- vbum1=vbuc1 - lda #GREY - sta textcolor.color - jsr textcolor - // [3174] phi from display_chip_end::@4 to display_chip_end::@5 [phi:display_chip_end::@4->display_chip_end::@5] - // display_chip_end::@5 - // bgcolor(BLUE) - // [3175] call bgcolor - // [789] phi from display_chip_end::@5 to bgcolor [phi:display_chip_end::@5->bgcolor] - // [789] phi bgcolor::color#15 = BLUE [phi:display_chip_end::@5->bgcolor#0] -- vbum1=vbuc1 - lda #BLUE - sta bgcolor.color - jsr bgcolor - // display_chip_end::@6 - // cputc(VERA_CHR_UR) - // [3176] stackpush(char) = $7c -- _stackpushbyte_=vbuc1 - lda #$7c - pha - // [3177] callexecute cputc -- call_vprc1 - jsr cputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // textcolor(BLUE) - // [3179] call textcolor - // [784] phi from display_chip_end::@6 to textcolor [phi:display_chip_end::@6->textcolor] - // [784] phi textcolor::color#23 = BLUE [phi:display_chip_end::@6->textcolor#0] -- vbum1=vbuc1 - lda #BLUE - sta textcolor.color - jsr textcolor - // [3180] phi from display_chip_end::@6 to display_chip_end::@7 [phi:display_chip_end::@6->display_chip_end::@7] - // display_chip_end::@7 - // bgcolor(BLACK) - // [3181] call bgcolor - // [789] phi from display_chip_end::@7 to bgcolor [phi:display_chip_end::@7->bgcolor] - // [789] phi bgcolor::color#15 = BLACK [phi:display_chip_end::@7->bgcolor#0] -- vbum1=vbuc1 - lda #BLACK - sta bgcolor.color - jsr bgcolor - // [3182] phi from display_chip_end::@7 to display_chip_end::@1 [phi:display_chip_end::@7->display_chip_end::@1] - // [3182] phi display_chip_end::i#2 = 0 [phi:display_chip_end::@7->display_chip_end::@1#0] -- vbum1=vbuc1 + // utoa_append +// Used to convert a single digit of an unsigned number value to a string representation +// Counts a single digit up from '0' as long as the value is larger than sub. +// Each time the digit is increased sub is subtracted from value. +// - buffer : pointer to the char that receives the digit +// - value : The value where the digit will be derived from +// - sub : the value of a '1' in the digit. Subtracted continually while the digit is increased. +// (For decimal the subs used are 10000, 1000, 100, 10, 1) +// returns : the value reduced by sub * digit so that it is less than sub. +// __mem() unsigned int utoa_append(__zp($3e) char *buffer, __mem() unsigned int value, __mem() unsigned int sub) +utoa_append: { + .label buffer = $3e + // [2243] phi from utoa_append to utoa_append::@1 [phi:utoa_append->utoa_append::@1] + // [2243] phi utoa_append::digit#2 = 0 [phi:utoa_append->utoa_append::@1#0] -- vbum1=vbuc1 lda #0 - sta i - // display_chip_end::@1 + sta digit + // [2243] phi utoa_append::value#2 = utoa_append::value#0 [phi:utoa_append->utoa_append::@1#1] -- register_copy + // utoa_append::@1 __b1: - // for(char i=0; i= sub) + // [2244] if(utoa_append::value#2>=utoa_append::sub#0) goto utoa_append::@2 -- vwum1_ge_vwum2_then_la1 + lda sub+1 + cmp value+1 + bne !+ + lda sub + cmp value + beq __b2 + !: bcc __b2 - // [3184] phi from display_chip_end::@1 to display_chip_end::@3 [phi:display_chip_end::@1->display_chip_end::@3] - // display_chip_end::@3 - // textcolor(GREY) - // [3185] call textcolor - // [784] phi from display_chip_end::@3 to textcolor [phi:display_chip_end::@3->textcolor] - // [784] phi textcolor::color#23 = GREY [phi:display_chip_end::@3->textcolor#0] -- vbum1=vbuc1 - lda #GREY - sta textcolor.color - jsr textcolor - // [3186] phi from display_chip_end::@3 to display_chip_end::@8 [phi:display_chip_end::@3->display_chip_end::@8] - // display_chip_end::@8 - // bgcolor(BLUE) - // [3187] call bgcolor - // [789] phi from display_chip_end::@8 to bgcolor [phi:display_chip_end::@8->bgcolor] - // [789] phi bgcolor::color#15 = BLUE [phi:display_chip_end::@8->bgcolor#0] -- vbum1=vbuc1 - lda #BLUE - sta bgcolor.color - jsr bgcolor - // display_chip_end::@9 - // cputc(VERA_CHR_UL) - // [3188] stackpush(char) = $7e -- _stackpushbyte_=vbuc1 - lda #$7e - pha - // [3189] callexecute cputc -- call_vprc1 - jsr cputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // display_chip_end::@return + // utoa_append::@3 + // *buffer = DIGITS[digit] + // [2245] *utoa_append::buffer#0 = DIGITS[utoa_append::digit#2] -- _deref_pbuz1=pbuc1_derefidx_vbum2 + ldy digit + lda DIGITS,y + ldy #0 + sta (buffer),y + // utoa_append::@return // } - // [3191] return + // [2246] return rts - // display_chip_end::@2 + // utoa_append::@2 __b2: - // cputc(VERA_CHR_HL) - // [3192] stackpush(char) = $62 -- _stackpushbyte_=vbuc1 - lda #$62 - pha - // [3193] callexecute cputc -- call_vprc1 - jsr cputc - // sideeffect stackpullpadding(1) -- _stackpullpadding_1 - pla - // for(char i=0; idisplay_chip_end::@1] - // [3182] phi display_chip_end::i#2 = display_chip_end::i#1 [phi:display_chip_end::@2->display_chip_end::@1#0] -- register_copy + // digit++; + // [2247] utoa_append::digit#1 = ++ utoa_append::digit#2 -- vbum1=_inc_vbum1 + inc digit + // value -= sub + // [2248] utoa_append::value#1 = utoa_append::value#2 - utoa_append::sub#0 -- vwum1=vwum1_minus_vwum2 + lda value + sec + sbc sub + sta value + lda value+1 + sbc sub+1 + sta value+1 + // [2243] phi from utoa_append::@2 to utoa_append::@1 [phi:utoa_append::@2->utoa_append::@1] + // [2243] phi utoa_append::digit#2 = utoa_append::digit#1 [phi:utoa_append::@2->utoa_append::@1#0] -- register_copy + // [2243] phi utoa_append::value#2 = utoa_append::value#1 [phi:utoa_append::@2->utoa_append::@1#1] -- register_copy jmp __b1 .segment Data - i: .byte 0 - .label x = display_print_chip.x - w: .byte 0 + .label value = printf_uint.uvalue + .label sub = utoa.digit_value + .label return = printf_uint.uvalue + digit: .byte 0 } .segment CodeVera - // spi_get_jedec -spi_get_jedec: { - // spi_fast() - // [3197] call spi_fast - /* -; Returns -; .X = Vendor ID -; .Y = Memory Type -; .A = Memory Capacity -.proc spi_get_jedec - jsr spi_fast - - jsr spi_select - lda #$9F - jsr spi_write - jsr spi_read - tax - jsr spi_read - tay - jsr spi_read + // spi_fast +spi_fast: { + // asm + // asm { ldavera_reg_SPICtrl and#%11111101 stavera_reg_SPICtrl } + /* +.proc spi_fast + lda Vera::Reg::SPICtrl + and #%11111101 + sta Vera::Reg::SPICtrl + rts +.endproc +*/ + lda vera_reg_SPICtrl + and #$fd + sta vera_reg_SPICtrl + // spi_fast::@return + // } + // [2250] return rts +} + // spi_select +spi_select: { + // spi_deselect() + // [2252] call spi_deselect + /* +.proc spi_select + jsr spi_deselect + + lda Vera::Reg::SPICtrl + ora #$01 + sta Vera::Reg::SPICtrl + rts .endproc - */ - jsr spi_fast - // [3198] phi from spi_get_jedec to spi_get_jedec::@1 [phi:spi_get_jedec->spi_get_jedec::@1] - // spi_get_jedec::@1 - // spi_select() - // [3199] call spi_select - // [3393] phi from spi_get_jedec::@1 to spi_select [phi:spi_get_jedec::@1->spi_select] - jsr spi_select - // spi_get_jedec::@2 - // spi_write(0x9F) - // [3200] spi_write::data = $9f -- vbum1=vbuc1 - lda #$9f - sta spi_write.data - // [3201] call spi_write - jsr spi_write - // [3202] phi from spi_get_jedec::@2 to spi_get_jedec::@3 [phi:spi_get_jedec::@2->spi_get_jedec::@3] - // spi_get_jedec::@3 - // spi_read() - // [3203] call spi_read - jsr spi_read - // [3204] spi_read::return#0 = spi_read::return#4 -- vbum1=vbum2 - lda spi_read.return_3 - sta spi_read.return - // [3205] phi from spi_get_jedec::@3 to spi_get_jedec::@4 [phi:spi_get_jedec::@3->spi_get_jedec::@4] - // spi_get_jedec::@4 - // spi_read() - // [3206] call spi_read - jsr spi_read - // [3207] spi_read::return#1 = spi_read::return#4 -- vbum1=vbum2 - lda spi_read.return_3 - sta spi_read.return_1 - // [3208] phi from spi_get_jedec::@4 to spi_get_jedec::@5 [phi:spi_get_jedec::@4->spi_get_jedec::@5] - // spi_get_jedec::@5 - // spi_read() - // [3209] call spi_read - jsr spi_read - // [3210] spi_read::return#2 = spi_read::return#4 -- vbum1=vbum2 - lda spi_read.return_3 - sta spi_read.return_2 - // spi_get_jedec::@return +*/ + jsr spi_deselect + // spi_select::@1 + // *vera_reg_SPICtrl |= 1 + // [2253] *vera_reg_SPICtrl = *vera_reg_SPICtrl | 1 -- _deref_pbuc1=_deref_pbuc1_bor_vbuc2 + lda #1 + ora vera_reg_SPICtrl + sta vera_reg_SPICtrl + // spi_select::@return // } - // [3211] return + // [2254] return rts } -.segment Code - // rom_write_byte + // spi_write /** - * @brief Write a byte to the ROM using the 22 bit address. - * The lower 14 bits of the 22 bit ROM address are transformed into the **ptr_rom** 16 bit ROM address. - * The higher 8 bits of the 22 bit ROM address are transformed into the **bank_rom** 8 bit bank number. - * **bank_ptr* is used to set the bank using ZP $01. **ptr_rom** is used to write the byte into the ROM. - * - * @param address The 22 bit ROM address. - * @param value The byte value to be written. + * @brief + * + * */ -// void rom_write_byte(__mem() unsigned long address, __mem() char value) -rom_write_byte: { - .label rom_bank1_rom_write_byte__0 = $3a - .label rom_bank1_rom_write_byte__1 = $29 - .label rom_bank1_rom_write_byte__2 = $3f - .label rom_ptr1_rom_write_byte__0 = $3b - .label rom_ptr1_rom_write_byte__2 = $3b - .label rom_ptr1_return = $3b - // rom_write_byte::rom_bank1 - // BYTE2(address) - // [3213] rom_write_byte::rom_bank1_$0 = byte2 rom_write_byte::address#4 -- vbuz1=_byte2_vdum2 - lda address+2 - sta.z rom_bank1_rom_write_byte__0 - // BYTE1(address) - // [3214] rom_write_byte::rom_bank1_$1 = byte1 rom_write_byte::address#4 -- vbuz1=_byte1_vdum2 - lda address+1 - sta.z rom_bank1_rom_write_byte__1 - // MAKEWORD(BYTE2(address),BYTE1(address)) - // [3215] rom_write_byte::rom_bank1_$2 = rom_write_byte::rom_bank1_$0 w= rom_write_byte::rom_bank1_$1 -- vwuz1=vbuz2_word_vbuz3 - lda.z rom_bank1_rom_write_byte__0 - sta.z rom_bank1_rom_write_byte__2+1 - lda.z rom_bank1_rom_write_byte__1 - sta.z rom_bank1_rom_write_byte__2 - // unsigned int bank_unshifted = MAKEWORD(BYTE2(address),BYTE1(address)) << 2 - // [3216] rom_write_byte::rom_bank1_bank_unshifted#0 = rom_write_byte::rom_bank1_$2 << 2 -- vwum1=vwuz2_rol_2 - asl - sta rom_bank1_bank_unshifted - lda.z rom_bank1_rom_write_byte__2+1 - rol - sta rom_bank1_bank_unshifted+1 - asl rom_bank1_bank_unshifted - rol rom_bank1_bank_unshifted+1 - // unsigned char bank = BYTE1(bank_unshifted) - // [3217] rom_write_byte::rom_bank1_return#0 = byte1 rom_write_byte::rom_bank1_bank_unshifted#0 -- vbum1=_byte1_vwum2 - lda rom_bank1_bank_unshifted+1 - sta rom_bank1_return - // rom_write_byte::rom_ptr1 - // (unsigned int)(address) & ROM_PTR_MASK - // [3218] rom_write_byte::rom_ptr1_$2 = (unsigned int)rom_write_byte::address#4 -- vwuz1=_word_vdum2 - lda address - sta.z rom_ptr1_rom_write_byte__2 - lda address+1 - sta.z rom_ptr1_rom_write_byte__2+1 - // [3219] rom_write_byte::rom_ptr1_$0 = rom_write_byte::rom_ptr1_$2 & $3fff -- vwuz1=vwuz1_band_vwuc1 - lda.z rom_ptr1_rom_write_byte__0 - and #<$3fff - sta.z rom_ptr1_rom_write_byte__0 - lda.z rom_ptr1_rom_write_byte__0+1 - and #>$3fff - sta.z rom_ptr1_rom_write_byte__0+1 - // ((unsigned int)(address) & ROM_PTR_MASK) + ROM_BASE - // [3220] rom_write_byte::rom_ptr1_return#0 = rom_write_byte::rom_ptr1_$0 + $c000 -- vwuz1=vwuz1_plus_vwuc1 - lda.z rom_ptr1_return - clc - adc #<$c000 - sta.z rom_ptr1_return - lda.z rom_ptr1_return+1 - adc #>$c000 - sta.z rom_ptr1_return+1 - // rom_write_byte::bank_set_brom1 - // BROM = bank - // [3221] BROM = rom_write_byte::rom_bank1_return#0 -- vbuz1=vbum2 - lda rom_bank1_return - sta.z BROM - // rom_write_byte::@1 - // *ptr_rom = value - // [3222] *((char *)rom_write_byte::rom_ptr1_return#0) = rom_write_byte::value#10 -- _deref_pbuz1=vbum2 - lda value - ldy #0 - sta (rom_ptr1_return),y - // rom_write_byte::@return +// void spi_write(__mem() volatile char data) +spi_write: { + // asm + // asm { ldadata stavera_reg_SPIData !: bitvera_reg_SPICtrl bmi!- } + /* +.proc spi_write + sta Vera::Reg::SPIData +@1: bit Vera::Reg::SPICtrl + bmi @1 + rts +.endproc +*/ + lda data + sta vera_reg_SPIData + !: + bit vera_reg_SPICtrl + bmi !- + // spi_write::@return // } - // [3223] return + // [2256] return rts - .segment Data - rom_bank1_bank_unshifted: .word 0 - rom_bank1_return: .byte 0 - address: .dword 0 - value: .byte 0 + .segment DataVera + data: .byte 0 } .segment Code // cbm_k_setlfs @@ -21708,7 +14391,7 @@ cbm_k_setlfs: { jsr CBM_SETLFS // cbm_k_setlfs::@return // } - // [3225] return + // [2258] return rts .segment Data channel: .byte 0 @@ -21726,58 +14409,58 @@ cbm_k_setlfs: { * @param stream FILE* stream. * @return int Contains a non-zero value if there is an error. */ -// __mem() int ferror(__zp($3d) struct $2 *stream) +// __mem() int ferror(__zp($40) struct $2 *stream) ferror: { - .label ferror__6 = $29 - .label ferror__15 = $2b - .label cbm_k_setnam1_filename = $b8 - .label cbm_k_setnam1_ferror__0 = $3b - .label stream = $3d - .label errno_len = $6b + .label ferror__6 = $39 + .label ferror__15 = $3a + .label cbm_k_setnam1_filename = $72 + .label cbm_k_setnam1_ferror__0 = $6c + .label stream = $40 + .label errno_len = $63 // unsigned char sp = (unsigned char)stream - // [3226] ferror::sp#0 = (char)ferror::stream#0 -- vbum1=_byte_pssz2 + // [2259] ferror::sp#0 = (char)ferror::stream#0 -- vbum1=_byte_pssz2 lda.z stream sta sp // cbm_k_setlfs(15, 8, 15) - // [3227] cbm_k_setlfs::channel = $f -- vbum1=vbuc1 + // [2260] cbm_k_setlfs::channel = $f -- vbum1=vbuc1 lda #$f sta cbm_k_setlfs.channel - // [3228] cbm_k_setlfs::device = 8 -- vbum1=vbuc1 + // [2261] cbm_k_setlfs::device = 8 -- vbum1=vbuc1 lda #8 sta cbm_k_setlfs.device - // [3229] cbm_k_setlfs::command = $f -- vbum1=vbuc1 + // [2262] cbm_k_setlfs::command = $f -- vbum1=vbuc1 lda #$f sta cbm_k_setlfs.command - // [3230] call cbm_k_setlfs + // [2263] call cbm_k_setlfs jsr cbm_k_setlfs // ferror::@11 // cbm_k_setnam("") - // [3231] ferror::cbm_k_setnam1_filename = str -- pbuz1=pbuc1 + // [2264] ferror::cbm_k_setnam1_filename = str -- pbuz1=pbuc1 lda #str sta.z cbm_k_setnam1_filename+1 // ferror::cbm_k_setnam1 // strlen(filename) - // [3232] strlen::str#5 = ferror::cbm_k_setnam1_filename -- pbuz1=pbuz2 + // [2265] strlen::str#5 = ferror::cbm_k_setnam1_filename -- pbuz1=pbuz2 lda.z cbm_k_setnam1_filename sta.z strlen.str lda.z cbm_k_setnam1_filename+1 sta.z strlen.str+1 - // [3233] call strlen - // [2611] phi from ferror::cbm_k_setnam1 to strlen [phi:ferror::cbm_k_setnam1->strlen] - // [2611] phi strlen::str#8 = strlen::str#5 [phi:ferror::cbm_k_setnam1->strlen#0] -- register_copy + // [2266] call strlen + // [1788] phi from ferror::cbm_k_setnam1 to strlen [phi:ferror::cbm_k_setnam1->strlen] + // [1788] phi strlen::str#8 = strlen::str#5 [phi:ferror::cbm_k_setnam1->strlen#0] -- register_copy jsr strlen // strlen(filename) - // [3234] strlen::return#12 = strlen::len#2 + // [2267] strlen::return#12 = strlen::len#2 // ferror::@12 - // [3235] ferror::cbm_k_setnam1_$0 = strlen::return#12 -- vwuz1=vwum2 + // [2268] ferror::cbm_k_setnam1_$0 = strlen::return#12 -- vwuz1=vwum2 lda strlen.return sta.z cbm_k_setnam1_ferror__0 lda strlen.return+1 sta.z cbm_k_setnam1_ferror__0+1 // char filename_len = (char)strlen(filename) - // [3236] ferror::cbm_k_setnam1_filename_len = (char)ferror::cbm_k_setnam1_$0 -- vbum1=_byte_vwuz2 + // [2269] ferror::cbm_k_setnam1_filename_len = (char)ferror::cbm_k_setnam1_$0 -- vbum1=_byte_vwuz2 lda.z cbm_k_setnam1_ferror__0 sta cbm_k_setnam1_filename_len // asm @@ -21790,12 +14473,12 @@ ferror: { jsr CBM_OPEN // ferror::@6 // cbm_k_chkin(15) - // [3239] ferror::cbm_k_chkin1_channel = $f -- vbum1=vbuc1 + // [2272] ferror::cbm_k_chkin1_channel = $f -- vbum1=vbuc1 lda #$f sta cbm_k_chkin1_channel // ferror::cbm_k_chkin1 // char status - // [3240] ferror::cbm_k_chkin1_status = 0 -- vbum1=vbuc1 + // [2273] ferror::cbm_k_chkin1_status = 0 -- vbum1=vbuc1 lda #0 sta cbm_k_chkin1_status // asm @@ -21805,7 +14488,7 @@ ferror: { sta cbm_k_chkin1_status // ferror::cbm_k_chrin1 // char ch - // [3242] ferror::cbm_k_chrin1_ch = 0 -- vbum1=vbuc1 + // [2275] ferror::cbm_k_chrin1_ch = 0 -- vbum1=vbuc1 lda #0 sta cbm_k_chrin1_ch // asm @@ -21813,26 +14496,26 @@ ferror: { jsr CBM_CHRIN sta cbm_k_chrin1_ch // return ch; - // [3244] ferror::cbm_k_chrin1_return#0 = ferror::cbm_k_chrin1_ch -- vbum1=vbum2 + // [2277] ferror::cbm_k_chrin1_return#0 = ferror::cbm_k_chrin1_ch -- vbum1=vbum2 sta cbm_k_chrin1_return // ferror::cbm_k_chrin1_@return // } - // [3245] ferror::cbm_k_chrin1_return#1 = ferror::cbm_k_chrin1_return#0 + // [2278] ferror::cbm_k_chrin1_return#1 = ferror::cbm_k_chrin1_return#0 // ferror::@7 // char ch = cbm_k_chrin() - // [3246] ferror::ch#0 = ferror::cbm_k_chrin1_return#1 - // [3247] phi from ferror::@7 to ferror::cbm_k_readst1 [phi:ferror::@7->ferror::cbm_k_readst1] - // [3247] phi __errno#123 = __errno#473 [phi:ferror::@7->ferror::cbm_k_readst1#0] -- register_copy - // [3247] phi ferror::errno_len#10 = 0 [phi:ferror::@7->ferror::cbm_k_readst1#1] -- vbuz1=vbuc1 + // [2279] ferror::ch#0 = ferror::cbm_k_chrin1_return#1 + // [2280] phi from ferror::@7 to ferror::cbm_k_readst1 [phi:ferror::@7->ferror::cbm_k_readst1] + // [2280] phi __errno#18 = __errno#118 [phi:ferror::@7->ferror::cbm_k_readst1#0] -- register_copy + // [2280] phi ferror::errno_len#10 = 0 [phi:ferror::@7->ferror::cbm_k_readst1#1] -- vbuz1=vbuc1 lda #0 sta.z errno_len - // [3247] phi ferror::ch#10 = ferror::ch#0 [phi:ferror::@7->ferror::cbm_k_readst1#2] -- register_copy - // [3247] phi ferror::errno_parsed#2 = 0 [phi:ferror::@7->ferror::cbm_k_readst1#3] -- vbum1=vbuc1 + // [2280] phi ferror::ch#10 = ferror::ch#0 [phi:ferror::@7->ferror::cbm_k_readst1#2] -- register_copy + // [2280] phi ferror::errno_parsed#2 = 0 [phi:ferror::@7->ferror::cbm_k_readst1#3] -- vbum1=vbuc1 sta errno_parsed // ferror::cbm_k_readst1 cbm_k_readst1: // char status - // [3248] ferror::cbm_k_readst1_status = 0 -- vbum1=vbuc1 + // [2281] ferror::cbm_k_readst1_status = 0 -- vbum1=vbuc1 lda #0 sta cbm_k_readst1_status // asm @@ -21840,629 +14523,337 @@ ferror: { jsr CBM_READST sta cbm_k_readst1_status // return status; - // [3250] ferror::cbm_k_readst1_return#0 = ferror::cbm_k_readst1_status -- vbum1=vbum2 + // [2283] ferror::cbm_k_readst1_return#0 = ferror::cbm_k_readst1_status -- vbum1=vbum2 sta cbm_k_readst1_return // ferror::cbm_k_readst1_@return // } - // [3251] ferror::cbm_k_readst1_return#1 = ferror::cbm_k_readst1_return#0 + // [2284] ferror::cbm_k_readst1_return#1 = ferror::cbm_k_readst1_return#0 // ferror::@8 // cbm_k_readst() - // [3252] ferror::$6 = ferror::cbm_k_readst1_return#1 -- vbuz1=vbum2 + // [2285] ferror::$6 = ferror::cbm_k_readst1_return#1 -- vbuz1=vbum2 sta.z ferror__6 // st = cbm_k_readst() - // [3253] ferror::st#1 = ferror::$6 -- vbum1=vbuz2 + // [2286] ferror::st#1 = ferror::$6 -- vbum1=vbuz2 sta st // while (!(st = cbm_k_readst())) - // [3254] if(0==ferror::st#1) goto ferror::@1 -- 0_eq_vbum1_then_la1 + // [2287] if(0==ferror::st#1) goto ferror::@1 -- 0_eq_vbum1_then_la1 beq __b1 // ferror::@2 // __status = st - // [3255] ((char *)&__stdio_file+$46)[ferror::sp#0] = ferror::st#1 -- pbuc1_derefidx_vbum1=vbum2 + // [2288] ((char *)&__stdio_file+$46)[ferror::sp#0] = ferror::st#1 -- pbuc1_derefidx_vbum1=vbum2 ldy sp sta __stdio_file+$46,y - // cbm_k_close(15) - // [3256] ferror::cbm_k_close1_channel = $f -- vbum1=vbuc1 - lda #$f - sta cbm_k_close1_channel - // ferror::cbm_k_close1 - // asm - // asm { ldachannel jsrCBM_CLOSE } - jsr CBM_CLOSE - // ferror::@9 - // return __errno; - // [3258] ferror::return#1 = __errno#123 -- vwsm1=vwsm2 - lda __errno - sta return - lda __errno+1 - sta return+1 - // ferror::@return - // } - // [3259] return - rts - // ferror::@1 - __b1: - // if (!errno_parsed) - // [3260] if(0!=ferror::errno_parsed#2) goto ferror::@3 -- 0_neq_vbum1_then_la1 - lda errno_parsed - bne __b3 - // ferror::@4 - // if (ch == ',') - // [3261] if(ferror::ch#10!=',') goto ferror::@3 -- vbum1_neq_vbuc1_then_la1 - lda #',' - cmp ch - bne __b3 - // ferror::@5 - // errno_parsed++; - // [3262] ferror::errno_parsed#1 = ++ ferror::errno_parsed#2 -- vbum1=_inc_vbum1 - inc errno_parsed - // strncpy(temp, __errno_error, errno_len+1) - // [3263] strncpy::n#0 = ferror::errno_len#10 + 1 -- vwum1=vbuz2_plus_1 - lda.z errno_len - clc - adc #1 - sta strncpy.n - lda #0 - adc #0 - sta strncpy.n+1 - // [3264] call strncpy - // [3002] phi from ferror::@5 to strncpy [phi:ferror::@5->strncpy] - // [3002] phi strncpy::dst#8 = ferror::temp [phi:ferror::@5->strncpy#0] -- pbuz1=pbuc1 - lda #temp - sta.z strncpy.dst+1 - // [3002] phi strncpy::src#6 = __errno_error [phi:ferror::@5->strncpy#1] -- pbuz1=pbuc1 - lda #<__errno_error - sta.z strncpy.src - lda #>__errno_error - sta.z strncpy.src+1 - // [3002] phi strncpy::n#3 = strncpy::n#0 [phi:ferror::@5->strncpy#2] -- register_copy - jsr strncpy - // [3265] phi from ferror::@5 to ferror::@13 [phi:ferror::@5->ferror::@13] - // ferror::@13 - // atoi(temp) - // [3266] call atoi - // [3278] phi from ferror::@13 to atoi [phi:ferror::@13->atoi] - // [3278] phi atoi::str#2 = ferror::temp [phi:ferror::@13->atoi#0] -- pbuz1=pbuc1 - lda #temp - sta.z atoi.str+1 - jsr atoi - // atoi(temp) - // [3267] atoi::return#4 = atoi::return#2 - // ferror::@14 - // __errno = atoi(temp) - // [3268] __errno#2 = atoi::return#4 -- vwsm1=vwsm2 - lda atoi.return - sta __errno - lda atoi.return+1 - sta __errno+1 - // [3269] phi from ferror::@1 ferror::@14 ferror::@4 to ferror::@3 [phi:ferror::@1/ferror::@14/ferror::@4->ferror::@3] - // [3269] phi __errno#178 = __errno#123 [phi:ferror::@1/ferror::@14/ferror::@4->ferror::@3#0] -- register_copy - // [3269] phi ferror::errno_parsed#11 = ferror::errno_parsed#2 [phi:ferror::@1/ferror::@14/ferror::@4->ferror::@3#1] -- register_copy - // ferror::@3 - __b3: - // __errno_error[errno_len] = ch - // [3270] __errno_error[ferror::errno_len#10] = ferror::ch#10 -- pbuc1_derefidx_vbuz1=vbum2 - lda ch - ldy.z errno_len - sta __errno_error,y - // errno_len++; - // [3271] ferror::errno_len#1 = ++ ferror::errno_len#10 -- vbuz1=_inc_vbuz1 - inc.z errno_len - // ferror::cbm_k_chrin2 - // char ch - // [3272] ferror::cbm_k_chrin2_ch = 0 -- vbum1=vbuc1 - lda #0 - sta cbm_k_chrin2_ch - // asm - // asm { jsrCBM_CHRIN stach } - jsr CBM_CHRIN - sta cbm_k_chrin2_ch - // return ch; - // [3274] ferror::cbm_k_chrin2_return#0 = ferror::cbm_k_chrin2_ch -- vbum1=vbum2 - sta cbm_k_chrin2_return - // ferror::cbm_k_chrin2_@return - // } - // [3275] ferror::cbm_k_chrin2_return#1 = ferror::cbm_k_chrin2_return#0 - // ferror::@10 - // cbm_k_chrin() - // [3276] ferror::$15 = ferror::cbm_k_chrin2_return#1 -- vbuz1=vbum2 - sta.z ferror__15 - // ch = cbm_k_chrin() - // [3277] ferror::ch#1 = ferror::$15 -- vbum1=vbuz2 - sta ch - // [3247] phi from ferror::@10 to ferror::cbm_k_readst1 [phi:ferror::@10->ferror::cbm_k_readst1] - // [3247] phi __errno#123 = __errno#178 [phi:ferror::@10->ferror::cbm_k_readst1#0] -- register_copy - // [3247] phi ferror::errno_len#10 = ferror::errno_len#1 [phi:ferror::@10->ferror::cbm_k_readst1#1] -- register_copy - // [3247] phi ferror::ch#10 = ferror::ch#1 [phi:ferror::@10->ferror::cbm_k_readst1#2] -- register_copy - // [3247] phi ferror::errno_parsed#2 = ferror::errno_parsed#11 [phi:ferror::@10->ferror::cbm_k_readst1#3] -- register_copy - jmp cbm_k_readst1 - .segment Data - temp: .fill 4, 0 - cbm_k_setnam1_filename_len: .byte 0 - cbm_k_chkin1_channel: .byte 0 - cbm_k_chkin1_status: .byte 0 - cbm_k_chrin1_ch: .byte 0 - cbm_k_readst1_status: .byte 0 - cbm_k_close1_channel: .byte 0 - cbm_k_chrin2_ch: .byte 0 - return: .word 0 - sp: .byte 0 - .label cbm_k_chrin1_return = ch - ch: .byte 0 - cbm_k_readst1_return: .byte 0 - st: .byte 0 - cbm_k_chrin2_return: .byte 0 - errno_parsed: .byte 0 -} -.segment Code - // atoi -// Converts the string argument str to an integer. -// __mem() int atoi(__zp($5a) const char *str) -atoi: { - .label atoi__6 = $47 - .label atoi__7 = $47 - .label str = $5a - .label atoi__10 = $47 - .label atoi__11 = $47 - // if (str[i] == '-') - // [3279] if(*atoi::str#2!='-') goto atoi::@3 -- _deref_pbuz1_neq_vbuc1_then_la1 - ldy #0 - lda (str),y - cmp #'-' - bne __b2 - // [3280] phi from atoi to atoi::@2 [phi:atoi->atoi::@2] - // atoi::@2 - // [3281] phi from atoi::@2 to atoi::@3 [phi:atoi::@2->atoi::@3] - // [3281] phi atoi::negative#2 = 1 [phi:atoi::@2->atoi::@3#0] -- vbum1=vbuc1 - lda #1 - sta negative - // [3281] phi atoi::res#2 = 0 [phi:atoi::@2->atoi::@3#1] -- vwsm1=vwsc1 - tya - sta res - sta res+1 - // [3281] phi atoi::i#4 = 1 [phi:atoi::@2->atoi::@3#2] -- vbum1=vbuc1 - lda #1 - sta i - jmp __b3 - // Iterate through all digits and update the result - // [3281] phi from atoi to atoi::@3 [phi:atoi->atoi::@3] - __b2: - // [3281] phi atoi::negative#2 = 0 [phi:atoi->atoi::@3#0] -- vbum1=vbuc1 - lda #0 - sta negative - // [3281] phi atoi::res#2 = 0 [phi:atoi->atoi::@3#1] -- vwsm1=vwsc1 - sta res - sta res+1 - // [3281] phi atoi::i#4 = 0 [phi:atoi->atoi::@3#2] -- vbum1=vbuc1 - sta i - // atoi::@3 - __b3: - // for (; str[i]>='0' && str[i]<='9'; ++i) - // [3282] if(atoi::str#2[atoi::i#4]<'0') goto atoi::@5 -- pbuz1_derefidx_vbum2_lt_vbuc1_then_la1 - ldy i - lda (str),y - cmp #'0' - bcc __b5 - // atoi::@6 - // [3283] if(atoi::str#2[atoi::i#4]<='9') goto atoi::@4 -- pbuz1_derefidx_vbum2_le_vbuc1_then_la1 - lda (str),y - cmp #'9' - bcc __b4 - beq __b4 - // atoi::@5 - __b5: - // if(negative) - // [3284] if(0!=atoi::negative#2) goto atoi::@1 -- 0_neq_vbum1_then_la1 - // Return result with sign - lda negative - bne __b1 - // [3286] phi from atoi::@1 atoi::@5 to atoi::@return [phi:atoi::@1/atoi::@5->atoi::@return] - // [3286] phi atoi::return#2 = atoi::return#0 [phi:atoi::@1/atoi::@5->atoi::@return#0] -- register_copy - rts - // atoi::@1 - __b1: - // return -res; - // [3285] atoi::return#0 = - atoi::res#2 -- vwsm1=_neg_vwsm1 - lda #0 - sec - sbc return - sta return - lda #0 - sbc return+1 - sta return+1 - // atoi::@return - // } - // [3287] return - rts - // atoi::@4 - __b4: - // res * 10 - // [3288] atoi::$10 = atoi::res#2 << 2 -- vwsz1=vwsm2_rol_2 - lda res - asl - sta.z atoi__10 - lda res+1 - rol - sta.z atoi__10+1 - asl.z atoi__10 - rol.z atoi__10+1 - // [3289] atoi::$11 = atoi::$10 + atoi::res#2 -- vwsz1=vwsz1_plus_vwsm2 - clc - lda.z atoi__11 - adc res - sta.z atoi__11 - lda.z atoi__11+1 - adc res+1 - sta.z atoi__11+1 - // [3290] atoi::$6 = atoi::$11 << 1 -- vwsz1=vwsz1_rol_1 - asl.z atoi__6 - rol.z atoi__6+1 - // res * 10 + str[i] - // [3291] atoi::$7 = atoi::$6 + atoi::str#2[atoi::i#4] -- vwsz1=vwsz1_plus_pbuz2_derefidx_vbum3 - ldy i - lda.z atoi__7 - clc - adc (str),y - sta.z atoi__7 - bcc !+ - inc.z atoi__7+1 - !: - // res = res * 10 + str[i] - '0' - // [3292] atoi::res#1 = atoi::$7 - '0' -- vwsm1=vwsz2_minus_vbuc1 - lda.z atoi__7 - sec - sbc #'0' - sta res - lda.z atoi__7+1 - sbc #0 - sta res+1 - // for (; str[i]>='0' && str[i]<='9'; ++i) - // [3293] atoi::i#2 = ++ atoi::i#4 -- vbum1=_inc_vbum1 - inc i - // [3281] phi from atoi::@4 to atoi::@3 [phi:atoi::@4->atoi::@3] - // [3281] phi atoi::negative#2 = atoi::negative#2 [phi:atoi::@4->atoi::@3#0] -- register_copy - // [3281] phi atoi::res#2 = atoi::res#1 [phi:atoi::@4->atoi::@3#1] -- register_copy - // [3281] phi atoi::i#4 = atoi::i#2 [phi:atoi::@4->atoi::@3#2] -- register_copy - jmp __b3 - .segment Data - .label res = return - // Initialize sign as positive - i: .byte 0 - return: .word 0 - // Initialize result - negative: .byte 0 -} -.segment Code - // cx16_k_macptr -/** - * @brief Read a number of bytes from the sdcard using kernal macptr call. - * BRAM bank needs to be set properly before the load between adressed A000 and BFFF. - * - * @return x the size of bytes read - * @return y the size of bytes read - * @return if carry is set there is an error - */ -// __mem() unsigned int cx16_k_macptr(__mem() volatile char bytes, __zp($58) void * volatile buffer) -cx16_k_macptr: { - .label buffer = $58 - // unsigned int bytes_read - // [3294] cx16_k_macptr::bytes_read = 0 -- vwum1=vwuc1 - lda #<0 - sta bytes_read - sta bytes_read+1 + // cbm_k_close(15) + // [2289] ferror::cbm_k_close1_channel = $f -- vbum1=vbuc1 + lda #$f + sta cbm_k_close1_channel + // ferror::cbm_k_close1 // asm - // asm { ldabytes ldxbuffer ldybuffer+1 clc jsrCX16_MACPTR stxbytes_read stybytes_read+1 bcc!+ lda#$FF stabytes_read stabytes_read+1 !: } - lda bytes - ldx buffer - ldy buffer+1 - clc - jsr CX16_MACPTR - stx bytes_read - sty bytes_read+1 - bcc !+ - lda #$ff - sta bytes_read - sta bytes_read+1 - !: - // return bytes_read; - // [3296] cx16_k_macptr::return#0 = cx16_k_macptr::bytes_read -- vwum1=vwum2 - lda bytes_read + // asm { ldachannel jsrCBM_CLOSE } + jsr CBM_CLOSE + // ferror::@9 + // return __errno; + // [2291] ferror::return#1 = __errno#18 -- vwsm1=vwsm2 + lda __errno sta return - lda bytes_read+1 + lda __errno+1 sta return+1 - // cx16_k_macptr::@return + // ferror::@return // } - // [3297] cx16_k_macptr::return#1 = cx16_k_macptr::return#0 - // [3298] return + // [2292] return rts - .segment Data - bytes: .byte 0 - bytes_read: .word 0 - .label return = fgets.bytes -} -.segment Code - // uctoa_append -// Used to convert a single digit of an unsigned number value to a string representation -// Counts a single digit up from '0' as long as the value is larger than sub. -// Each time the digit is increased sub is subtracted from value. -// - buffer : pointer to the char that receives the digit -// - value : The value where the digit will be derived from -// - sub : the value of a '1' in the digit. Subtracted continually while the digit is increased. -// (For decimal the subs used are 10000, 1000, 100, 10, 1) -// returns : the value reduced by sub * digit so that it is less than sub. -// __mem() char uctoa_append(__zp($43) char *buffer, __mem() char value, __mem() char sub) -uctoa_append: { - .label buffer = $43 - // [3300] phi from uctoa_append to uctoa_append::@1 [phi:uctoa_append->uctoa_append::@1] - // [3300] phi uctoa_append::digit#2 = 0 [phi:uctoa_append->uctoa_append::@1#0] -- vbum1=vbuc1 - lda #0 - sta digit - // [3300] phi uctoa_append::value#2 = uctoa_append::value#0 [phi:uctoa_append->uctoa_append::@1#1] -- register_copy - // uctoa_append::@1 + // ferror::@1 __b1: - // while (value >= sub) - // [3301] if(uctoa_append::value#2>=uctoa_append::sub#0) goto uctoa_append::@2 -- vbum1_ge_vbum2_then_la1 - lda value - cmp sub - bcs __b2 - // uctoa_append::@3 - // *buffer = DIGITS[digit] - // [3302] *uctoa_append::buffer#0 = DIGITS[uctoa_append::digit#2] -- _deref_pbuz1=pbuc1_derefidx_vbum2 - ldy digit - lda DIGITS,y - ldy #0 - sta (buffer),y - // uctoa_append::@return - // } - // [3303] return - rts - // uctoa_append::@2 - __b2: - // digit++; - // [3304] uctoa_append::digit#1 = ++ uctoa_append::digit#2 -- vbum1=_inc_vbum1 - inc digit - // value -= sub - // [3305] uctoa_append::value#1 = uctoa_append::value#2 - uctoa_append::sub#0 -- vbum1=vbum1_minus_vbum2 - lda value - sec - sbc sub - sta value - // [3300] phi from uctoa_append::@2 to uctoa_append::@1 [phi:uctoa_append::@2->uctoa_append::@1] - // [3300] phi uctoa_append::digit#2 = uctoa_append::digit#1 [phi:uctoa_append::@2->uctoa_append::@1#0] -- register_copy - // [3300] phi uctoa_append::value#2 = uctoa_append::value#1 [phi:uctoa_append::@2->uctoa_append::@1#1] -- register_copy - jmp __b1 - .segment Data - .label value = smc_get_version_text.release - .label sub = uctoa.digit_value - .label return = smc_get_version_text.release - digit: .byte 0 -} -.segment CodeVera - // spi_read_flash -// void spi_read_flash(unsigned long spi_data) -spi_read_flash: { - // spi_select() - // [3307] call spi_select - /* -; .X [7:0] -; .Y [15:8] -; .A [23:16] -.proc spi_read_flash - pha - - jsr spi_select - lda #$03 - jsr spi_write - pla - jsr spi_write - tya - jsr spi_write - txa - jsr spi_write - - rts -.endproc - */ - // [3393] phi from spi_read_flash to spi_select [phi:spi_read_flash->spi_select] - jsr spi_select - // spi_read_flash::@1 - // spi_write(0x03) - // [3308] spi_write::data = 3 -- vbum1=vbuc1 - lda #3 - sta spi_write.data - // [3309] call spi_write - jsr spi_write - // spi_read_flash::@2 - // spi_write(BYTE2(spi_data)) - // [3310] spi_write::data = 0 -- vbum1=vbuc1 - lda #0 - sta spi_write.data - // [3311] call spi_write - jsr spi_write - // spi_read_flash::@3 - // spi_write(BYTE1(spi_data)) - // [3312] spi_write::data = 0 -- vbum1=vbuc1 + // if (!errno_parsed) + // [2293] if(0!=ferror::errno_parsed#2) goto ferror::@3 -- 0_neq_vbum1_then_la1 + lda errno_parsed + bne __b3 + // ferror::@4 + // if (ch == ',') + // [2294] if(ferror::ch#10!=',') goto ferror::@3 -- vbum1_neq_vbuc1_then_la1 + lda #',' + cmp ch + bne __b3 + // ferror::@5 + // errno_parsed++; + // [2295] ferror::errno_parsed#1 = ++ ferror::errno_parsed#2 -- vbum1=_inc_vbum1 + inc errno_parsed + // strncpy(temp, __errno_error, errno_len+1) + // [2296] strncpy::n#0 = ferror::errno_len#10 + 1 -- vwum1=vbuz2_plus_1 + lda.z errno_len + clc + adc #1 + sta strncpy.n lda #0 - sta spi_write.data - // [3313] call spi_write - jsr spi_write - // spi_read_flash::@4 - // spi_write(BYTE0(spi_data)) - // [3314] spi_write::data = 0 -- vbum1=vbuc1 + adc #0 + sta strncpy.n+1 + // [2297] call strncpy + // [2339] phi from ferror::@5 to strncpy [phi:ferror::@5->strncpy] + jsr strncpy + // [2298] phi from ferror::@5 to ferror::@13 [phi:ferror::@5->ferror::@13] + // ferror::@13 + // atoi(temp) + // [2299] call atoi + // [2311] phi from ferror::@13 to atoi [phi:ferror::@13->atoi] + // [2311] phi atoi::str#2 = ferror::temp [phi:ferror::@13->atoi#0] -- pbuz1=pbuc1 + lda #temp + sta.z atoi.str+1 + jsr atoi + // atoi(temp) + // [2300] atoi::return#4 = atoi::return#2 + // ferror::@14 + // __errno = atoi(temp) + // [2301] __errno#2 = atoi::return#4 -- vwsm1=vwsm2 + lda atoi.return + sta __errno + lda atoi.return+1 + sta __errno+1 + // [2302] phi from ferror::@1 ferror::@14 ferror::@4 to ferror::@3 [phi:ferror::@1/ferror::@14/ferror::@4->ferror::@3] + // [2302] phi __errno#116 = __errno#18 [phi:ferror::@1/ferror::@14/ferror::@4->ferror::@3#0] -- register_copy + // [2302] phi ferror::errno_parsed#11 = ferror::errno_parsed#2 [phi:ferror::@1/ferror::@14/ferror::@4->ferror::@3#1] -- register_copy + // ferror::@3 + __b3: + // __errno_error[errno_len] = ch + // [2303] __errno_error[ferror::errno_len#10] = ferror::ch#10 -- pbuc1_derefidx_vbuz1=vbum2 + lda ch + ldy.z errno_len + sta __errno_error,y + // errno_len++; + // [2304] ferror::errno_len#1 = ++ ferror::errno_len#10 -- vbuz1=_inc_vbuz1 + inc.z errno_len + // ferror::cbm_k_chrin2 + // char ch + // [2305] ferror::cbm_k_chrin2_ch = 0 -- vbum1=vbuc1 lda #0 - sta spi_write.data - // [3315] call spi_write - jsr spi_write - // spi_read_flash::@return + sta cbm_k_chrin2_ch + // asm + // asm { jsrCBM_CHRIN stach } + jsr CBM_CHRIN + sta cbm_k_chrin2_ch + // return ch; + // [2307] ferror::cbm_k_chrin2_return#0 = ferror::cbm_k_chrin2_ch -- vbum1=vbum2 + sta cbm_k_chrin2_return + // ferror::cbm_k_chrin2_@return // } - // [3316] return - rts + // [2308] ferror::cbm_k_chrin2_return#1 = ferror::cbm_k_chrin2_return#0 + // ferror::@10 + // cbm_k_chrin() + // [2309] ferror::$15 = ferror::cbm_k_chrin2_return#1 -- vbuz1=vbum2 + sta.z ferror__15 + // ch = cbm_k_chrin() + // [2310] ferror::ch#1 = ferror::$15 -- vbum1=vbuz2 + sta ch + // [2280] phi from ferror::@10 to ferror::cbm_k_readst1 [phi:ferror::@10->ferror::cbm_k_readst1] + // [2280] phi __errno#18 = __errno#116 [phi:ferror::@10->ferror::cbm_k_readst1#0] -- register_copy + // [2280] phi ferror::errno_len#10 = ferror::errno_len#1 [phi:ferror::@10->ferror::cbm_k_readst1#1] -- register_copy + // [2280] phi ferror::ch#10 = ferror::ch#1 [phi:ferror::@10->ferror::cbm_k_readst1#2] -- register_copy + // [2280] phi ferror::errno_parsed#2 = ferror::errno_parsed#11 [phi:ferror::@10->ferror::cbm_k_readst1#3] -- register_copy + jmp cbm_k_readst1 + .segment Data + temp: .fill 4, 0 + cbm_k_setnam1_filename_len: .byte 0 + cbm_k_chkin1_channel: .byte 0 + cbm_k_chkin1_status: .byte 0 + cbm_k_chrin1_ch: .byte 0 + cbm_k_readst1_status: .byte 0 + cbm_k_close1_channel: .byte 0 + cbm_k_chrin2_ch: .byte 0 + return: .word 0 + sp: .byte 0 + .label cbm_k_chrin1_return = ch + ch: .byte 0 + cbm_k_readst1_return: .byte 0 + st: .byte 0 + cbm_k_chrin2_return: .byte 0 + errno_parsed: .byte 0 } - // vera_compare -// __mem() unsigned int vera_compare(__mem() char bank_ram, __zp($64) char *bram_ptr, unsigned int vera_compare_size) -vera_compare: { - .label bram_ptr = $64 - // vera_compare::bank_set_bram1 - // BRAM = bank - // [3318] BRAM = vera_compare::bank_ram#0 -- vbuz1=vbum2 - lda bank_ram - sta.z BRAM - // [3319] phi from vera_compare::bank_set_bram1 to vera_compare::@1 [phi:vera_compare::bank_set_bram1->vera_compare::@1] - // [3319] phi vera_compare::bram_ptr#2 = vera_compare::bram_ptr#0 [phi:vera_compare::bank_set_bram1->vera_compare::@1#0] -- register_copy - // [3319] phi vera_compare::equal_bytes#2 = 0 [phi:vera_compare::bank_set_bram1->vera_compare::@1#1] -- vwum1=vwuc1 - lda #<0 - sta equal_bytes - sta equal_bytes+1 - // [3319] phi vera_compare::compared_bytes#2 = 0 [phi:vera_compare::bank_set_bram1->vera_compare::@1#2] -- vwum1=vwuc1 - sta compared_bytes - sta compared_bytes+1 - // vera_compare::@1 - __b1: - // while (compared_bytes < vera_compare_size) - // [3320] if(vera_compare::compared_bytes#2vera_compare::@2] - // vera_compare::@2 - __b2: - // unsigned char vera_byte = spi_read() - // [3323] call spi_read - jsr spi_read - // [3324] spi_read::return#12 = spi_read::return#4 - // vera_compare::@5 - // [3325] vera_compare::vera_byte#0 = spi_read::return#12 - // if (vera_byte == *bram_ptr) - // [3326] if(vera_compare::vera_byte#0!=*vera_compare::bram_ptr#2) goto vera_compare::@3 -- vbum1_neq__deref_pbuz2_then_la1 +.segment Code + // atoi +// Converts the string argument str to an integer. +// __mem() int atoi(__zp($49) const char *str) +atoi: { + .label atoi__6 = $4b + .label atoi__7 = $4b + .label str = $49 + .label atoi__10 = $4b + .label atoi__11 = $4b + // if (str[i] == '-') + // [2312] if(*atoi::str#2!='-') goto atoi::@3 -- _deref_pbuz1_neq_vbuc1_then_la1 ldy #0 - lda (bram_ptr),y - cmp vera_byte - bne __b3 - // vera_compare::@4 - // equal_bytes++; - // [3327] vera_compare::equal_bytes#1 = ++ vera_compare::equal_bytes#2 -- vwum1=_inc_vwum1 - inc equal_bytes - bne !+ - inc equal_bytes+1 - !: - // [3328] phi from vera_compare::@4 vera_compare::@5 to vera_compare::@3 [phi:vera_compare::@4/vera_compare::@5->vera_compare::@3] - // [3328] phi vera_compare::equal_bytes#6 = vera_compare::equal_bytes#1 [phi:vera_compare::@4/vera_compare::@5->vera_compare::@3#0] -- register_copy - // vera_compare::@3 + lda (str),y + cmp #'-' + bne __b2 + // [2313] phi from atoi to atoi::@2 [phi:atoi->atoi::@2] + // atoi::@2 + // [2314] phi from atoi::@2 to atoi::@3 [phi:atoi::@2->atoi::@3] + // [2314] phi atoi::negative#2 = 1 [phi:atoi::@2->atoi::@3#0] -- vbum1=vbuc1 + lda #1 + sta negative + // [2314] phi atoi::res#2 = 0 [phi:atoi::@2->atoi::@3#1] -- vwsm1=vwsc1 + tya + sta res + sta res+1 + // [2314] phi atoi::i#4 = 1 [phi:atoi::@2->atoi::@3#2] -- vbum1=vbuc1 + lda #1 + sta i + jmp __b3 + // Iterate through all digits and update the result + // [2314] phi from atoi to atoi::@3 [phi:atoi->atoi::@3] + __b2: + // [2314] phi atoi::negative#2 = 0 [phi:atoi->atoi::@3#0] -- vbum1=vbuc1 + lda #0 + sta negative + // [2314] phi atoi::res#2 = 0 [phi:atoi->atoi::@3#1] -- vwsm1=vwsc1 + sta res + sta res+1 + // [2314] phi atoi::i#4 = 0 [phi:atoi->atoi::@3#2] -- vbum1=vbuc1 + sta i + // atoi::@3 __b3: - // bram_ptr++; - // [3329] vera_compare::bram_ptr#1 = ++ vera_compare::bram_ptr#2 -- pbuz1=_inc_pbuz1 - inc.z bram_ptr - bne !+ - inc.z bram_ptr+1 - !: - // compared_bytes++; - // [3330] vera_compare::compared_bytes#1 = ++ vera_compare::compared_bytes#2 -- vwum1=_inc_vwum1 - inc compared_bytes - bne !+ - inc compared_bytes+1 - !: - // [3319] phi from vera_compare::@3 to vera_compare::@1 [phi:vera_compare::@3->vera_compare::@1] - // [3319] phi vera_compare::bram_ptr#2 = vera_compare::bram_ptr#1 [phi:vera_compare::@3->vera_compare::@1#0] -- register_copy - // [3319] phi vera_compare::equal_bytes#2 = vera_compare::equal_bytes#6 [phi:vera_compare::@3->vera_compare::@1#1] -- register_copy - // [3319] phi vera_compare::compared_bytes#2 = vera_compare::compared_bytes#1 [phi:vera_compare::@3->vera_compare::@1#2] -- register_copy - jmp __b1 - .segment DataVera - bank_ram: .byte 0 - .label return = equal_bytes - .label vera_byte = spi_read.return_3 - compared_bytes: .word 0 - /// Holds the amount of bytes actually verified between the VERA and the RAM. - equal_bytes: .word 0 -} -.segment CodeVera - // spi_read -spi_read: { - // unsigned char SPIData - // [3331] spi_read::SPIData = 0 -- vbum1=vbuc1 - /* - .proc spi_read - stz Vera::Reg::SPIData -@1: bit Vera::Reg::SPICtrl - bmi @1 - lda Vera::Reg::SPIData - rts -.endproc -*/ + // for (; str[i]>='0' && str[i]<='9'; ++i) + // [2315] if(atoi::str#2[atoi::i#4]<'0') goto atoi::@5 -- pbuz1_derefidx_vbum2_lt_vbuc1_then_la1 + ldy i + lda (str),y + cmp #'0' + bcc __b5 + // atoi::@6 + // [2316] if(atoi::str#2[atoi::i#4]<='9') goto atoi::@4 -- pbuz1_derefidx_vbum2_le_vbuc1_then_la1 + lda (str),y + cmp #'9' + bcc __b4 + beq __b4 + // atoi::@5 + __b5: + // if(negative) + // [2317] if(0!=atoi::negative#2) goto atoi::@1 -- 0_neq_vbum1_then_la1 + // Return result with sign + lda negative + bne __b1 + // [2319] phi from atoi::@1 atoi::@5 to atoi::@return [phi:atoi::@1/atoi::@5->atoi::@return] + // [2319] phi atoi::return#2 = atoi::return#0 [phi:atoi::@1/atoi::@5->atoi::@return#0] -- register_copy + rts + // atoi::@1 + __b1: + // return -res; + // [2318] atoi::return#0 = - atoi::res#2 -- vwsm1=_neg_vwsm1 lda #0 - sta SPIData - // asm - // asm { stzvera_reg_SPIData !: bitvera_reg_SPICtrl bmi!- ldavera_reg_SPIData staSPIData } - stz vera_reg_SPIData - !: - bit vera_reg_SPICtrl - bmi !- - lda vera_reg_SPIData - sta SPIData - // return SPIData; - // [3333] spi_read::return#3 = spi_read::SPIData -- vbum1=vbum2 - sta return_3 - // spi_read::@return + sec + sbc return + sta return + lda #0 + sbc return+1 + sta return+1 + // atoi::@return // } - // [3334] spi_read::return#4 = spi_read::return#3 - // [3335] return + // [2320] return rts - .segment DataVera - SPIData: .byte 0 - return: .byte 0 - return_1: .byte 0 - return_2: .byte 0 - return_3: .byte 0 + // atoi::@4 + __b4: + // res * 10 + // [2321] atoi::$10 = atoi::res#2 << 2 -- vwsz1=vwsm2_rol_2 + lda res + asl + sta.z atoi__10 + lda res+1 + rol + sta.z atoi__10+1 + asl.z atoi__10 + rol.z atoi__10+1 + // [2322] atoi::$11 = atoi::$10 + atoi::res#2 -- vwsz1=vwsz1_plus_vwsm2 + clc + lda.z atoi__11 + adc res + sta.z atoi__11 + lda.z atoi__11+1 + adc res+1 + sta.z atoi__11+1 + // [2323] atoi::$6 = atoi::$11 << 1 -- vwsz1=vwsz1_rol_1 + asl.z atoi__6 + rol.z atoi__6+1 + // res * 10 + str[i] + // [2324] atoi::$7 = atoi::$6 + atoi::str#2[atoi::i#4] -- vwsz1=vwsz1_plus_pbuz2_derefidx_vbum3 + ldy i + lda.z atoi__7 + clc + adc (str),y + sta.z atoi__7 + bcc !+ + inc.z atoi__7+1 + !: + // res = res * 10 + str[i] - '0' + // [2325] atoi::res#1 = atoi::$7 - '0' -- vwsm1=vwsz2_minus_vbuc1 + lda.z atoi__7 + sec + sbc #'0' + sta res + lda.z atoi__7+1 + sbc #0 + sta res+1 + // for (; str[i]>='0' && str[i]<='9'; ++i) + // [2326] atoi::i#2 = ++ atoi::i#4 -- vbum1=_inc_vbum1 + inc i + // [2314] phi from atoi::@4 to atoi::@3 [phi:atoi::@4->atoi::@3] + // [2314] phi atoi::negative#2 = atoi::negative#2 [phi:atoi::@4->atoi::@3#0] -- register_copy + // [2314] phi atoi::res#2 = atoi::res#1 [phi:atoi::@4->atoi::@3#1] -- register_copy + // [2314] phi atoi::i#4 = atoi::i#2 [phi:atoi::@4->atoi::@3#2] -- register_copy + jmp __b3 + .segment Data + .label res = return + // Initialize sign as positive + i: .byte 0 + return: .word 0 + // Initialize result + negative: .byte 0 } .segment Code - // rom_byte_compare + // cx16_k_macptr /** - * @brief Verify a byte with the flashed ROM using the 22 bit rom address. - * The lower 14 bits of the 22 bit ROM address are transformed into the **ptr_rom** 16 bit ROM address. - * The higher 8 bits of the 22 bit ROM address are transformed into the **bank_rom** 8 bit bank number. - * **bank_ptr* is used to set the bank using ZP $01. **ptr_rom** is used to write the byte into the ROM. + * @brief Read a number of bytes from the sdcard using kernal macptr call. + * BRAM bank needs to be set properly before the load between adressed A000 and BFFF. * - * @param address The 22 bit ROM address. - * @param value The byte value to be written. + * @return x the size of bytes read + * @return y the size of bytes read + * @return if carry is set there is an error */ -// __mem() char rom_byte_compare(__zp($4c) char *ptr_rom, __mem() char value) -rom_byte_compare: { - .label ptr_rom = $4c - // if (*ptr_rom != value) - // [3336] if(*rom_byte_compare::ptr_rom#0==rom_byte_compare::value#0) goto rom_byte_compare::@1 -- _deref_pbuz1_eq_vbum2_then_la1 - lda value - ldy #0 - cmp (ptr_rom),y - beq __b2 - // [3337] phi from rom_byte_compare to rom_byte_compare::@2 [phi:rom_byte_compare->rom_byte_compare::@2] - // rom_byte_compare::@2 - // [3338] phi from rom_byte_compare::@2 to rom_byte_compare::@1 [phi:rom_byte_compare::@2->rom_byte_compare::@1] - // [3338] phi rom_byte_compare::return#0 = 0 [phi:rom_byte_compare::@2->rom_byte_compare::@1#0] -- vbum1=vbuc1 - tya - sta return - rts - // [3338] phi from rom_byte_compare to rom_byte_compare::@1 [phi:rom_byte_compare->rom_byte_compare::@1] - __b2: - // [3338] phi rom_byte_compare::return#0 = 1 [phi:rom_byte_compare->rom_byte_compare::@1#0] -- vbum1=vbuc1 - lda #1 +// __mem() unsigned int cx16_k_macptr(__mem() volatile char bytes, __zp($56) void * volatile buffer) +cx16_k_macptr: { + .label buffer = $56 + // unsigned int bytes_read + // [2327] cx16_k_macptr::bytes_read = 0 -- vwum1=vwuc1 + lda #<0 + sta bytes_read + sta bytes_read+1 + // asm + // asm { ldabytes ldxbuffer ldybuffer+1 clc jsrCX16_MACPTR stxbytes_read stybytes_read+1 bcc!+ lda#$FF stabytes_read stabytes_read+1 !: } + lda bytes + ldx buffer + ldy buffer+1 + clc + jsr CX16_MACPTR + stx bytes_read + sty bytes_read+1 + bcc !+ + lda #$ff + sta bytes_read + sta bytes_read+1 + !: + // return bytes_read; + // [2329] cx16_k_macptr::return#0 = cx16_k_macptr::bytes_read -- vwum1=vwum2 + lda bytes_read sta return - // rom_byte_compare::@1 - // rom_byte_compare::@return + lda bytes_read+1 + sta return+1 + // cx16_k_macptr::@return // } - // [3339] return + // [2330] cx16_k_macptr::return#1 = cx16_k_macptr::return#0 + // [2331] return rts .segment Data - return: .byte 0 - value: .byte 0 + bytes: .byte 0 + bytes_read: .word 0 + .label return = fgets.bytes } .segment Code // ultoa_append @@ -22474,18 +14865,18 @@ rom_byte_compare: { // - sub : the value of a '1' in the digit. Subtracted continually while the digit is increased. // (For decimal the subs used are 10000, 1000, 100, 10, 1) // returns : the value reduced by sub * digit so that it is less than sub. -// __mem() unsigned long ultoa_append(__zp($45) char *buffer, __mem() unsigned long value, __mem() unsigned long sub) +// __mem() unsigned long ultoa_append(__zp($3c) char *buffer, __mem() unsigned long value, __mem() unsigned long sub) ultoa_append: { - .label buffer = $45 - // [3341] phi from ultoa_append to ultoa_append::@1 [phi:ultoa_append->ultoa_append::@1] - // [3341] phi ultoa_append::digit#2 = 0 [phi:ultoa_append->ultoa_append::@1#0] -- vbum1=vbuc1 + .label buffer = $3c + // [2333] phi from ultoa_append to ultoa_append::@1 [phi:ultoa_append->ultoa_append::@1] + // [2333] phi ultoa_append::digit#2 = 0 [phi:ultoa_append->ultoa_append::@1#0] -- vbum1=vbuc1 lda #0 sta digit - // [3341] phi ultoa_append::value#2 = ultoa_append::value#0 [phi:ultoa_append->ultoa_append::@1#1] -- register_copy + // [2333] phi ultoa_append::value#2 = ultoa_append::value#0 [phi:ultoa_append->ultoa_append::@1#1] -- register_copy // ultoa_append::@1 __b1: // while (value >= sub) - // [3342] if(ultoa_append::value#2>=ultoa_append::sub#0) goto ultoa_append::@2 -- vdum1_ge_vdum2_then_la1 + // [2334] if(ultoa_append::value#2>=ultoa_append::sub#0) goto ultoa_append::@2 -- vdum1_ge_vdum2_then_la1 lda value+3 cmp sub+3 bcc !+ @@ -22501,215 +14892,25 @@ ultoa_append: { lda value cmp sub bcs __b2 - !: - // ultoa_append::@3 - // *buffer = DIGITS[digit] - // [3343] *ultoa_append::buffer#0 = DIGITS[ultoa_append::digit#2] -- _deref_pbuz1=pbuc1_derefidx_vbum2 - ldy digit - lda DIGITS,y - ldy #0 - sta (buffer),y - // ultoa_append::@return - // } - // [3344] return - rts - // ultoa_append::@2 - __b2: - // digit++; - // [3345] ultoa_append::digit#1 = ++ ultoa_append::digit#2 -- vbum1=_inc_vbum1 - inc digit - // value -= sub - // [3346] ultoa_append::value#1 = ultoa_append::value#2 - ultoa_append::sub#0 -- vdum1=vdum1_minus_vdum2 - lda value - sec - sbc sub - sta value - lda value+1 - sbc sub+1 - sta value+1 - lda value+2 - sbc sub+2 - sta value+2 - lda value+3 - sbc sub+3 - sta value+3 - // [3341] phi from ultoa_append::@2 to ultoa_append::@1 [phi:ultoa_append::@2->ultoa_append::@1] - // [3341] phi ultoa_append::digit#2 = ultoa_append::digit#1 [phi:ultoa_append::@2->ultoa_append::@1#0] -- register_copy - // [3341] phi ultoa_append::value#2 = ultoa_append::value#1 [phi:ultoa_append::@2->ultoa_append::@1#1] -- register_copy - jmp __b1 - .segment Data - .label value = printf_ulong.uvalue - .label sub = ultoa.digit_value - .label return = printf_ulong.uvalue - digit: .byte 0 -} -.segment Code - // rom_wait -/** - * @brief Wait for the required time to allow the chip to flash the byte into the ROM. - * This is a core wait routine which is the most important routine in this whole program. - * Once a byte is flashed into the ROM, it takes time for the chip to actually flash the byte. - * The chip has implemented a loop mechanism to guarantee correct flashing of the written byte. - * It does this by requiring the execution of two sequential reads from the previously written ROM address. - * And loop those sequential reads until bit 6 of the 2 read bytes are equal. - * Once those two bits are equal, the chip has successfully flashed the byte into the ROM. - * - * - * @param ptr_rom The 16 bit pointer where the byte was written. This pointer is used for the sequence reads to verify bit 6. - */ -/* inline */ -// void rom_wait(__zp($2d) char *ptr_rom) -rom_wait: { - .label rom_wait__0 = $2b - .label rom_wait__1 = $29 - .label ptr_rom = $2d - // rom_wait::@1 - __b1: - // test1 = *((brom_ptr_t)ptr_rom) - // [3348] rom_wait::test1#1 = *rom_wait::ptr_rom#3 -- vbum1=_deref_pbuz2 - ldy #0 - lda (ptr_rom),y - sta test1 - // test2 = *((brom_ptr_t)ptr_rom) - // [3349] rom_wait::test2#1 = *rom_wait::ptr_rom#3 -- vbum1=_deref_pbuz2 - lda (ptr_rom),y - sta test2 - // test1 & 0x40 - // [3350] rom_wait::$0 = rom_wait::test1#1 & $40 -- vbuz1=vbum2_band_vbuc1 - lda #$40 - and test1 - sta.z rom_wait__0 - // test2 & 0x40 - // [3351] rom_wait::$1 = rom_wait::test2#1 & $40 -- vbuz1=vbum2_band_vbuc1 - lda #$40 - and test2 - sta.z rom_wait__1 - // while ((test1 & 0x40) != (test2 & 0x40)) - // [3352] if(rom_wait::$0!=rom_wait::$1) goto rom_wait::@1 -- vbuz1_neq_vbuz2_then_la1 - lda.z rom_wait__0 - cmp.z rom_wait__1 - bne __b1 - // rom_wait::@return - // } - // [3353] return - rts - .segment Data - test1: .byte 0 - test2: .byte 0 -} -.segment Code - // rom_byte_program -/** - * @brief Write a byte and wait until the byte has been successfully flashed into the ROM. - * - * @param address The 22 bit ROM address. - * @param value The byte value to be written. - */ -/* inline */ -// void rom_byte_program(__mem() unsigned long address, __mem() char value) -rom_byte_program: { - .label rom_ptr1_rom_byte_program__0 = $47 - .label rom_ptr1_rom_byte_program__2 = $47 - .label rom_ptr1_return = $47 - // rom_byte_program::rom_ptr1 - // (unsigned int)(address) & ROM_PTR_MASK - // [3355] rom_byte_program::rom_ptr1_$2 = (unsigned int)rom_byte_program::address#0 -- vwuz1=_word_vdum2 - lda address - sta.z rom_ptr1_rom_byte_program__2 - lda address+1 - sta.z rom_ptr1_rom_byte_program__2+1 - // [3356] rom_byte_program::rom_ptr1_$0 = rom_byte_program::rom_ptr1_$2 & $3fff -- vwuz1=vwuz1_band_vwuc1 - lda.z rom_ptr1_rom_byte_program__0 - and #<$3fff - sta.z rom_ptr1_rom_byte_program__0 - lda.z rom_ptr1_rom_byte_program__0+1 - and #>$3fff - sta.z rom_ptr1_rom_byte_program__0+1 - // ((unsigned int)(address) & ROM_PTR_MASK) + ROM_BASE - // [3357] rom_byte_program::rom_ptr1_return#0 = rom_byte_program::rom_ptr1_$0 + $c000 -- vwuz1=vwuz1_plus_vwuc1 - lda.z rom_ptr1_return - clc - adc #<$c000 - sta.z rom_ptr1_return - lda.z rom_ptr1_return+1 - adc #>$c000 - sta.z rom_ptr1_return+1 - // rom_byte_program::@1 - // rom_write_byte(address, value) - // [3358] rom_write_byte::address#3 = rom_byte_program::address#0 - // [3359] rom_write_byte::value#3 = rom_byte_program::value#0 - // [3360] call rom_write_byte - // [3212] phi from rom_byte_program::@1 to rom_write_byte [phi:rom_byte_program::@1->rom_write_byte] - // [3212] phi rom_write_byte::value#10 = rom_write_byte::value#3 [phi:rom_byte_program::@1->rom_write_byte#0] -- register_copy - // [3212] phi rom_write_byte::address#4 = rom_write_byte::address#3 [phi:rom_byte_program::@1->rom_write_byte#1] -- register_copy - jsr rom_write_byte - // rom_byte_program::@2 - // rom_wait(ptr_rom) - // [3361] rom_wait::ptr_rom#1 = (char *)rom_byte_program::rom_ptr1_return#0 -- pbuz1=pbuz2 - lda.z rom_ptr1_return - sta.z rom_wait.ptr_rom - lda.z rom_ptr1_return+1 - sta.z rom_wait.ptr_rom+1 - // [3362] call rom_wait - // [3347] phi from rom_byte_program::@2 to rom_wait [phi:rom_byte_program::@2->rom_wait] - // [3347] phi rom_wait::ptr_rom#3 = rom_wait::ptr_rom#1 [phi:rom_byte_program::@2->rom_wait#0] -- register_copy - jsr rom_wait - // rom_byte_program::@return - // } - // [3363] return - rts - .segment Data - .label address = rom_write_byte.address - .label value = rom_write_byte.value -} -.segment Code - // utoa_append -// Used to convert a single digit of an unsigned number value to a string representation -// Counts a single digit up from '0' as long as the value is larger than sub. -// Each time the digit is increased sub is subtracted from value. -// - buffer : pointer to the char that receives the digit -// - value : The value where the digit will be derived from -// - sub : the value of a '1' in the digit. Subtracted continually while the digit is increased. -// (For decimal the subs used are 10000, 1000, 100, 10, 1) -// returns : the value reduced by sub * digit so that it is less than sub. -// __mem() unsigned int utoa_append(__zp($3f) char *buffer, __mem() unsigned int value, __mem() unsigned int sub) -utoa_append: { - .label buffer = $3f - // [3365] phi from utoa_append to utoa_append::@1 [phi:utoa_append->utoa_append::@1] - // [3365] phi utoa_append::digit#2 = 0 [phi:utoa_append->utoa_append::@1#0] -- vbum1=vbuc1 - lda #0 - sta digit - // [3365] phi utoa_append::value#2 = utoa_append::value#0 [phi:utoa_append->utoa_append::@1#1] -- register_copy - // utoa_append::@1 - __b1: - // while (value >= sub) - // [3366] if(utoa_append::value#2>=utoa_append::sub#0) goto utoa_append::@2 -- vwum1_ge_vwum2_then_la1 - lda sub+1 - cmp value+1 - bne !+ - lda sub - cmp value - beq __b2 - !: - bcc __b2 - // utoa_append::@3 + !: + // ultoa_append::@3 // *buffer = DIGITS[digit] - // [3367] *utoa_append::buffer#0 = DIGITS[utoa_append::digit#2] -- _deref_pbuz1=pbuc1_derefidx_vbum2 + // [2335] *ultoa_append::buffer#0 = DIGITS[ultoa_append::digit#2] -- _deref_pbuz1=pbuc1_derefidx_vbum2 ldy digit lda DIGITS,y ldy #0 sta (buffer),y - // utoa_append::@return + // ultoa_append::@return // } - // [3368] return + // [2336] return rts - // utoa_append::@2 + // ultoa_append::@2 __b2: // digit++; - // [3369] utoa_append::digit#1 = ++ utoa_append::digit#2 -- vbum1=_inc_vbum1 + // [2337] ultoa_append::digit#1 = ++ ultoa_append::digit#2 -- vbum1=_inc_vbum1 inc digit // value -= sub - // [3370] utoa_append::value#1 = utoa_append::value#2 - utoa_append::sub#0 -- vwum1=vwum1_minus_vwum2 + // [2338] ultoa_append::value#1 = ultoa_append::value#2 - ultoa_append::sub#0 -- vdum1=vdum1_minus_vdum2 lda value sec sbc sub @@ -22717,207 +14918,114 @@ utoa_append: { lda value+1 sbc sub+1 sta value+1 - // [3365] phi from utoa_append::@2 to utoa_append::@1 [phi:utoa_append::@2->utoa_append::@1] - // [3365] phi utoa_append::digit#2 = utoa_append::digit#1 [phi:utoa_append::@2->utoa_append::@1#0] -- register_copy - // [3365] phi utoa_append::value#2 = utoa_append::value#1 [phi:utoa_append::@2->utoa_append::@1#1] -- register_copy + lda value+2 + sbc sub+2 + sta value+2 + lda value+3 + sbc sub+3 + sta value+3 + // [2333] phi from ultoa_append::@2 to ultoa_append::@1 [phi:ultoa_append::@2->ultoa_append::@1] + // [2333] phi ultoa_append::digit#2 = ultoa_append::digit#1 [phi:ultoa_append::@2->ultoa_append::@1#0] -- register_copy + // [2333] phi ultoa_append::value#2 = ultoa_append::value#1 [phi:ultoa_append::@2->ultoa_append::@1#1] -- register_copy jmp __b1 .segment Data - .label value = smc_detect.return - .label sub = utoa.digit_value - .label return = smc_detect.return + .label value = printf_ulong.uvalue + .label sub = ultoa.digit_value + .label return = printf_ulong.uvalue digit: .byte 0 } .segment Code - // memcpy8_vram_vram -/** - * @brief Copy a block of memory in VRAM from a source to a target destination. - * This function is designed to copy maximum 255 bytes of memory in one step. - * If more than 255 bytes need to be copied, use the memcpy_vram_vram function. - * - * @see memcpy_vram_vram - * - * @param dbank_vram Bank of the destination location in vram. - * @param doffset_vram Offset of the destination location in vram. - * @param sbank_vram Bank of the source location in vram. - * @param soffset_vram Offset of the source location in vram. - * @param num16 Specified the amount of bytes to be copied. - */ -// void memcpy8_vram_vram(__mem() char dbank_vram, __mem() unsigned int doffset_vram, __mem() char sbank_vram, __mem() unsigned int soffset_vram, __mem() char num8) -memcpy8_vram_vram: { - .label memcpy8_vram_vram__0 = $23 - .label memcpy8_vram_vram__1 = $24 - .label memcpy8_vram_vram__2 = $25 - .label memcpy8_vram_vram__3 = $26 - .label memcpy8_vram_vram__4 = $27 - .label memcpy8_vram_vram__5 = $28 - // *VERA_CTRL &= ~VERA_ADDRSEL - // [3371] *VERA_CTRL = *VERA_CTRL & ~VERA_ADDRSEL -- _deref_pbuc1=_deref_pbuc1_band_vbuc2 - lda #VERA_ADDRSEL^$ff - and VERA_CTRL - sta VERA_CTRL - // BYTE0(soffset_vram) - // [3372] memcpy8_vram_vram::$0 = byte0 memcpy8_vram_vram::soffset_vram#0 -- vbuz1=_byte0_vwum2 - lda soffset_vram - sta.z memcpy8_vram_vram__0 - // *VERA_ADDRX_L = BYTE0(soffset_vram) - // [3373] *VERA_ADDRX_L = memcpy8_vram_vram::$0 -- _deref_pbuc1=vbuz1 - sta VERA_ADDRX_L - // BYTE1(soffset_vram) - // [3374] memcpy8_vram_vram::$1 = byte1 memcpy8_vram_vram::soffset_vram#0 -- vbuz1=_byte1_vwum2 - lda soffset_vram+1 - sta.z memcpy8_vram_vram__1 - // *VERA_ADDRX_M = BYTE1(soffset_vram) - // [3375] *VERA_ADDRX_M = memcpy8_vram_vram::$1 -- _deref_pbuc1=vbuz1 - sta VERA_ADDRX_M - // sbank_vram | VERA_INC_1 - // [3376] memcpy8_vram_vram::$2 = memcpy8_vram_vram::sbank_vram#0 | VERA_INC_1 -- vbuz1=vbum2_bor_vbuc1 - lda #VERA_INC_1 - ora sbank_vram - sta.z memcpy8_vram_vram__2 - // *VERA_ADDRX_H = sbank_vram | VERA_INC_1 - // [3377] *VERA_ADDRX_H = memcpy8_vram_vram::$2 -- _deref_pbuc1=vbuz1 - sta VERA_ADDRX_H - // *VERA_CTRL |= VERA_ADDRSEL - // [3378] *VERA_CTRL = *VERA_CTRL | VERA_ADDRSEL -- _deref_pbuc1=_deref_pbuc1_bor_vbuc2 - lda #VERA_ADDRSEL - ora VERA_CTRL - sta VERA_CTRL - // BYTE0(doffset_vram) - // [3379] memcpy8_vram_vram::$3 = byte0 memcpy8_vram_vram::doffset_vram#0 -- vbuz1=_byte0_vwum2 - lda doffset_vram - sta.z memcpy8_vram_vram__3 - // *VERA_ADDRX_L = BYTE0(doffset_vram) - // [3380] *VERA_ADDRX_L = memcpy8_vram_vram::$3 -- _deref_pbuc1=vbuz1 - sta VERA_ADDRX_L - // BYTE1(doffset_vram) - // [3381] memcpy8_vram_vram::$4 = byte1 memcpy8_vram_vram::doffset_vram#0 -- vbuz1=_byte1_vwum2 - lda doffset_vram+1 - sta.z memcpy8_vram_vram__4 - // *VERA_ADDRX_M = BYTE1(doffset_vram) - // [3382] *VERA_ADDRX_M = memcpy8_vram_vram::$4 -- _deref_pbuc1=vbuz1 - sta VERA_ADDRX_M - // dbank_vram | VERA_INC_1 - // [3383] memcpy8_vram_vram::$5 = memcpy8_vram_vram::dbank_vram#0 | VERA_INC_1 -- vbuz1=vbum2_bor_vbuc1 - lda #VERA_INC_1 - ora dbank_vram - sta.z memcpy8_vram_vram__5 - // *VERA_ADDRX_H = dbank_vram | VERA_INC_1 - // [3384] *VERA_ADDRX_H = memcpy8_vram_vram::$5 -- _deref_pbuc1=vbuz1 - sta VERA_ADDRX_H - // [3385] phi from memcpy8_vram_vram memcpy8_vram_vram::@2 to memcpy8_vram_vram::@1 [phi:memcpy8_vram_vram/memcpy8_vram_vram::@2->memcpy8_vram_vram::@1] + // strncpy +/// Copies up to n characters from the string pointed to, by src to dst. +/// In a case where the length of src is less than that of n, the remainder of dst will be padded with null bytes. +/// @param dst ? This is the pointer to the destination array where the content is to be copied. +/// @param src ? This is the string to be copied. +/// @param n ? The number of characters to be copied from source. +/// @return The destination +// char * strncpy(__zp($4f) char *dst, __zp($34) const char *src, __mem() unsigned int n) +strncpy: { + .label dst = $4f + .label src = $34 + // [2340] phi from strncpy to strncpy::@1 [phi:strncpy->strncpy::@1] + // [2340] phi strncpy::dst#2 = ferror::temp [phi:strncpy->strncpy::@1#0] -- pbuz1=pbuc1 + lda #ferror.temp + sta.z dst+1 + // [2340] phi strncpy::src#2 = __errno_error [phi:strncpy->strncpy::@1#1] -- pbuz1=pbuc1 + lda #<__errno_error + sta.z src + lda #>__errno_error + sta.z src+1 + // [2340] phi strncpy::i#2 = 0 [phi:strncpy->strncpy::@1#2] -- vwum1=vwuc1 + lda #<0 + sta i + sta i+1 + // strncpy::@1 __b1: - // [3385] phi memcpy8_vram_vram::num8#2 = memcpy8_vram_vram::num8#1 [phi:memcpy8_vram_vram/memcpy8_vram_vram::@2->memcpy8_vram_vram::@1#0] -- register_copy - // the size is only a byte, this is the fastest loop! - // memcpy8_vram_vram::@1 - // while (num8--) - // [3386] memcpy8_vram_vram::num8#0 = -- memcpy8_vram_vram::num8#2 -- vbum1=_dec_vbum2 - ldy num8_1 - dey - sty num8 - // [3387] if(0!=memcpy8_vram_vram::num8#2) goto memcpy8_vram_vram::@2 -- 0_neq_vbum1_then_la1 - lda num8_1 - bne __b2 - // memcpy8_vram_vram::@return + // for(size_t i = 0;istrncpy::@3] + // [2346] phi strncpy::src#6 = strncpy::src#2 [phi:strncpy::@2/strncpy::@4->strncpy::@3#0] -- register_copy + // strncpy::@3 + __b3: + // *dst++ = c + // [2347] *strncpy::dst#2 = strncpy::c#0 -- _deref_pbuz1=vbum2 + lda c + ldy #0 + sta (dst),y + // *dst++ = c; + // [2348] strncpy::dst#0 = ++ strncpy::dst#2 -- pbuz1=_inc_pbuz1 + inc.z dst + bne !+ + inc.z dst+1 + !: + // for(size_t i = 0;istrncpy::@1] + // [2340] phi strncpy::dst#2 = strncpy::dst#0 [phi:strncpy::@3->strncpy::@1#0] -- register_copy + // [2340] phi strncpy::src#2 = strncpy::src#6 [phi:strncpy::@3->strncpy::@1#1] -- register_copy + // [2340] phi strncpy::i#2 = strncpy::i#1 [phi:strncpy::@3->strncpy::@1#2] -- register_copy jmp __b1 .segment Data - num8: .byte 0 - dbank_vram: .byte 0 - doffset_vram: .word 0 - sbank_vram: .byte 0 - soffset_vram: .word 0 - num8_1: .byte 0 -} -.segment CodeVera - // spi_fast -spi_fast: { - // asm - // asm { ldavera_reg_SPICtrl and#%11111101 stavera_reg_SPICtrl } - /* -.proc spi_fast - lda Vera::Reg::SPICtrl - and #%11111101 - sta Vera::Reg::SPICtrl - rts -.endproc -*/ - lda vera_reg_SPICtrl - and #$fd - sta vera_reg_SPICtrl - // spi_fast::@return - // } - // [3392] return - rts -} - // spi_select -spi_select: { - // spi_deselect() - // [3394] call spi_deselect - /* -.proc spi_select - jsr spi_deselect - - lda Vera::Reg::SPICtrl - ora #$01 - sta Vera::Reg::SPICtrl - rts -.endproc -*/ - jsr spi_deselect - // spi_select::@1 - // *vera_reg_SPICtrl |= 1 - // [3395] *vera_reg_SPICtrl = *vera_reg_SPICtrl | 1 -- _deref_pbuc1=_deref_pbuc1_bor_vbuc2 - lda #1 - ora vera_reg_SPICtrl - sta vera_reg_SPICtrl - // spi_select::@return - // } - // [3396] return - rts -} - // spi_write -/** - * @brief - * - * - */ -// void spi_write(__mem() volatile char data) -spi_write: { - // asm - // asm { ldadata stavera_reg_SPIData !: bitvera_reg_SPICtrl bmi!- } - /* -.proc spi_write - sta Vera::Reg::SPIData -@1: bit Vera::Reg::SPICtrl - bmi @1 - rts -.endproc -*/ - lda data - sta vera_reg_SPIData - !: - bit vera_reg_SPICtrl - bmi !- - // spi_write::@return - // } - // [3398] return - rts - .segment DataVera - data: .byte 0 + c: .byte 0 + i: .word 0 + n: .word 0 } // File Data -.segment Data /** * @file errno.c * @author Sven Van de Velde (sven.van.de.velde@telenet.be) @@ -22961,36 +15069,22 @@ spi_write: { .segment DataVera display_jp1_spi_vera_text: .word __34, str, __36, __37, __38, __39, __40, str, __42, __43, str, __45, __46, __47, str, __49 .segment Data - display_no_valid_smc_bootloader_text: .word __50, str, __52, __53, str, __55, __56, __57, __58 - display_smc_rom_issue_text: .word __59, str, __69, __62, str, __64, __65, __66 - display_smc_unsupported_rom_text: .word __67, str, __69, __70, str, __72, __73 - display_debriefing_text_smc: .word __88, str, main.text, str, __78, __79, __80, str, __82, str, __84, __85, __86, __87 - display_debriefing_text_rom: .word __88, str, __90, __91 + display_smc_rom_issue_text: .word __50, str, __60, __53, str, __55, __56, __57 + display_smc_unsupported_rom_text: .word __58, str, __60, __61, str, __63, __64 + display_debriefing_text_smc: .word __79, str, main.text, str, __69, __70, __71, str, __73, str, __75, __76, __77, __78 + display_debriefing_text_rom: .word __79, str, __81, __82 smc_file_header: .fill $20, 0 smc_version_text: .fill $10, 0 - // Globals - rom_device_ids: .byte 0 - .fill 7, 0 rom_device_names: .word 0 .fill 2*7, 0 rom_size_strings: .word 0 .fill 2*7, 0 rom_release_text: .fill 8*$d, 0 rom_release: .fill 8, 0 - rom_prefix: .fill 8, 0 - rom_github: .fill 8*8, 0 - rom_manufacturer_ids: .byte 0 - .fill 7, 0 - rom_sizes: .dword 0 - .fill 4*7, 0 - file_sizes: .dword 0 - .fill 4*7, 0 - rom_file_github: .fill 8*8, 0 - rom_file_release: .fill 8, 0 status_rom: .byte 0 .fill 7, 0 info_text: .fill $50, 0 - status_text: .word __92, __93, __94, smc_action_text_1, smc_action_text, __97, __98, __99, __100, __101, __102, __103 + status_text: .word __83, __84, __85, vera_read.vera_action_text_2, vera_read.vera_action_text_1, __88, __89, __90, __91, __92, __93, __94 status_color: .byte BLACK, GREY, WHITE, CYAN, PURPLE, CYAN, PURPLE, PURPLE, GREEN, YELLOW, RED, PINK __3: .text "Welcome to the CX16 update tool! This program updates the" .byte 0 @@ -23068,114 +15162,78 @@ spi_write: { .byte 0 __49: .text "The program continues once the JP1 pins are opened/closed." .byte 0 - __50: .text "The SMC chip in your CX16 doesn't have a valid bootloader." - .byte 0 - __52: .text "A valid bootloader is needed to update the SMC chip." - .byte 0 - __53: .text "Unfortunately, your SMC chip cannot be updated using this tool!" - .byte 0 - __55: .text "A bootloader can be installed onto the SMC chip using an" - .byte 0 - __56: .text "an Arduino or an AVR ISP device." - .byte 0 - __57: .text "Alternatively a new SMC chip with a valid bootloader can be" - .byte 0 - __58: .text "ordered from TexElec." - .byte 0 - __59: .text "There is an issue with the CX16 SMC or ROM flash readiness." + __50: .text "There is an issue with the CX16 SMC or ROM flash readiness." .byte 0 - __62: .text "to avoid possible conflicts of firmware, bricking your CX16." + __53: .text "to avoid possible conflicts of firmware, bricking your CX16." .byte 0 - __64: .text "Therefore, ensure you have the correct SMC.BIN and ROM.BIN" + __55: .text "Therefore, ensure you have the correct SMC.BIN and ROM.BIN" .byte 0 - __65: .text "files placed on your SDcard. Also ensure that the" + __56: .text "files placed on your SDcard. Also ensure that the" .byte 0 - __66: .text "J1 jumper pins on the CX16 board are closed." + __57: .text "J1 jumper pins on the CX16 board are closed." .byte 0 - __67: .text "There is an issue with the CX16 SMC or ROM flash versions." + __58: .text "There is an issue with the CX16 SMC or ROM flash versions." .byte 0 - __69: .text "Both the SMC and the main ROM must be updated together," + __60: .text "Both the SMC and the main ROM must be updated together," .byte 0 - __70: .text "to avoid possible conflicts, risking bricking your CX16." + __61: .text "to avoid possible conflicts, risking bricking your CX16." .byte 0 - __72: .text "The SMC.BIN and ROM.BIN found on your SDCard may not be" + __63: .text "The SMC.BIN and ROM.BIN found on your SDCard may not be" .byte 0 - __73: .text "mutually compatible. Update the CX16 at your own risk!" + __64: .text "mutually compatible. Update the CX16 at your own risk!" .byte 0 - __78: .text "Because your SMC chipset has been updated," + __69: .text "Because your SMC chipset has been updated," .byte 0 - __79: .text "the restart process differs, depending on the" + __70: .text "the restart process differs, depending on the" .byte 0 - __80: .text "SMC boootloader version installed on your CX16 board:" + __71: .text "SMC boootloader version installed on your CX16 board:" .byte 0 - __82: .text "- SMC bootloader v2.0: your CX16 will automatically shut down." + __73: .text "- SMC bootloader v2.0: your CX16 will automatically shut down." .byte 0 - __84: .text "- SMC bootloader v1.0: you need to " + __75: .text "- SMC bootloader v1.0: you need to " .byte 0 - __85: .text " COMPLETELY DISCONNECT your CX16 from the power source!" + __76: .text " COMPLETELY DISCONNECT your CX16 from the power source!" .byte 0 - __86: .text " The power-off button won't work!" + __77: .text " The power-off button won't work!" .byte 0 - __87: .text " Then, reconnect and start the CX16 normally." + __78: .text " Then, reconnect and start the CX16 normally." .byte 0 - __88: .text "Your CX16 system has been successfully updated!" + __79: .text "Your CX16 system has been successfully updated!" .byte 0 - __90: .text "Since your CX16 system SMC chip has not been updated" + __81: .text "Since your CX16 system SMC chip has not been updated" .byte 0 - __91: .text "your CX16 will just reset automatically after count down." + __82: .text "your CX16 will just reset automatically after count down." .byte 0 - __92: .text "None" + __83: .text "None" .byte 0 - __93: .text "Skip" + __84: .text "Skip" .byte 0 - __94: .text "Detected" + __85: .text "Detected" .byte 0 - __97: .text "Comparing" + __88: .text "Comparing" .byte 0 - __98: .text "Update" + __89: .text "Update" .byte 0 - __99: .text "Updating" + __90: .text "Updating" .byte 0 - __100: .text "Updated" + __91: .text "Updated" .byte 0 - __101: .text "Issue" + __92: .text "Issue" .byte 0 - __102: .text "Error" + __93: .text "Error" .byte 0 - __103: .text "Waiting" - .byte 0 - s: .text "Comparing: " - .byte 0 - s1: .text " differences between RAM:" + __94: .text "Waiting" .byte 0 s2: .text ":" .byte 0 - s3: .text " <-> ROM:" - .byte 0 - string_0: .text "Flashing ... (-) equal, (+) flashed, (!) error." - .byte 0 - info_text1: .text "Flashing ..." - .byte 0 - s4: .text " " - .byte 0 - chip: .text "ROM" + s: .text " " .byte 0 s5: .text " ... " .byte 0 - s6: .text " ..." - .byte 0 - s21: .text "[" - .byte 0 - info_text6: .text "No update required" - .byte 0 - s13: .text " differences!" - .byte 0 - smc_action_text: .text "Reading" - .byte 0 - smc_action_text_1: .text "Checking" - .byte 0 +.segment DataVera str: .text "" .byte 0 +.segment Data isr_vsync: .word $314 __conio: .fill SIZEOF_STRUCT___1, 0 // Buffer used for stringified number being printed @@ -23194,18 +15252,6 @@ spi_write: { .segment DataVera vera_file_size: .dword 0 .segment Data - // Globals (to save zeropage and code overhead with parameter passing.) - smc_bootloader: .word 0 - smc_release: .byte 0 - smc_major: .byte 0 - smc_minor: .byte 0 - smc_file_size: .word 0 - smc_file_release: .byte 0 - smc_file_major: .byte 0 - smc_file_minor: .byte 0 - smc_file_size_1: .word 0 - // Globals (to save zeropage and code overhead with parameter passing.) - smc_bootloader_1: .word 0 status_vera: .byte 0 .segment DataVera spi_manufacturer: .byte 0 diff --git a/target/src/cx16-update.klog b/target/src/cx16-update.klog index d7efce7..40c6ca1 100644 --- a/target/src/cx16-update.klog +++ b/target/src/cx16-update.klog @@ -15,22 +15,22 @@ Basic-segment: $0801-$080c Basic Code-segment: - $080d-$58a7 Code + $080d-$3478 Code Data-segment: - $58a8-$772f Data + $3479-$4b60 Data CodeIntro-segment: - $7730-$7780 CodeIntro + $4b61-$4bb1 CodeIntro CodeVera-segment: - $7781-$84c8 CodeVera + $4bb2-$585b CodeVera DataIntro-segment: - $84c9-$8506 DataIntro + $585c-$5899 DataIntro DataVera-segment: - $8507-$87ce DataVera + $589a-$5bf9 DataVera Writing Vice symbol file: cx16-update.vs Writing Symbol file: cx16-update.sym