-
-
Notifications
You must be signed in to change notification settings - Fork 106
Hardware modification guide
Unfortunately there are currently problems with the OpenOCD configuration for DelugeProbe and there are known problems like hitting wrong positions, requiring multiple load retries and breakpoints being reported as exceptions. We hope those will get fixed so we leave the following guide as is
by Aria Burrell <litui@litui.ca>
DON'T PANIC
- Introduction
- Adding a Debug Header to Your Deluge
- Exposing Your Debug Port
- Building and Flashing Your DelugeProbe
So, you're a developer and synth enthusiast who is interested in contributing to the Deluge now that it's gone Open Source... welcome! Especially if you're new to embedded development, it can be a bit daunting at first, but this guide aims to start you off with the right gear!
This guide is intended primarily for those who are soldering at an intermediate level. Most of the process is very basic for those experienced with circuitry and embedded systems work (or even DIY synth modules), but for absolute beginners there are some difficult parts where you should enlist the help of a skilled solderer.
Be aware that some of these physical modding steps may void your warranty.
Synthstrom waives all liability for damage incurred through the following of this process.
But, you're an intrepid developer and/or synthesist who laughs in the face of adversity ("ha ha ha!")! You got this, and if you're at all uncertain about any of these steps, by all means come ask for community help in the forum or in the #dev-chat channel on the Synthstrom Audible Discord.
Writing, compiling, and loading of firmware (via SD Card) doesn't require any special hardware. In the case of small code tweaks you can probably get by making and testing the change over a few iterations without special hardware.
Once things start getting complicated (e.g.: you need to track changing variable values, test function outputs, etc.), you're going to want a hardware debugger.
There is one, officially supported debugger by Renesas (makers of the chip used in the Deluge) and that is the SEGGER JLink series debuggers.
IF you use Windows and already own a SEGGER J-Link or don't mind spending between $500 USD and $1500 USD on a small, single-purpose piece of debugging gear, THEN you have the easier path: you can follow the Debug Header Installation instructions below, hook up your J-Link, and skip the rest of this guide.
You can acquire a JLink EDU or JLink EDU Mini which can be used for educational and non-commercial purposes, but the license allowances are somewhat ambiguous with regard to open source project contributions. Use at your own discretion.
The e2 Studio software (based on Eclipse) is the official (Windows) tool Renesas recommends for development and debugging on the Deluge's microprocessor. Everything JLink-related should work out-of-the-box in e2 Studio.
IF you use Linux or Mac, already own a DAPlink debugger, or have $5 in your back pocket you're willing to spend on a Raspberry Pi Pico which can easily be converted to a YaPicoProbe (CMSIS-DAP) debugger, this is the path for you!
Rather than spending almost as much as you spent on your Deluge buying a debugger, you could spend a maximum of about $32 USD (all inclusive) plus a couple hours of your time to have everything you need to contribute to the Deluge open source project using your preferred IDE/Editor and operating system.
Please be warned that at present this debugger is much slower than the JLink debugger. This is due mainly to poor optimization of Cortex-A debugging within OpenOCD.
There is work underway to improve support for Cortex-A processors (like what's in the Deluge) on the Black Magic Probe firmware. This would allow even more (fast) options for debugging. This support is not quite ready, however.
More to come!
Hardware debugging is going to require you to have access to the JTAG/SWD debug header on your Deluge. This means at minimum you will need to open up your Deluge and solder in an SWD (Serial Wire Debug) connector. If you'd like to be able to debug with your Deluge sealed up, you will also need to modify the body of the Deluge. Instructions below!
Basic tools and supplies you will almost certainly need if you aim to complete all the steps (debug pins, optional case mod, DelugeProbe):
- a clean, freshly tinned precision soldering iron
- thin gauge flux-core solder wire for fine electronics work
- a few different screwdrivers for opening and closing the chassis:
- full size Phillips (X) #2
- precision Phillips (X) #1
- 1.5mm hex driver
- wire cutters (or scissors)
- wire strippers
- needlenose pliers and/or an adjustable wrench (for removing nuts holding on the faceplate)
- a Micro USB cable for connecting your computer to the Raspberry Pi Pico
- a divided tray for temporarily holding screws and components until needed
- an anti-static mat and/or bracelet
- a Dremel or other small metal-drilling/cutting/engraving apparatus to cut an access hole for the debug port
- electrician's tape (for covering up contacts and patching errors)
- scotch or masking tape (for holding pins in place while you solder)
Whether or not you are the one doing the actual work, you will need the following components to complete all the mod steps in this guide, priced out below (in USD):
Qty. | Mouser | Description | USD Each |
---|---|---|---|
For debug pinout Deluge mod: | (on the board only; Deluge case must be left partially open to use) | ||
1x each | 200-FTS10501LD | Samtec Micro Low Profile Header Strip (ignore the photo) | $2.62 |
For (optional) Deluge case mod: | (requires external modification to case, but allows access even if chassis is closed) | ||
1x each | 485-1675 | Adafruit 10-pin 2x5 Socket 1.27mm pitch IDC (SWD) Cable | $2.95 |
1x each | 485-2743 | Adafruit SWD (2x5 1.27mm) Cable Breakout Board | $2.95 |
1x tube | 910-EGS10C-20G | Electronics Grade Silicone Adhesive Sealant (Clear) 20g Squeeze Tube | $4.94 |
For Making DelugeProbe Debugger: | |||
1x each | 485-1675 | Adafruit 10-pin 2x5 Socket 1.27mm pitch IDC (SWD) Cable | $2.95 |
1x each | 485-2743 | Adafruit SWD (2x5 1.27mm) Cable Breakout Board | $2.95 |
1x spool | 485-4730 | Adafruit 30AWG Rainbow wire wrap (way more than you'll probably ever need) | $6.95 |
1x each | 358-SC0917 OR 358-SC0915 | Raspberry Pi Pico (with or without pre-soldered pins) | $5.00 |
GRAND TOTAL | $31.31 |
There are other parts you could use if you have different things on hand, and cheaper (bulk) supplies you could stock up on if you're an electronics technician or engineer but this guide is intended as a one-off. Remember it never hurts to get a couple extras of something in case of a parts defect or mistakes being made!
If you prefer your electronic parts to be stably mounted, consider purchasing a mixed pack of protoboards from Amazon, AliExpress, or even a dollar store. The instructions below are the same whether or not you use a protoboard.
If you would like to house your debugger in some sort of case, lots of options are available on Mouser and other sites.
Personally, I am a fan of putting my Picos on DFRobot IO Expansion Boards. This exposes labelled male and female hookups for every pin so I don't need to solder anything to the board (allowing me to repurpose it for other things at any time). I then use an Adafruit JTAG to SWD Adapter Board to connect the Pico DelugeProbe to the Deluge. It looks like this:
The guide below will do things slightly differently, soldering connections to the DelugeProbe and making it more permanent (and less prone to user error).
The soldering skill required below is Intermediate in difficulty so if you are new to soldering it might be beneficial to ask someone with more soldering experience to help out with the more difficult parts. It's only one section that is hard, the rest is pretty basic.
The Deluge will need to come apart almost completely and components will be vulnerable to static shock and damage throughout so please take care when the Deluge case is open.
THIS WILL PROBABLY VOID YOUR HARDWARE WARRANTY
You agree that by following the below process you understand the risks and that Synthstrom Audible is not liable in the event of damage.
If this is a major concern for you, check with Ian at Synthstrom if they are currently offering a service to install debug pins for you.
Prepare table space (enough to fit three Deluges) and ready your parts tray as there will be many parts to keep track of. In addition to your anti-static mat, you will need the Deluge to be face-down for part of this so find a book at least as thick as the height of the knobs to rest the keybed of the Deluge on.
Follow the steps in the YouTube video linked above to take the Deluge apart. Please note the creator's correction that you should use a hex precision-driver, not a torx driver.
Don't be afraid to take pictures at each stage so you can remember how things looked when it comes time to put it all back together. Take your time, be methodical, and don't forget to breathe.
Now that the guts of the Deluge are exposed you'll need to locate the debug header. It will be 2 columns of 5 rows each, located above (or below depending what way you're looking at it) the Renesas processor.
Before getting started, I recommend watching through the following video on soldering the identical 2x5 set of pins to an ARM development board SWD header.
Once located you'll need to insert the short-pinned (unplated) side of your 10 pin strip and use a piece of scotch or masking tape temporarily to hold it in place. When you gently flip the board over, you should see the pins peeking through the holes on the other side of the board.
You'll notice the holes are very closely positioned next to each other as compared to other headers on the board (for instance, P52 to the side of the processor). This makes for some difficult soldering to ensure there is no current flowing between pins.
If you will be soldering yourself, ready your clean, tinned soldering iron. Gently, but quickly apply heat to each pin/pad and melt a very small amount of solder and flux on each.
You absolutely don't want the solder to spread across pads, you just want it to bond each pin to the pads around each hole. Take care not to apply heat for too long. If it doesn't work within a couple seconds, stop. Wait for the board to cool, then try again. In the end it should look something like this:
It doesn't have to be perfect, but at a minimum, there must be clear separation between joints and good connections between each pin and its pad. Use a magnifying glass to check if needed. If you mess up, there are a couple of tricks to cleaning up between pads:
- Remove any solder from your iron's tip by wiping it on the wet sponge included in your kit, then slowly, without much pressure, push the heated tip against the space between pins allowing it to melt and slide through the accumulated solder. If it doesn't work the first pass, wipe off the iron and try again - a well-tinned tip will attract excess solder to it.
- Get yourself a solder vacuum, melt the blob then immediately press the vacuum to the excess solder and press the trigger. It may over-clear the mess, but you can always apply additional solder to the pins.
Once complete, on the other side, it will look something like this, (though if you ordered from the parts list above, your pins will not include a plastic shield - through-hole versions of this part were hard to source):
Now that you've visually ensured your pins are soldered correctly, you'll need to ensure all the rubber keycaps are in place and screw the board back onto the frontplate.
If you'll be modding the case, take a break before starting the next part (you deserve it!).
If you're not going to be modding the case, connect one of your debug cables to the pins as in the following image, and put the rest of your Deluge enclosure back together. I suggest leaving off the left wooden panel/ear and letting the cable dangle out that side so it can be connected to the probe easily.
Regardless of whether you have a notched shield on your pins, you need to make sure when attaching the cable that you align the red/pink wire with the white arrow on your Deluge board. The wire may be a different colour but it will be unique as compared to the others in the ribbon.
There are multiple routes you could take to exposing a debug port on the outside of your Deluge. I chose to mod the metal backplate but it occurred to me after the fact that I could have used my CNC router and done a tidier job modding the left wooden panel/ear. In fact, I did this later on. It is also possible to 3d-print side panels. Either of these approaches are preferred to directly modifying your case.
SOME OF THESE APPROACHES MAY VOID YOUR HARDWARE WARRANTY
You should already have a 2x5 set of pins soldered into your Deluge board, the board should be screwed back on to the frontplate, and the remainder of your Deluge enclosure should be open.
That being the case, we'll ignore the Deluge for the first part of this, focusing instead on one of the debug cables and one of the Adafruit SWD breakout boards. Parts I and II of this section may not be needed depending on the approach you take here. Read up on the various approaches in Part III and then decide.
For this part, you will need one of the Adafruit SWD breakout boards purchased above (the other one is for making the DelugeProbe later) and one of the 10 pin Adafruit SWD cables.
The first step is to cut off one of the cable's connectors. Ensure your cut is at 90 degrees and very close to the connector so you leave enough length for the cable to reach. You want to leave the other end intact so it can be attached to the pins now soldered onto your board.
Once your cable is cut, you'll want to carefully split the wires at the end apart so they can be separately connected to the breakout board. You can use an Xacto blade or other sharp implement to help with this process but try not to cut into the insulation around the wires, just the thin material holding the separate bundles together. The separated lengths should be between 2cm and 3cm (3/4 inch to 1 inch).
Once separated, you'll need to strip the ends of the wires no more than a few millimetres (1/8 inch).
If you don't have a wire stripper or a set of snips with a notch for stripping wire, you can slide a blade gently around the wire to gently mark the insulation. Then using your fingernails or a set of pliers, you should be able to pull off the insulation beyond your mark. This takes some practice so perhaps try with other wire first.
Now you'll need to "tin" each of the exposed ends of each wire by applying a thin layer of solder to each. This improves adhesion and reduces the risk of corrosion. Find a way to keep the cable steady while you work -- electronics folks often use a "helping hand" but you can easily hold the cable down with your wrist. If using a helping hand or clip, I recommend wrapping the cable with a spare bit of plastic bag or tape so the clip doesn't cut into the soft insulation.
Keeping each of the wire ends bundled (you don't want stray bits of wire sticking out), apply solder to each tip. Once complete, grab your SWD breakout board and have a quick stretch before we get to the next part.
Using the above as a reference, take note of how the solder points for each wire on the breakout board are alternating. Odd numbers down the one side starting at Vref
(the red wire), and even numbers down the other side ending in RST
.
Using a vise or helping hand to hold onto the SWD breakout board, solder each wire in place, remembering to alternate sides as in the diagram.
When complete, it should look something like this:
Now get hold of your Deluge enclosure because you're ready for the scary part...
There are multiple options for exposing your debug port to the outside world. Please review the options before deciding.
Simply unscrew the right-hand side panel (keep the screws somewhere safe) and remove it whenever you need to access the debug port. You can even leave a cable attached for this purpose. Simple as that!
TODO: Fill in instructions and links for 3d-printing a side panel.
TODO: Fill in instructions and links for CNC-cutting a side panel.
There should be enough clearance to dangle a debug cable in front of / alongside one of the midi ports. While it may seem like it would be in the way, there is room for a midi DIN cable to be attached without the debug cable interfering. Easy-peasy!
Here, you have multiple options as there is a lot of free space on the back panel or the left wooden ear. I opted to measure out the needed space and drill/file the way with a Dremel engraver, but you may have cleaner/more accurate tools at your disposal. My recommendation is to cut a space for the jack below the headphone jack. This way, on the off-chance that it causes any interference it'll only be for you as the listener, not on the inputs or line-outs.
If you make a bit of a mess, it's not a big deal as you can slap a sticker over it (as I did), but there are cleaner approaches.
I would recommend putting masking tape over the area you'll be cutting temporarily. Not only will you be able to trace the lines you'll need to cut but you'll avoid making unsightly marks on the surface.
Did I follow that advice? No, but I also made a bit of a mess. Your mileage may vary.
Now that you have a hole that the connector on the breakout board fits through, crack open that electronics-grade silicone tube you purchased, and apply liberally to both the soldered (top) side of the breakout board and the inside of the Deluge case around where the connector will go. Avoid getting silicone inside the connector if at all possible as it will be a pain to get out once cured.
Push the connector through the hole and let the connector and back panel sit for 24 hours to ensure the breakout board doesn't go anywhere. Make sure you cover up your open Deluge with something (perhaps your solder mat) and keep pets and dust away until you're ready to work with it again.
...
After your wait, get ready to put the Deluge back together again, but this time make sure to attach the debug cable to the pins you installed before, as below. Remember, red wire to white arrow or, as is visible in the image, red wire away from the Renesas chip. Make sure the connector is on properly (over all 10 pins) and pressed down such that it will not move in a closed case.
To close up your case, make sure the silicone pads are properly aligned on the PCB -- most of them have little nubs that sit in the PCB to help with this. Pay partiular attention to the holes through the PCB that will be used to join it to the faceplate! If some of the silicone pad ends up between the PCB and the faceplate standoff, the PCB will be bent (not permanantly) and the pads will feel extra-mushy when you press them. Then you should be able to drop the faceplate on top and press the plate and PCB together. Now put all the screws and knobs back on, and fire it up to make sure everything still works.
Congrats, you're done with the hardest parts!
The Raspberry Pi Pico is an inexpensive development board that, among many other useful things, can be used as a hardware debugger. The Picoprobe firmware, intended for using a Pico to debug other Picos primarily, also works reasonably to debug other ARM-based devices. DelugeProbe is a custom firmware based on a fork of the Picoprobe firmware called "Yet Another Picoprobe". YAPicoprobe includes a variety of features, most of which have been disabled in the DelugeProbe for simplicity's sake.
DelugeProbe is a work-in-progress firmware being tailored to achieving as-fast-as-possible debugging of the Synthstrom Deluge and its Renesas RZ/A1LU microprocessor. Please be warned that at present this debugger is much slower than the JLink debugger. This is due mainly to poor optimization of Cortex-A debugging within OpenOCD.
DelugeProbe Additional Goals (not yet working):
- Drag & Drop Firmware Loading for the Deluge
- At-a-glance Deluge status information from running memory
- Support for other, more compact RP2040-based boards including the Adafruit QT Py RP2040, the Adafruit KeeBoar RP2040, and the Seeed RP2040.
This section involves only basic soldering. If your pico has pins, you may want to use a protoboard to hold everything (as in the wiring diagram below), but this wiring works just fine loosely assembled as well:
- Pico GND -> breakout board GND & GND (solder/wire these together)
- Pico GP2 (4th pin) -> Breakout board CLK
- Pico GP3 (5th pin) -> Breakout board SWIO
- Pico GP4 (6th pin) -> Breakout board NC
- Pico GP5 (7th pin) -> Breakout board SWO
This wiring is the same whether you're using a Raspberry Pi Pico or Pico W.
Once wired up, you'll be able to connect the debug cable between your Pico and the Deluge. But first, you need some firmware!
Start by downloading the latest DelugeProbe .uf2 firmware. Save it somewhere easily accessible for drag & drop on your computer.
You can also use the PicoProbe firmware or YAPicoProbe firmware if you choose, though your debugging experience may be less tailored to the Deluge's specific hardware if you go with either of these. There are also notable speed improvements in YAPicoProbe and DelugeProbe over the original PicoProbe firmware.
Hold down the Reset/Bootsel button on the Raspberry Pi Pico and, while continuing to hold the button down, plug it in to your computer via its Micro USB port. Once plugged in, wait a moment then let go of the button.
If a window doesn't pop up for it, check your system to see if you have a new "drive" called RPI-RP2
. Open up that directory/folder. In another window, find where you put the .uf2
file for the DelugeProbe firmware (try your Download
folder), and simply drag it to the RPI-RP2
drive.
Once loaded, the drive will disappear and, if successful, be replaced by a drive called DelugeProbe.
Congratulations! You've got a DelugeProbe. Out of the box, it should work with your Deluge and the Renesas e2 Studio configuration included in the DelugeFirmware git repository.
Instructions to use it with other approaches will be added to this document in the fullness of time.