Connect Bluetooth controllers to MSX computers
Note
An adapter based on PCB v1 Build1a has been successfully built and tested using the bluepad32 firmware!
Adapter v1 Build2b has NOT yet been built, although I may build it in the future.
The other builds will NOT be built, and are just left for reference.
For an upgraded SMD version, please visit msx-joyblue-v2.
The msx-joyblue is an adapter that allows connecting Bluetooth controllers to MSX general purpose ports.
The adapter is based on the unijoysticle2 and bluepad32 projects, both owned by Ricardo Quesada.
The main features of the msx-joyblue v1 adapter are:
- small size
- made of widely available electronic components
- uses easy to solder through-hole components to lower the skills needed to build the adapter
- emulates up to two MSX joysticks
- attaches to MSX computers using female standard DE9 connectors
- formally requires an external USB power supply as the adapter draws slightly more current than two MSX ports can officially provide
- optionally, can be powered using MSX general purpose ports without an external power supply if your MSX can safely supply enough current
- builtin leds provide information about the operation of the adapter
The msx-joyblue v1 adapter uses an ESP32-WROOM-32E based development board (either a ESP32-DevKitC-32E board or a NodeMCU-32 V1.3 board) to convert the Bluetooth controller actions to the MSX joystick standard signalling.
A printed circuit board (PCB) is used to easily bind all components:
- The ESP32 adapter board is connected using female headers
- PH2.0 connectors are used to connect cable extensions
- A 2.54 pitch I2C header is added for future extensions
- Jumpers are provided to enable different power options
- Only through-hole components are used
Connection to the MSX general purpose ports is implemented using a DE9 joystick extension cables with a female DE9 connector on one side and a loose end on the other side. The MSX joystick extension cable loose end is wired according to the following pinout mapping.
MSX joystick connector pinout, from controller plug side |
MSX side pin | Cable color (may vary) | Signal |
---|---|---|
5 | Brown | +5v |
4 | Orange | RIGHT |
3 | Grey | LEFT |
2 | Black | DOWN |
1 | Red | UP |
6 | Green | TRIG1 |
7 | White | TRIG2 |
8 | Blue | STROBE |
9 | Yellow | GND |
The Build1a adapter ignores the MSX general purpose pin8 (OUT) signal. This is not a problem in general, but can cause incompatibilities with specific software, like MSX-HID 1, which uses pin8 to try to guess which kind of device is connected to a MSX general purpose port. For MSX-HID, holding the Trigger B button, will put the software in FM-Towns compatible mode which will make the adapter functional.
This build uses open collector outputs (via 74LS05 hex inverters with open collector outputs) which makes the adapter safer 2 than the standard MSX joystick schematic depicted in the MSX Technical Data Book, as it avoids a series of undesired conditions that can lead to bus contention/short circuits.
msx-joyblue-v1 Build1a without case |
Warning
Build2 will not be finally built! Use at your own risk!
Build2 has been superseded by Build2b.
The Build2 adapter takes into account the MSX general purpose pin8 (OUT) signal:
- When pin8 is HIGH, the adapter puts all stick and triggers signals in high impedance mode irrespective of their status (as if stick and triggers were not hold in the standard MSX joystick schematic), which become HIGH on the MSX side via the MSX PSG related circuitry pull-ups (matching the expected behavior)
- When pin8 is LOW
- if a stick direction or trigger is hold, the corresponding signal is pulled down to GND causing it to be LOW (matching the expected behavior)
- if a stick direction or trigger is not hold, the corresponding signal is put in high impedance mode, which becomes HIGH on the MSX side via the MSX PSG related circuitry pull-ups (matching the expected behavior)
This build uses discrete logic components to honor the pin8 signaling (a 74LS04 hex inverter and three 74LS03 quad 2-input positive-nand gates with open collector outputs) and uses open collector outputs which makes the adapter safer 2 than the standard MSX joystick schematic depicted in the MSX Technical Data Book, as it avoids a series of undesired conditions that can lead to bus contention/short circuits.
msx-joyblue-v1 Build2 render |
Warning
Build2b has NOT yet been tested! Use at your own risk!
The Build2b is similar to Build2 but simplifies the BOM by using less different components.
This build uses discrete logic components to honor the pin8 signaling (four 74LS03 quad 2-input positive-nand gates with open collector outputs) and uses open collector outputs which makes the adapter safer 2 than the standard MSX joystick schematic depicted in the MSX Technical Data Book, as it avoids a series of undesired conditions that can lead to bus contention/short circuits.
msx-joyblue-v1 Build2b render |
Warning
Build3 will not be finally built! Use at your own risk!
The Build3 adapter takes into account the MSX general purpose pin8 (OUT) signal, and produces outputs exactly as described for Build2.
This build uses GALs, instead of discrete logic components, to honor the pin8 signaling (two ATF16V8B Electrically-Erasable Programmable Logic Device) and uses open collector outputs which makes the adapter safer 2 than the standard MSX joystick schematic depicted in the MSX Technical Data Book, as it avoids a series of undesired conditions that can lead to bus contention/short circuits.
msx-joyblue-v1 Build3 render |
The msx-joyblue v1 adapter firmware uses Ricardo Quesada bluepad32 library to drive Bluetooth controllers. A small modification to the library that enables support for MSX computers was commited to the develop branch. The main branch carries too the modification since February 2024.
See the bluepad32 documentation for supported Bluetooth controllers.
A simple acrylic enclosure is included.
msx-joyblue-v1 Build1a inside tested case prototype |
The msx-joyblue adapter uses about ~107mA when operating, while a single MSX general purpose port is capable of delivering up to 50mA according to the MSX standard 3. That means that even using two MSX general purpose ports (50mA + 50mA = 100mA) we are slightly over (107mA) the max current specification for the MSX general purpose ports.
Thus, the safest way to power the msx-joyblue adapter is by powering it via the USB micro connector of the attached ESP32 board using an external 5V USB power supply. The board automatically powers up when using the USB micro connector without enabling any switch.
Nevertheless, even if the MSX especification puts such a low limit on the current that can be drawn from a general purpose port, real MSX hardware usually can safely deliver enough current for the msx-joyblue adapter to work correctly without harming our beloved classic computers.
Taking that into account, the msx-joyblue adapter has been enabled to be optionally powered by the MSX general purpose ports port A and port B.
To enable powering the msx-joyblue adapter from port A and/or port B, the switch J3 JOY PWR must be first turned on by sliding the switch handle to the right.
Note
A 1N5817 Schottky diode D1 is used to avoid leaking current from the msx-joyblue adapter to the MSX in case the msx-joyblue adapter is powered by USB. And two Positive Temperature Coeficient (PTC) resettable fuses F3 and F4 of 50mA each protect the MSX general purpose ports port A and port B from excess of current in case something goes horribly wrong on the msx-joyblue adapter side, aligning to the MSX specification.
To power the msx-joyblue adapter using the MSX general purpose ports we must first understand how the PTC protections on the msx-joyblue adapter are implemented.
The selected PTCs are rated for 50mA which is the so called Hold Current (the maximum current that can flow in normal operation). There is also the Trip Current (the minimum current necessary for the PTC to move to high-resistance state) which for the selected PTCs is around 100mA. Those thresholds are dependent on temperature and voltage. And to make things more undeterministic, the behavior of the PTC when current is between those thresholds is undefined (it may trip or not).
In normal operation and for a room temperature of around 25 degrees Celsius, the selected PTCs in practice never trip below 75mA.
So if our MSX computer can safely provide more than 50mA on each MSX general purpose port (which is usually the case), we can connect both Port A and port B to the MSX computer and turn on the J3 JOY PWR switch to power the msx-joyblue adapter. Note that we need to connect both ports even if we use just one Bluetooth gamepad, just to meet the power requirements.
From PCB board version 1a, two jumpers JP3 and JP4 can be used to bypass the PTC protections for port A and port B.
Warning
Bypassing the PTC protections may damage your MSX computer. Do not bypass the PTC protections unless you known what you are doing.
By closing JP3 (and/or JP4) and if our MSX computer can safely provide more than 100mA on a single MSX general purpose port, we can connect Port A (or Port B) to the MSX computer and turn on the J3 JOY PWR switch to power the msx-joyblue adapter using a single joystick port.
In summary, we can use the following options to power the msx-joyblue adapter (from safest to less safe):
- via the ESP32 USB micro conector
- leave open jumpers J3 and J4
- turn off the J3 JOY PWR switch
- connect a 5V USB power supply to the ESP32 USB micro connector
- via two MSX general purpose ports, if your MSX can safely provide slightly more than 50mA on each MSX general purpose port
- leave open jumpers J3 and J4
- turn on the J3 JOY PWR switch
- connect both Port A and Port B to the MSX general purpose ports
- via one MSX general port, if your MSX can safely provide more than 100mA on each MSX general purpose port
- close jumpers J3 and/or J4
- turn on the J3 JOY PWR switch
- connect Port A or Port B to a MSX general purpose port
Model | Adapter PCB v1 Build1a |
---|---|
Sony MSX HB-101P | OK |
Sony MSX HB-501F | OK |
Toshiba MSX HX-10 | OK |
Philips MSX2 VG-8235 | OK |
Panasonic MSX2+ FS-A1WSX | OK |
Omega MSX2+ | OK |
MSXVR | OK |
Ricardo Quesada bluepad32 library
Ricardo Quesada Unijoysticle2 project
MSX General Purpose port
- https://www.oshwa.org/open-source-hardware-logo/
- https://en.wikipedia.org/wiki/File:Numbered_DE9_Diagram.svg
- https://commons.wikimedia.org/wiki/File:Bluetooth.svg
Footnotes
-
https://www.msx.org/wiki/Joystick/joypad_controller (see "Undesired Conditions") ↩ ↩2 ↩3 ↩4