Hawk - Open Source Xbox Live Communicator

Inspect Gerbers

Tracespace View

Assembly Guide

Interactive HTML BOM

Order PCBs:

Compare PCB Prices:

Buy Parts

Adjust quantity:
%
 
ReferencesQtyDescriptionManufacturerMPNDigikeyLCSC
U11IC REG LINEAR 3.3V 300MA SOT23-5Microchip TechnologyMIC5504-3.3YM5576-4764-1-NDC3021093
U21IC MCU 32BIT 32KB FLASH 32LQFPSTMicroelectronicsSTM32G431K6T6497-STM32G431K6T6-NDC730097
U31IC CODEC MONO AUD 16BIT 24TQFNMaxim IntegratedMAX9860ETG+TMAX9860ETG+TCT-NDC516787
U41IC REG LINEAR 1.8V 300MA SOT23-5Microchip TechnologyMIC5504-1.8YM5576-4879-1-NDC626116
C1, C2, C3, C12, C205CAP CER 10uF 0603ANYCAP CER 10uF 0603311-1448-1-NDC19702
C4, C5, C6, C7, C135CAP CER 100nF 0603ANYCAP CER 100nF 0603311-1088-1-NDC30926
C8, C9, C10, C11, C14, C15, C16, C17, C18, C1910CAP CER 1uF 0603ANYCAP CER 1uF 0603311-1446-1-NDC15849

Hawk - Open Source Xbox Live Communicator

This project is an open source replacement of the Microsoft Xbox Live Communicator utilizing modern components and custom open-source firmware.

hawk!

It provides feature parity with the original communicator with the following differences:

  • A 3.5mm TRRS jack is used to support more generic headsets. (Stereo headsets will output as mono.)
  • The volume wheel is replaced with a button. Volume is indicated by LED brightness.

Usage

  • When installing Hawk into your controller, it must be installed in the slot closest to you.
  • Press the button to increment the volume. Once maximum volume is reached, it will cycle back to zero.
  • Hold the button for 1 second to mute and disable the microphone input (LED will flash at 1Hz).
  • Hold the button 2 seconds to enter microphone gain adjustment mode (LED will flash at 4Hz).
  • Volume and microphone gain adjustments will be saved internally. You can reset these to default by holding the button down for 8 seconds.

Assembly

  • When ordering PCB thickness should be 1.2mm!
  • See Kitspace for BOM, PCB ordering and assembly information.
  • See KiCanvas for schematic view.

Compilation

  • Download and install Visual Studio Code.
  • Install the PlatformIO IDE plugin.
  • In Visual Studio Code File > Open Folder... > hawk
  • Hit build on the Platform IO toolbar (✓).

Programming

  • Compile or Download the pre-built firmware image.
  • USB DFU. Connect an xbox controller to your PC, then hold the Hawk button down while inserting it into the controller to enter DFU mode. Your PC should detect this. you can then program with STM32Cubeprogrammer
  • ST-Link interface (5 pin header available on PCB)

FAQ

  • What is the pinout of the headphone jack?
    • Hawk's headphone jack is wired as per CTIA standard TRRS. There is another less common standard called OMTP. This will not work but adapters are available.
  • It doesn't fit in my controller slot.
    • PCB should be manufactured with 1.2mm thickness. Most fabrication houses default to 1.6mm so be careful!
  • Microphone is really quiet.
    • You can increase the microphone gain above default. Hold the Hawk button down for more than 2 seconds to enter gain adjustment mode. The LED will blink 4 times per second to show it is in the right mode then press the button to increase the gain. Hold for 1 second to exit. If this is still too quiet, you can modify the MAX_MICROPHONE_GAIN variable and recompile the code to bump it up even higher.
  • Speaker is really quiet
    • Adjust the volume by pressing the button until the LED is at its maximum brightness. Unfortunately, it is already compiled to the maximum allowable by Hawk. If it is still too quiet, your headset's impedance may be too low.
  • Does this work on modern controller adapters (ogx360, wingman etc)?
    • Not really, but kind of. To do this, you must connect a USB 1.1 compliant hub to the Xbox player port. Your controller then connects to port 1 of this hub and Hawk to port 2.
  • LED just flashes constantly when connected
    • This means the main IC cannot communicate with the audio codec on Hawk. This is likely a soldering issue.
  • Error: Database: There's no active configuration for this device. when programming.
    • Try an earlier revision of STM32CubeProgrammer. Users have reported some success with v2.5.0.

Attribution