# EclaireXL - Feature #76

# Merge down to trunk

10/05/2018 09:17 PM - foft

| Status:                                                                         | Resolved | Start date:     | 10/05/2018 |  |
|---------------------------------------------------------------------------------|----------|-----------------|------------|--|
| Priority:                                                                       | High     | Due date:       |            |  |
| Assignee:                                                                       |          | % Done:         | 0%         |  |
| Category:                                                                       |          | Estimated time: | 0:00 hour  |  |
| Target version:                                                                 |          |                 |            |  |
| Description                                                                     |          |                 |            |  |
| Several requests to get some of these features back up and running on the mist. |          |                 |            |  |

# History

### #1 - 10/05/2018 09:17 PM - foft

- Tracker changed from Bug to Feature

# #2 - 10/07/2018 03:21 PM - foft

- Subject changed from MIST backport to Merge down to trunk

# #3 - 10/07/2018 03:30 PM - foft

- Priority changed from Normal to High

Keen to get this work back on the mainline.

# #4 - 10/07/2018 03:30 PM - foft

This will probably break many (other platform) core builds on trunk in the short term...

# #5 - 10/13/2018 08:32 PM - foft

- Status changed from New to In Progress

Made an svn copy of existing trunk (branches/releases/trunk\_20181013\_premerge) Also made a backup of lots of random local stuff on my trunk checkout! Going to merge down the entire eclaireXL branch and start working on trunk. This will break a lot, since there are a lot of specific eclaire firmware features for instance.

# #6 - 10/13/2018 08:57 PM - foft

Easy part done, merged down.

For now I branched firmware into firmware\_eclairexI and firmware\_legacy (for other platforms). However common is probably incompatible with the other core builds to some degree... Probably nothing too major.

# #7 - 02/20/2019 10:44 PM - foft

György spurred me on by fixing the mist for 5200.

I've merged his changes.

I've also made a start at getting other cores building. So far mcc216 builds. Firmware is going to need merging to make these work though, but having them build is a good step...

# #8 - 02/25/2019 09:54 PM - foft

Allowed targets without usb to build. The code expected the 48MHz clock to generate the 1MHz tick, which needed to be more accurate for atx support.

## #9 - 03/01/2019 10:03 PM - foft

Got the legacy firmware to work against the new hardware. At least the mcc216 is working in a8 mode...

Unfortunately need to save a few hundred bytes to fit atx support.

# #10 - 03/01/2019 10:14 PM - foft

Trying to program 5200 ntsc... getting there, but not quite!

### #11 - 03/05/2019 09:56 PM - foft

5200 ntsc is working on mcc. Trying to merge the two firmwares...

So menu structure is different, flash support and pll support. Commenting those and it builds, except its too large for some targets (>32k).

Probably need to write a simple generic menu thing and use it instead of this massive hack.

### #12 - 03/08/2019 10:24 PM - foft

Trying to get the 40k eclaire rom working 'as is' on the mcc now. All building ... but ...its erasing my sd card! Hmmm, what is going on here...

### #13 - 04/01/2019 10:34 PM - foft

Now trying to get Chameleon 1 back up and running ... before moving onto Chameleon 2. So far got the Atari screen but sio seems broken for some reason.

### #14 - 04/02/2019 10:11 PM - foft

sio on chameleon was just a missed new pin (io clock). Done most of chameleon2 wiring with the new helpers... Just a few things remain then I can try it:

- 8MHz->50MHz in plls
- Assign pins in qsf
- · Solder on jtag
- Change device to cyclone 10 in qsf
- Cross fingers!

### #15 - 04/02/2019 10:16 PM - foft

Getting closer!

- 8MHz->50MHz in plls
- DONE:Assign pins in qsf
- Solder on jtag
- DONE:Change device to cyclone 10
- Install cyclone 10 support to quartus
- Cross fingers!

### #16 - 04/02/2019 10:24 PM - foft

Enough for today!

- 8MHz->50MHz in plls
- DONE:Assign pins in qsf
- Solder on jtag
- DONE:Change device to cyclone 10
- DONE:Install cyclone 10 support to quartus
- Upgrade all ip to cyclone 10
- Cross fingers!

### #17 - 04/23/2019 10:10 PM - foft

Continuing chameleon bring up on <u>#78</u>

### #18 - 05/25/2019 08:00 PM - foft

I think chameleon 1 and chameleon 2 are good. firmware\_eclaire is running on them and also on the eclaire.

Heading back to some other targets soon.

## #19 - 05/28/2019 10:28 PM - foft

Building the mcc216 with this latest firmware + plumbing changes. Realized the scandoubler will not fit in the memory at the same time as this larger firmware, arg!

### #20 - 05/28/2019 10:45 PM - foft

freezer 1024 1 antic 1536 1

| scandouble    | er1  | 1460 | 0 2 |
|---------------|------|------|-----|
| scandouble    | er2  | 1460 | 02  |
| zpu rom       | 327  | 7680 | 40  |
| zpu ram       | 16   | 384  | 2   |
| " 16          | 384  | 2    |     |
| " 16          | 384  | 2    |     |
| " 16          | 384  | 2    |     |
| sio fifo rx 3 | 3840 | ) 1  |     |
| sio fifo tx 2 | 2048 | 31   |     |
| usb fifo rx   | 512  | 21   |     |
| usb fifo tx   | 512  | 2 1  |     |

total ... 58. Perhaps I can specify the fifo to use logic elements instead. Or back to shrinking that zpu rom... Really should be able to get it into 32k!

#### #21 - 06/04/2019 10:34 PM - foft

Tried building with riscv and the firmware size dropped from 37KB to <32KB. Which is great! So might need to reactivate the zpu->riscv plan...

#### #22 - 06/07/2019 09:39 PM - foft

That was with 64-bit riscv, switched to the 32-bit version and its bigger: 39512

#### #23 - 06/07/2019 09:53 PM - foft

-flto gets me to 33244

# #24 - 06/09/2019 11:31 PM - foft

Experimenting with replacing the menu with a simple structure/code approach, should cut code size somewhat.

### #25 - 06/12/2019 10:31 PM - foft

Haha, working and much neater, but 300 bytes more

#### #26 - 06/12/2019 10:52 PM - foft

Probably split into too many functions, adding function call overhead...

Anyway should probably target some of these big items: nm --print-size --size-sort --radix=d ECLAIREXL.elf | less

0007457 00000527 T tfp\_format 00012850 00000571 T flash rpd 00003149 00000617 t follow\_path 00003760 00000627 T pf mount 00032220 00000633 T usb\_dispatchPktWithData 00018367 00000656 T handleRead 00009291 00000685 T display menu 00005062 00000720 T pf readdir 00033905 00000769 T usb poll 00016633 00000915 T set drive status 00006091 00001083 T file\_selector 00019667 00001179 T loadAtxSector 00029689 00001464 T parse\_report\_descriptor 00058972 00001568 B devices 00021992 00001880 t usb\_hid\_parse\_conf 00023478 00003296 t usb hid init 00026289 00004307 t usb\_hid\_poll

### #27 - 06/15/2019 10:26 AM - foft

Need to save 6k. Lots of complexity in the USB, largely for supporting the custom mcc joysticks. I could comment them but its mostly for the MCC that I have memory issues so I want to support the official joypads!

Idea: Really USB pollling is simple, send an in request then a byte stream is returned with some bits set/unset (buttons) and signed/unsigned values (axes). Could store a file with a mapping in per vid/iid and have simple code to apply. So we simplify structure and use files for custom devices.

### #28 - 06/15/2019 10:28 AM - foft

Perhaps I could even write byte stream to a hardware buffer and have regs for axis offset, axis type (signed/unsigned), button offset. Then poll becomes just sending an in request and writing to this hardware buffer. init becomes initializing these regs from a vid named file (optional) or decoding HID.

### #29 - 06/15/2019 10:29 AM - foft

Perhaps a state machine to do the in request too, then I do not even need to call poll.

### #30 - 06/21/2019 08:20 PM - foft

Saved some memory in USB and also saved some memory by disabling flash. Now fits in 36K on MCC, with a little space. Will do for this board, can save the things I thought of above for later!

### #31 - 06/21/2019 10:31 PM - foft

mcc\_5200 seems fine (minimal changes here). Next up mcctv... Tried to merge diff and quite a lot of failed hunks, will have to do manually.

### #32 - 06/22/2019 09:06 PM - foft

mcctv 800xl and 5200 working

### #33 - 06/22/2019 09:50 PM - foft

mist 800xl is working. Skipping mist 5200 since it has been converted into a zpu-free core by György

### #34 - 06/22/2019 09:59 PM - foft

That is really the main existing boards that worked well. Might do a release build with this state.

After which these remain...

- 1. papilio duo simple port. Since its xilinx will need to fix the fifo (using Intel IP...)
- 2. fpgaarcade never did a decent port but am keen to wire it up properly
- 3. de1 will probably limit to: pure de1, de1 with 'standard' joystick ports and skip my breakout boards. I imagine anyone who has them not has the real deal (i.e. eclaireXL).
- 4. sockit keen to try the ddr3 ram and also the hps->fpga pin rererouting stuff.
- 5. aeon lite if my soldering still works!

# #35 - 06/22/2019 11:21 PM - foft

Released a first cut of them here <u>http://www.64kib.com/autobuild/20190622/</u> See <u>http://www.64kib.com/autobuild/changes.txt</u>

### #36 - 06/24/2019 11:07 PM - foft

Trying to get pll switching working on other boards (different ip than on cyclone v)...

### #37 - 06/26/2019 10:08 PM - foft

So near and yet so far... Re-configures and still have ready screen at slightly different frequency. But ZPU and 6502 seem to have locked solid. Not sure why, I'm freezing the clock and holding reset high. Must be some kind of glitch I guess.

# #38 - 06/26/2019 10:11 PM - foft

Freezing/restarting all the clocks with my state machine works just fine. I wonder if the reconfig somehow destroys the phase relationship between the clocks or something.

Plan:

- i) Create another high frequency clock with the USB PLL (not reconfigured)
- ii) Delete the non-pll stuff to make space
- iii) Add a signal tap logic analyzer to look at the clocks
- iv) Profit!

# #39 - 06/26/2019 10:52 PM - foft

Results are in, think its sync between the clocks

### #40 - 06/27/2019 10:33 PM - foft

OK, don't think it was that.

Wrote a much better state machine, configure pll 1 while pll 2 is in reset, wait for it to no longer be busy, wait for it to sync, wait a bit longer for luck, then onto the same for pll 2. Didn't work...

Then messed around a lot and got something working. I do not actually need to reconfigure pll2 (downstream pll) and just re-configuring upstream while resetting downstream works!! I do not understand it but am happy to have a solution.

Trying to wire it up to pal signal so I can switch back and forth.

### #41 - 06/27/2019 10:37 PM - foft

reset to put back original settings does not crash, but does not put back settings!

# #42 - 06/30/2019 07:41 PM - foft

PAL/NTSC switching canned test is working on mcctv:-)

# #43 - 07/02/2019 10:52 PM - foft

Wired up svideo\_gtia while I'm at it (i.e. direct palette to svideo, rather than via rgb), looks a bit better... Was mostly since the ntsc palette was not correctly supported.

# #44 - 07/02/2019 10:53 PM - foft

Last thing to finish up this mcctv version is to make profiles work on the sdcard I guess, one for another day.

### #45 - 09/11/2019 10:21 PM - foft

I added sd card profiles a while back

### #46 - 09/23/2021 08:45 PM - foft

- Status changed from In Progress to Resolved

Been back on trunk for years now, should close this!