Skip to content

Commit b0d2034

Browse files
committed
readme: cleanup
1 parent dbe424f commit b0d2034

File tree

2 files changed

+433
-155
lines changed

2 files changed

+433
-155
lines changed

README.md

+64-155
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
# esp-box-emu
2-
Emulator(s) running on ESP BOX with custom pcb and 3d printed enclosure :)
32

3+
Emulator(s) running on ESP BOX with custom pcb and 3d printed enclosure :)
44

55
https://user-images.githubusercontent.com/213467/236730090-56c3bd64-86e4-4b9b-a909-0b363fab4fc6.mp4
66

@@ -17,52 +17,6 @@ is built using the following:
1717
- Nofrendo (NES emulator)
1818
- GNUBoy (GB / GBC emulator)
1919

20-
## Videos
21-
22-
### Gameboy Color
23-
24-
This video shows settings page (with audio control and video scaling control), and then Links Awakening DX. While running the ROMs, the video scaling can be toggled through the three options (Original, Fit, and Fill) using the BOOT button on the side of the ESP-S3-BOX and the audio output can be toggled on / off using the MUTE button on the top.
25-
26-
https://user-images.githubusercontent.com/213467/202577104-da104296-c888-47f4-bb69-e1dcac7f3a08.mp4
27-
28-
### NES (Super Mario Bros. and Zelda, turning audio up for zelda :) )
29-
30-
https://user-images.githubusercontent.com/213467/200666734-d5fdd27e-d335-462b-9f27-c93c5750de01.mp4
31-
32-
https://user-images.githubusercontent.com/213467/201548463-9870a1c1-886c-4540-b1c6-c7ed3b49d8a5.mp4
33-
34-
### Gameboy (Pokemon and Links Awakening)
35-
36-
https://user-images.githubusercontent.com/213467/200667103-71425aa6-3e77-41b1-83d1-c2072a1a0ecb.mp4
37-
38-
Older Videos:
39-
* [heavily compressed](https://user-images.githubusercontent.com/213467/200664203-46058c44-3025-4e81-973f-27ada573d5d2.mp4)
40-
* [just zelda](https://user-images.githubusercontent.com/213467/199843965-1bf38a5f-2cc6-4ff0-adba-bbd67b366bc3.mp4)
41-
42-
## Images
43-
44-
<table style="padding:10px">
45-
<tr>
46-
<td><img src="./images/romgui_tloz.jpg" alt="Rom GUI: Zelda (NES)" width = 400px ></td>
47-
<td><img src="./images/zelda.jpeg" alt="Zelda (NES) emulated" width = 400px ></td>
48-
</tr>
49-
<tr>
50-
<td><img src="./images/zelda_its_dangerous.jpeg" alt="It's Dangerous To Go Alone, Take This!" width = 400px ></td>
51-
<td><img src="./images/zelda_sword.jpeg" alt="Zelda (NES) Get Sword" width = 400px ></td>
52-
</tr>
53-
<tr>
54-
<td><img src="./images/settingsgui.jpg" alt="Settings Screen (Audio Volume for now)" width = 400px></td>
55-
<td><img src="./images/romgui_smb3.jpg" alt="Super Mario Bros. 3 (NES)" width = 400px ></td>
56-
</tr>
57-
<tr>
58-
<td><img src="./images/romgui_pokemon_yellow.jpg" alt="Pokemon Yellow (GBC)" width = 400px ></td>
59-
<td><img src="./images/romgui_tloz_links_awakening.jpg" alt="Link's Awakening (GB)" width = 400px ></td>
60-
</tr>
61-
<tr>
62-
<td><img src="./images/squareline_studio.png" alt="Squareline Studio Design" width = 400px ></td>
63-
</tr>
64-
</table>
65-
6620
## Features
6721

6822
Note: for the ECAD + MCAD I'm using the free version of Fusion360.
@@ -80,43 +34,32 @@ The printable files can be found in the [./mcad](./mcad) folder or can be downlo
8034

8135
This project has the following features (still WIP):
8236

83-
- [x] Squareline Studio design files for generating boilerplate LVGL ([SQS files](./squareline), [Generated files](./components/gui/generated))
37+
- [x] Squareline Studio design files for generating boilerplate LVGL ([SLS files](./squareline), [Generated files](./components/gui/generated))
8438
- [x] LVGL gui for selecting emulators / roms (showing boxart and name)
85-
- [x] LVGL gui for controlling settings (such as volume) (using [gui component](./components/gui))
39+
- [x] LVGL gui for controlling settings (such as volume, video, haptics) (using [gui component](./components/gui))
8640
- [x] Loading of gui data (rom titles and boxart) from metadata file (example [here](./metadata.csv))
8741
- [x] Audio output (using I2S + es8311 audio codec, [es8311 component](./components/codec))
88-
- [x] Interaction with [QwiicNes NES gamepad](https://www.sparkfun.com/products/18038)
89-
- [x] Interaction with analog joystick + buttons (using [controller component](./components/controller))
90-
- [x] Interaction with d-pad + buttons (using [controller component](./components/controller))
42+
- [x] Interaction with d-pad + buttons (using [controller component](./components/controller))
9143
- [x] Interaction with touchscreen (using [tt21100 component](./components/tt21100))
9244
- [x] Navigation of LVGL rom menu with controller (up,down,start)
93-
- [ ] Runnable emulators (automatically selected by rom extension):
45+
- [x] Runnable emulators (automatically selected by rom extension):
9446
- [x] NES emulator (~100 FPS running Legend of Zelda)
9547
- [x] GB/GBC emulator (~100 FPS running Link's Awakening DX (GBC))
9648
- [ ] SNES emulator
9749
- [ ] SMS / Genesis emulator
98-
- [x] LittleFS file system for local storage of roms and metadata
99-
- [x] Support for uSD (FAT) filesystem over SPI
100-
- [x] Memory mapping of selected rom data from storage (littlefs or uSD) into
101-
raw data partition (SPIFLASH)
50+
- [x] uSD card (FAT) filesystem over SPI
51+
- [x] Memory mapping of selected rom data from storage into raw data partition
52+
(SPIFLASH)
10253
- [X] Emulator framebuffers on SPIRAM
103-
- [x] Some hacky support for BT Gamepad input (see note below regarding wifi use.)
104-
- [x] Refactor to have a blit function which queues up transfers for screen into a task
54+
- [x] Queued transfers of screen data for maximum draw speed while running emulation
10555
- [x] Scaling of GB/GBC display to support original, fit, and fill video scaling modes
10656
- [x] Scaling for NES display to support original (which is fit) and fill video scaling modes
10757
- [x] Use mute button to toggle volume output while running the roms
108-
- [x] Use boot button to switch between video scaling modes while running the roms
10958
- [x] Feedback through tiny haptic motor (DRV2605)
110-
- [x] Save state
59+
- [x] Save state (with automated save screenshot creation saved to uSD card)
11160
- [x] Load state
112-
- [ ] Feedback through BLDC haptic motor (see
113-
https://github.com/scottbez1/smartknob)
11461
- [x] State management (UI to select state when loading roms, ui/buttons for
115-
saving/loading states while running)
116-
- [ ] Favorites menu?
117-
- [ ] Recently played menu?
118-
- [ ] Show emulator with rom for easy sorting / finding
119-
- [ ] Graphics in black borders next to rom display during NES / GB/C emulation
62+
saving/loading states while running, and displaying save screenshots)
12063
- [x] Schematic / Layout for control board peripheral containing
12164
- [x] joystick / D-Pad / Button inputs (via i2c I/O expander / ADC)
12265
- [x] Battery
@@ -125,38 +68,19 @@ This project has the following features (still WIP):
12568
- [x] uSD card
12669
- [x] boost converter
12770
- [x] usb 2.0 passthrough from usb-c
128-
- [ ] TMC BLDC driver chip
129-
- [ ] ABI magnetic encoder chip
130-
- [ ] BLDC motor (haptics)
13171
- [x] CAD for control board peripheral case in the same footprint as GBC
13272
- [x] USB-C Port for programming / charging
13373
- [x] uSD card slot for roms
13474
- [x] start / select buttons (same location as GBC)
13575
- [x] ABXY buttons (basically same size / location as GBC)
13676
- [x] Directional Pad (same size / location as GBC)
13777
- [ ] Use same audio + video tasks for both NES and GB/C emulation
138-
- [ ] FTP Client for browsing remote FTP server of roms and displaying their
139-
data in LVGL
78+
- [ ] Graphics in black borders next to rom display during NES / GB/C emulation
14079

141-
### Support for dynamically loading emulators (TBD)
142-
143-
Down the line I'd like to add the ability to load the emulator cores from the
144-
FTP server (which would be pre-compiled ESP32 libraries) so that they wouldn't
145-
take up as much space on the ESP32 itself. Right now that's not a huge concern
146-
though because the ESP (S3 module in the ESP BOX especially) has more than
147-
enough flash for the emulators so assuming their RAM can be managed it won't be
148-
much of an issue.
149-
150-
Info for loading elf files at runtime:
151-
https://github.com/niicoooo/esp32-elfloader.
152-
[Here](https://github.com/joltwallet/jolt_wallet/tree/master/jolt_os/jelf_loader)
153-
is another implementation.
154-
15580
## Filsystem / Storage
15681

157-
The emu-box supports both on-board FLASH storage through LittleFS (limited to
158-
the 16 MB flash chip in the S3 in the box) as well as support for external FAT
159-
filesystems on a uSD card connected via SPI (this is the DEFAULT option):
82+
The emu-box supports external FAT filesystems on a uSD card connected via SPI
83+
(this is the DEFAULT option):
16084

16185
| uSD SPI | ESP32 GPIO (exposed via PMOD header) |
16286
|---------|--------------------------------------|
@@ -165,25 +89,6 @@ filesystems on a uSD card connected via SPI (this is the DEFAULT option):
16589
| MISO | 13 |
16690
| SCLK | 12 |
16791

168-
The storage can be changed via `menuconfig`.
169-
170-
### Using LittleFS (Internal FLASH):
171-
172-
You will need to set up a `flash_data/` folder which contains your roms (.nes,
173-
.gb, .gbc), images (.jpg), and metadata.csv. (See next section for more info
174-
about Rom Images and the metadata file). The contents of this folder will be
175-
flashed into the `littlefs` partition.
176-
177-
At least once, you'll need to update the
178-
[./main/CMakeLists.txt](./main/CMakeLists.txt) to uncomment the line that has
179-
`FLASH_IN_PROJECT` as part of the `littlefs_create_partition_image` command -
180-
this will flash all files in your `flash_data/` folder onto the `littlefs`
181-
partition on the embedded FLASH chip. Alternatively, you can use the
182-
`esptool.py`, `parttool.py` as mentioned in [the SPIFFS
183-
docs](https://docs.espressif.com/projects/esp-idf/en/latest/esp32/api-reference/storage/spiffs.html).
184-
185-
### Using FAT (external uSD card):
186-
18792
Format your uSD card as a FAT filesystem and add your roms (.nes, .gb, .gbc),
18893
images (.jpg), and metadata.csv. (See next section for more info about Rom
18994
Images and the metadata file). Make sure the uSD card is plugged into the socket
@@ -272,8 +177,9 @@ The ESP32S3 Box uses a capacitive touch controller connected via I2C.
272177

273178
The touch driver can be either the TT21100 or Ft5x06 chip.
274179

275-
NOTE: it appears the one I have (regular ESP32 S3 BOX) which has the red circle
276-
at the bottom of the display (the `HOME` button) uses the TT21100 chip.
180+
NOTE: it appears the one I have is the regular ESP32 S3 BOX which has the red
181+
circle at the bottom of the display (the `HOME` button) and uses the TT21100
182+
chip.
277183

278184
#### Audio
279185

@@ -301,50 +207,6 @@ I2C Pinout (shared with touchscreen chip above):
301207
| SCL | 18 |
302208
| SDA | 8 |
303209

304-
### Controllers
305-
306-
#### Sparkfun QwiicNES
307-
308-
The Sparkfun QwiicNES ([product page](https://www.sparkfun.com/products/18038),
309-
[library](https://github.com/sparkfun/SparkFun_QwiicNES_Arduino_Library)) is a
310-
NES controller adapter that supports direct GPIO and I2C. The
311-
[controller](./components/controller) component we have supports direct GPIO
312-
configuration if you choose to use it (find the configuration in the
313-
[./components/box-emu-hal/src/input.cpp](./components/box-emu-hal/src/input.cpp)).
314-
315-
It also however has a ATmega 32u4 which allows it to act as a USB gamepad and
316-
exposes the NES gamepad over I2C as well. For ease of use, the I2C functionality
317-
has been wrapped into a [qwiicnes component](./components/qwiicnes). There is an
318-
example of using this qwiicnes component in the component's example folder.
319-
320-
#### Joy bonnet
321-
322-
The [joy bonnet](https://pinout.xyz/pinout/joy_bonnet) was designed as a
323-
raspberry pi hat which has abxy, start/select, analog joystick, and player 1 /
324-
player 2 buttons. It's useful for prototyping input / hardware and testing how
325-
well the emulators run (by playing them of course ;) )
326-
327-
The joystick is routed out via an ADS1015 I2C ADC chip (addr 0x48), with the
328-
__Y-axis__ mapped to __channel 0__, and the __X-axis__ mapped to __channel 1__.
329-
[see
330-
here](https://github.com/adafruit/Adafruit-Retrogame/blob/master/joyBonnet.py)
331-
332-
Pinout (pin number is w.r.t. header, not pi GPIO):
333-
334-
| Button | Joy Bonnet Header Pin Number |
335-
|---------|------------------------------|
336-
| A | 32 |
337-
| B | 31 |
338-
| X | 36 |
339-
| Y | 33 |
340-
| Start | 37 |
341-
| Select | 38 |
342-
| Ground | 6, 9, 14, 20, 25, 30, 34, 39 |
343-
| 5V | 2, 4 |
344-
| 3V3 | 1, 17 |
345-
| I2C SDA | 3 |
346-
| I2C SCL | 5 |
347-
348210
### Other NES Emulators
349211
* https://github.com/nesemu/NESemu
350212
* https://github.com/NiwakaDev/NIWAKA_NES
@@ -368,3 +230,50 @@ Pinout (pin number is w.r.t. header, not pi GPIO):
368230
* [NES Signal Reference](https://wiki.nesdev.com/w/index.php/Standard_controller)
369231
* [Genesis Signal Reference](https://www.raspberryfield.life/2019/03/25/sega-mega-drive-genesis-6-button-xyz-controller/)
370232
* [DIY Gameboy](https://learn.adafruit.com/pigrrl-raspberry-pi-gameboy/overview)
233+
234+
## Videos
235+
236+
### Gameboy Color
237+
238+
This video shows settings page (with audio control and video scaling control), and then Links Awakening DX. While running the ROMs, the video scaling can be toggled through the three options (Original, Fit, and Fill) using the BOOT button on the side of the ESP-S3-BOX and the audio output can be toggled on / off using the MUTE button on the top.
239+
240+
https://user-images.githubusercontent.com/213467/202577104-da104296-c888-47f4-bb69-e1dcac7f3a08.mp4
241+
242+
### NES (Super Mario Bros. and Zelda, turning audio up for zelda :) )
243+
244+
https://user-images.githubusercontent.com/213467/200666734-d5fdd27e-d335-462b-9f27-c93c5750de01.mp4
245+
246+
https://user-images.githubusercontent.com/213467/201548463-9870a1c1-886c-4540-b1c6-c7ed3b49d8a5.mp4
247+
248+
### Gameboy (Pokemon and Links Awakening)
249+
250+
https://user-images.githubusercontent.com/213467/200667103-71425aa6-3e77-41b1-83d1-c2072a1a0ecb.mp4
251+
252+
Older Videos:
253+
* [heavily compressed](https://user-images.githubusercontent.com/213467/200664203-46058c44-3025-4e81-973f-27ada573d5d2.mp4)
254+
* [just zelda](https://user-images.githubusercontent.com/213467/199843965-1bf38a5f-2cc6-4ff0-adba-bbd67b366bc3.mp4)
255+
256+
## Images
257+
258+
<table style="padding:10px">
259+
<tr>
260+
<td><img src="./images/romgui_tloz.jpg" alt="Rom GUI: Zelda (NES)" width = 400px ></td>
261+
<td><img src="./images/zelda.jpeg" alt="Zelda (NES) emulated" width = 400px ></td>
262+
</tr>
263+
<tr>
264+
<td><img src="./images/zelda_its_dangerous.jpeg" alt="It's Dangerous To Go Alone, Take This!" width = 400px ></td>
265+
<td><img src="./images/zelda_sword.jpeg" alt="Zelda (NES) Get Sword" width = 400px ></td>
266+
</tr>
267+
<tr>
268+
<td><img src="./images/settingsgui.jpg" alt="Settings Screen (Audio Volume for now)" width = 400px></td>
269+
<td><img src="./images/romgui_smb3.jpg" alt="Super Mario Bros. 3 (NES)" width = 400px ></td>
270+
</tr>
271+
<tr>
272+
<td><img src="./images/romgui_pokemon_yellow.jpg" alt="Pokemon Yellow (GBC)" width = 400px ></td>
273+
<td><img src="./images/romgui_tloz_links_awakening.jpg" alt="Link's Awakening (GB)" width = 400px ></td>
274+
</tr>
275+
<tr>
276+
<td><img src="./images/squareline_studio.png" alt="Squareline Studio Design" width = 400px ></td>
277+
</tr>
278+
</table>
279+

0 commit comments

Comments
 (0)