For user manual and purchasing please visit: https://www.ddzheng.cc/?page_id=666
Table of Contents
Update 13 Feb. 2025:
The first batch run has finished. This will be also PVT. change to reverse mounted 1206 led on bottom side.
data:image/s3,"s3://crabby-images/f2691/f26914c9df42ab4197079fb696b775c5905b6788" alt=""
data:image/s3,"s3://crabby-images/ac57f/ac57f183c8542309a1384f722c4ab234cb2ba5a7" alt=""
Update 29 Jan 2025:
Out of advice from Gearspace user I will add a header footprint for remote mounted button.
I added ability to wake up WiFi using Bluetooth LE. The operation is done by using a smartphone and attempt to connect to the board. The connection will wake up WiFi and at same time kill BLE process in ESP32, this will cause the connection to fail. This is done on purpose so an app is not needed to wake the WiFi, and you won’t have to un-pair the Bluetooth device each time.
Well, here it is
This project has taken too long but it’s finally complete and ready to use and I’ll make everything open source at a later time.
data:image/s3,"s3://crabby-images/e43bc/e43bc47f799c61fa210d8eaa7587b9a8e3642ce2" alt=""
data:image/s3,"s3://crabby-images/36490/364906c88ffd11e10732b1e27212b89c7e697062" alt=""
The SR-JV80 Expansion Card
The Roland JV series synthesizer were a legend of their time. Most of those synthesizers can accept 1 or more SR-JV80 series expansion card.
data:image/s3,"s3://crabby-images/56987/56987014e212b28d2da2bef15b940be26554024e" alt=""
data:image/s3,"s3://crabby-images/80cfe/80cfedad593a3529200b303038f84821139d1d08" alt=""
Roland has made some great sounds in these cards. According to most material there are 19 cards made by Roland. As time progresses these cards has become unobtanium and extremely expensive (especially in China, a card usually calls for $60 to $200). A list of expansion card can be seen at Edward DTech’s site: https://www.dtech.lv/techarticles_roland_exp.html
The Roland JV-80, JV-90, JV-1000, JV-880, and JV-1010 synths from the JV series can be expanded with 1 SR-JV80 wave expansion board, as can the JD-990 and the Fantom FA-76. The XP-30 and XV-88 can accept up to 2. The XP-50, XP-60, XP-80, JV-1080, XV-3080, and XV-5080 can accept up to 4. The JV-2080 can accept up to 8.
There are products available to act as re-writable SR-JV80 card but they are equally as expensive and from my view, not as user friendly.
data:image/s3,"s3://crabby-images/dec21/dec21a05a0612205e0b01ad7faf5e08a32ffe785" alt=""
Now these cards are relatively simple, they consist of 8MB of ROM and that’s it. It’s connected to the sound generation part of synthesizer via the 40-pin connector. It then act as wave ROM and the sound engine can retrieve samples and patch data from it.
data:image/s3,"s3://crabby-images/57ede/57ede855f1c1f3af8cc0a5398eb16ff2431cbef7" alt=""
data:image/s3,"s3://crabby-images/f378c/f378c5c59c72f34777bf76593a132c18f3476981" alt=""
The Project
Blackbox
The expansion interface and the synthesizer is essentially a giant blackbox system which we cannot know exactly how it operates. And one thing for sure is that the connector is nowhere to get. After some research I find the SCSI 40-pin all plastic connector which fits the expansion connector perfectly after some filing of the edges.
data:image/s3,"s3://crabby-images/4fb8d/4fb8dda4aeed018655f826739092ee94741c664c" alt=""
The connector pinout can be gathered from the schematic and PCB image in service manual.
The physical form factor is another problem. Since I don’t even have a real card on hand, I used some of the high-res photo I found on the internet and used photoshop to correct the image and took some measurement. I then put the drawings in KiCAD.
data:image/s3,"s3://crabby-images/fa89f/fa89f70725f94f1a1b9f14e07b703e402774c537" alt=""
Defining the System and Design the Schematic
I’ve defined the requirements for this project as follows:
- This product will have a re-writable memory (EEPROM or flash memory, as opposed to mask rom or OTP ROM)
- This product will have a Wi-Fi interface so that one don’t need to remove it from the synthesizer to reprogram it
- It need to conform to the original SR-JV80 expansion card form factor and be able to install in the synth without modifying the synth
For the main processor, as I’ve previously used Espressif products, I decided to use ESP32-S3 as the processor of the card. I decided on the WROOM module.
data:image/s3,"s3://crabby-images/4c17b/4c17b33ae3a656d982cf53e36ca4ce8d7b3af9a4" alt=""
Because the original SR-JV80 expansion card has 4 2MB ROM, the Sector101’s Romulator use the same structure, utilizing 4 flash chips.
data:image/s3,"s3://crabby-images/f55c3/f55c3f197d7803242db310d7f0a19514156ca289" alt=""
I decided to ditch this solution and use one 8MB(64M) flash. I selected the Cypress (Spansion) S29GL064 and MXIC MX29LV640E.
data:image/s3,"s3://crabby-images/27531/275312af60839fcdf031c71d383760268530122d" alt=""
The interface has one chip select line for each chip. This means I’ll need to translate 4 mutually exclusive active low input to 2 active high output (4 to 2 encoder), which can be realized with XOR gate. I selected 74HC86.
data:image/s3,"s3://crabby-images/2f4d7/2f4d7cc13db2f7d5e3d1e96109a644437a814cd7" alt=""
At this capacity level there are only 3.3V flash available, but since I need to be able to isolate the synthesizer interface from the card to be able to program it in-place anyway, this won’t be a problem. The data and address lines on the 3.3V side will connect to processor for erasing and programming. On the 5V side they connect to the interface. This is done using 4x 74LVC8T245.
data:image/s3,"s3://crabby-images/916f7/916f7711fc6fb604d1dc35ec37ff3b0c904e3e44" alt=""
There isn’t enough IO on the ESP32 so I decided on the first version to use a IO expander, which turns out to be way too slow. So I later changed to 74HC595 and eventually 74HCS595. Driving these with the SPI interface it can reach a clock speed of 20MHz or more (Max available from ESP32 is 80M but I don’t think it’s possible with the HCS logic family).
data:image/s3,"s3://crabby-images/33e66/33e66f298822509655c1c6305b89f80f74fc2e44" alt=""
Finally power management with a 1117, a USB port, a program port, a button, 2 LEDs, and a MOSFET for controlling the card present sense pin is added.
data:image/s3,"s3://crabby-images/31faa/31faaa7eeb08129c3bb71faab4d53958b5049028" alt=""
data:image/s3,"s3://crabby-images/7321f/7321f61a6e7a4802bdee2f5675aa6754a809c6c8" alt=""
data:image/s3,"s3://crabby-images/fb4f2/fb4f27c95c4fbee1edc567d728f9ca7acc169a94" alt=""
The OE and CE of the flash is configurable to pull-up or pull-down, together with mounting the diodes or not it can control the behavior of the bus controls.
data:image/s3,"s3://crabby-images/00cc0/00cc0ffa14c8bb38217ece51822c212e954e63f6" alt=""
Layout
There are 3 versions as of now:
- Test board version 1 with IO expander. Occupies 2 card slots.
- Test board with 74HC595 and no 74HC08. Occupies 2 card slots.
- Board with current design, occupying 1 slot and same profile as real card.
Laying out the board is a painful process as there are so many wires. Luckily with KiCAD’s shove routing and long-lat top-bottom strategy it can be done without too much of a hassle.
For the current version I’m using 4-layer board but it can also be fabricated with 2 layers only since the internal layers are only just power and ground, which is also present on top and bottom layer.
data:image/s3,"s3://crabby-images/f0dcc/f0dccfc3e1d8df10c3e1b5747d68ab09735d1f05" alt=""
Fabrication and Testing
I manufactured the boards at JLCPCB. I have JLCPCB assemble the basic parts like LDO, RCL, and anything else that doesn’t require feeder changing fee in their SMT process.
data:image/s3,"s3://crabby-images/68800/688004f35940c2239e4a6c9b932248fbdda14d52" alt=""
For testing I bought N8R8 version (8MB Flash, 8MB PSRAM) of the ESP32S3-WROOM.
On the first version (IO expander) I quickly realized it won’t work due to the slow speed of the IO expander. So I quickly spun the next test board version. However under the influence of the scramble scheme of these ROM, I connected the address and data wires all wrong. So I had to airwire all those lines at the 5V side. Luckily I put 0R resistor in series with the 5V signals on the test boards.
data:image/s3,"s3://crabby-images/db872/db872eb15b1fa5f734a7f01efbdbceb587a1de9a" alt=""
On this version I tested for all functionality and did some signal measurement. On these first versions I didn’t manage the CE lines from the interface however since those are CE lines there are no overall CE available after encoding (can’t distinguish between address 00 or no CE active). This resulted in one card shown as 4 identical cards in my XP-80 due to the WOE line is shared between cards. I only made one test board but there definitely will be bus conflict if more than one card are installed.
data:image/s3,"s3://crabby-images/9138c/9138c30d7ea3a4810aabcc69521b2fbb841f091f" alt=""
So later on the third version I added a 74HC08 to get a combined CE line, which through a diode control the flash’s CE pin. This is OR’ed with the WOE line to get the card’s OE control, which is fed through the remaining 74LVC245 channel to get a 3.3V OE to control the flash and the data port 74LVC245. The OR’ing is done using the remaining gates of the 74HC86 and 74HC08 to save cost.
data:image/s3,"s3://crabby-images/f9a93/f9a9303d20c74fb26c04860e8bbd1ee87ac657c6" alt=""
Currently this all working just fine. For the production version I’ll probably just tie CE with a pull-down.
Software
This is where I suck. I have previously used ESP-IDF and know something about FreeRTOS but when it comes to real projects it still give me headaches.
data:image/s3,"s3://crabby-images/fa4d5/fa4d5a76c2b5915d61b5aae77c3d2464805e8509" alt=""
When user connect to the WiFi hotspot and access the ESP32 server, some webpages are served, and the user can erase the flash, upload a new ROM, and configure the WiFi. The WiFi off option is the latest add due to the fear of too high current consumption if someone install all expansion with such card.
data:image/s3,"s3://crabby-images/3a721/3a7210b12e58da8b7c41b2fbb710c9710739b2f1" alt=""
data:image/s3,"s3://crabby-images/9aab8/9aab8a2c42ec45bb3775407e041c22dd995dbcce" alt=""
data:image/s3,"s3://crabby-images/4c515/4c5155409babc37f3cbf0b8aa522d4ee46af08ea" alt=""
To save cost, some flash I chose does only support byte/word programming. The flash programming is done with IO operations so their speed is very important. I used direct register writes for bus control pins, used dedicated IO to control the data pins (single CPU cycle set 8 pins), and SPI running at 20M clock to control the shift registers for address lines. The current program time for 8MB is 6 minutes.
data:image/s3,"s3://crabby-images/4608c/4608cc3f8cdc79fd3762430856dcbeda9fa0be8a" alt=""
data:image/s3,"s3://crabby-images/25f93/25f9359414b109262ef2eaf1eb3809d5f6a38f82" alt=""
data:image/s3,"s3://crabby-images/5a47e/5a47e28f765f5e8088fd72346e01cf71def8737e" alt=""
The programming runs in a task and receive data to program through a queue.
The software reads nvs storage on startup to get WiFi configuration information. It configures data pins, shift register output pins and all bus control pins as tri-state. If the button is pressed on boot and still pressed after 3 seconds, the nvs config will be cleared. If WiFi off is set, a button press will start WiFi and server. When user selects erase or program, ESP32 will set the OE of U2, U3, U4 high through IO1 so their outputs tri-state. The OE of U5 will also tri-state due to pull-up. This way the expansion port is isolated allowing programming of the flash in-system.
I chose to only include off and on option, rather than more options like off after x minutes, because if the 5V supply is not enough, the WiFi of multiple installed card cannot start simultaneously anyway, so it has to be off on boot and be later woken up manually.
Overall Result
data:image/s3,"s3://crabby-images/87f5d/87f5dcda1258c10765c6ddfa336951d6694c6dbf" alt=""
data:image/s3,"s3://crabby-images/22405/224057e3d5395ff97469daf60f5706840265f8a4" alt=""
Currently everything is working. I’ll do some more testing and probably will spin a small batch for PVT sale. After I’m confident enough with the design I’ll release those as open source.
That sounds very, very good, i always dreamed to make a card by my own..!!
Hello,
I’m totally interested in a few of these cards, I have one JV1080 and one JV2028.
Been using one of the Sector101 cards to load patches on my units but the whole
process of opening the units is not something I enjoy doing to say the least.
Let me know availability and price.
Thanks in advance
Hi LdF, you can now purchase card at https://www.ddzheng.cc/?page_id=666
If you need more than one or two cards, please order 1 or 2 first and order more when next batch is available. I’ll give you discount then.
Greetings
this is awesome. Would be really interested in purchasing a few of these!