template and source for hardware projects
Go to file
King Kévin 61112471f2 sch: set TJ2242 BoM 2022-07-24 18:19:19 +02:00
coraleda/subc lib: add TJ2242 current limit 2022-07-24 17:31:49 +02:00
geda/symbols lib: add TJ2242 current limit 2022-07-24 17:31:49 +02:00
library@c939ac91d6 lib: update repo 2022-05-28 12:36:25 +02:00
.gitignore add PnP export 2021-12-19 11:24:57 +01:00
.gitmodules update submodule source 2022-05-11 12:13:02 +02:00
.qeda.yaml lib: add TJ2242 current limit 2022-07-24 17:31:49 +02:00
CHANGELOG.md doc: list v1 changes 2022-06-16 17:01:00 +02:00
DEVELOPMENT.md doc: add flashing instructions 2022-06-16 18:14:01 +02:00
LICENSE.txt add CERN-OHL-S license 2021-07-22 12:22:58 +02:00
README.md doc: document OCS timing 2022-07-24 16:50:40 +02:00
Rakefile rake: all multi-sheet export 2022-06-16 16:44:14 +02:00
dfp_clone.rb fix dfp generation 2022-05-20 14:04:33 +02:00
eeprom.bin doc: add flashing instructions 2022-06-16 18:14:01 +02:00
eeprom.rb doc: add flashing instructions 2022-06-16 18:14:01 +02:00
gafrc add schematic configuration and template 2021-07-22 12:28:19 +02:00
mass_prop.sh add PnP export 2021-12-19 11:24:57 +01:00
pnp_fab.tab add PnP export 2021-12-19 11:24:57 +01:00
usb_hub-dfp1.sch sch: set TJ2242 BoM 2022-07-24 18:19:19 +02:00
usb_hub-dfp2.sch sch: set TJ2242 BoM 2022-07-24 18:19:19 +02:00
usb_hub-dfp3.sch sch: set TJ2242 BoM 2022-07-24 18:19:19 +02:00
usb_hub-dfp4.sch sch: set TJ2242 BoM 2022-07-24 18:19:19 +02:00
usb_hub-dfp5.sch sch: set TJ2242 BoM 2022-07-24 18:19:19 +02:00
usb_hub-dfp6.sch sch: set TJ2242 BoM 2022-07-24 18:19:19 +02:00
usb_hub-dfp7.sch sch: set TJ2242 BoM 2022-07-24 18:19:19 +02:00
usb_hub.lht brd: route TJ2242 2022-07-24 18:15:24 +02:00
usb_hub.sch sch: minor, fix connection 2022-06-17 16:36:30 +02:00
version switch to version 2 to add fixes 2022-06-16 18:04:17 +02:00

README.md

the CuVoodoo USB hub is a 7-port USB 2.0 hub meant for device testing.

purpose

most USB hub are super cheap and crappy, leading to poor connection and data transfer. there are industrial USB hubs, but they are bulky and very expensive. to solve this issue I decided to design my own USB hub, tailored to my needs.

when developing and testing hardware, you often end with a lot of USB devices connected. USB allows to have up to 128 devices, but only with a maximum depth of 7. thus you are only allowed to have a maximum of 5 USB hubs between computer and devices, and I often have to plan my setup to not reach this limit. most 7-port USB hubs use two 4-port USB hub, the seconds being connected to the first. there are some exception to that, but they are rare, old, and often not advertised as such. this heavily limits the number of end devices. this device is a 7-port flat USB hub, preventing reaching this limit too often.

the incoming and outgoing USB ports are individually ESD protected. this safety becomes important when developing, testing, and handling bare electronic devices. this also comes in handy against when connecting circuit with different ground potentials. ESD protections already saved my day twice this way. the issue is that they can blow without you noticing, but at least they protected the device once.

each output port is current limited to 500 mA. no device should draw more that this specified limit. it if does, there is very probably an issue with the device. this protection allows to isolate the faulty device and not have it affect all other connected devices, or the hub itself. the fault is also detected and reported by the hub to the host computer.

each output port is power controlled. this allows to remotely switch on an off individual devices. this is an important requirement when developing and testing devices, which require a power cycle.

additionally, a switch next to the power can force the power off state.

the USB hub can be self-powered (through the USB input port), externally powered by 5V, or externally powered by anything between 6 and 40V. this allows to use higher voltage power supplies to provide enough current to all ports. the 5V are not feed back to the host.

each USB port comes with a high voltage output power port, connected to the high voltage input port. this allows to power devices which require more than 5V (e.g. 12V externally powered devices). these power outputs are controllable. as with the 5V USB power output, this allows to remotely switch on an off individual devices.

each port has status LEDs, indicating the speed and power status of the connected device.

the board uses proper impedance and differential signal routing to provide clean USB signal transfer.

design choice

USB 2.0

this hub is only for USB 2.0 devices. by far this are most of the devices I develop. is makes it simpler and keeps the cost reasonable. I often even disable USB 3.0 because of the 13-device limitation of the Intel xHCI. when I need USB 3.0 for the very few devices, I connected them to the computer directly.

USB2517

I wanted to use the FE2.1 7-port USB hub chip. it does not need an external voltage regulator or crystal. and it is easier to solder thanks to its TQFP package, and provides all required functionalities. sadly I could not find a source for the 64-pin packages, and the 48-pin variant does not provide all required functionalities. thus I had to fall back to the Microchip USB2517, which uses a harder to solder QFN package.

power control

some USB hub chips allow to remotely control the power output on individual ports. this capability is here also used to control the power on the higher voltage output. thus you can completely power off even larger target devices.

current limitation

very few USB hubs that have current limitation on the output. this does limit the current to 500 mA, but only in constant current mode. if well designed, the fault is also reported to the computer. sometimes the hub also turns off the power, or it is up to the user to power off the faulty port.

on this hub, the fault is reported, and the power is automatically disabled, preventing damages on the device due to prolonged shorts. this is very useful when testing devices. the power is restored once the current limit is cleared.

the power distribution switch detects the over-current state and asserts the fault flag after 10 ms. after 0.1 ms (as set in OC_TIMER, in Configuration Data Byte 2, in EEPROM) the hub will switch off power. this also clears the over-current state. after 100 ms the HUB will re-enable power. this loop will repeat indefinitely. no over-current is reported to the host in this case. it is only reported when the OCS is asserted for longer (unknown time).

LED color

the USB specification, LEDs are used as port indicator (section 11.5.3)

  • off: powered off/disconnected
  • amber: current limitation reached
  • green: enabled or transmitting

instead the following color scheme is used:

  • green off: power off or over-current
  • green on: power on
  • red: low speed device connected
  • blue: full speed device connected
  • purple (red+blue): high speed device connected
  • red and blue off: disconnected

usage

it mainly works like a regular USB hub, at least when it comes to the data transfer. just plug the device in a port.

power on the Downstream Facing Ports (DFPs) is only available when the Upstream Facing Port (UFP) is connected.

the hub can operate as bus powered (power coming from the UFP), but it would not be able to provide more than 500 mA across all DFPs. it is preferable to connect an external 5V power supply to be able to provide 500 mA on all DFPs. this will also turn the hub into self powered, not using any power from the UFP. alternatively, you can connect a 6 to 40V power supply on the other power input. the power for the hub and the 5V for the DFP will be derivate from this higher voltage supply. the same higher voltage will be available on the power output next to the individual DFPs.

a switch next to each DFP allows to turn off the power output on the USB and power ports. the green LED is on when power output is available.

the power output on the USB and power ports can also be turned on/off remotely using standard USB commands. this power output control is implemented in uhubctl:

# list controllable USB hub ports
sudo uhubctl
# switch of port
uhubctl --action off --location 1-1.4 --ports 5

when too much current is drawn on the USB port, the error is reported to the host and the power output is automatically disabled.