This page is intended to document tools which can be used to force FCC mode in the Phantom 3 and Inspire 1 series. Alot of this content is derived from github discussion, credits to mefistotelis for his tool creations. https://github.com/o-gs/dji-firmware-tools/issues/10
A method has been created to enable FCC mode as well as changing other transmission settings. There are two methods, one is sending communications to the RC directly, the second is extracting firmware for your Phantom 3 or Inspire 1 Remote control, modifying some settings, saving and re-compiling the firmware file. You will then need to install the firmware file onto the remote control to take effect.
Make sure to review this GitHub with more info: https://github.com/o-gs/dji-firmware-tools
Create a folder, maybe named “P3FCC” and then download all of the files below into it.
Pre-reqs:
NOTE: Make sure to SET PATH for Python during install. If you don't know what this means, google it.
Once these libraries are all installed you can use the tools to decrypt the firwmare files.
We are targeting the 1400 or 1401 modules. The 1400 module is for the GL300A controller, the 1401 is for the GL300B/C controllers. <Need to include Inspire RC model>
You need to access the RC firmware files. You can find them on the DankDroneDownloader site
Direct links available as well:
Phantom 3 RC: <insert URL's for download>
Inspire RC:
<insert URL's for download>
Once downloaded, move the file into same folder as the files you downloaded earlier.
You will go through these steps:
Extracting the file:
dji_xv4_fwcon.py -vvv -x -p <firmwarename.bin>
arm_bin2elf.py -vv -e -b 0x000a000 –section .ARM.exidx@0x019300:0 –section .bss@0x1ff6000:0x4000 –section .bss2@0x1ffe000:0x1000 –section .bss3@0x1bff6000:0x2400 –section .bss4@0x1c01a000:0x2400 –section .bss5@0x40022000:0x50000 –section .bss6@0x400ee000:0x200 –section .bss7@0xe0004000:0x1200 -p <firmwarename_m1401.bin>
lightbridge_stm32_hardcoder.py -vvv -x -e <firmwarename__m1401.elf>
Parameter Name | Description |
---|---|
og_hardcoded.lightbridge_stm32.packet_received_attenuation_override | What to do when received a packet with transceiver power set request; 0 - use the received attenuation value, 1 - override the value with constant one |
og_hardcoded.lightbridge_stm32.packet_received_attenuation_value | Constant attenuation value used when packet_received_attenuation_override is enabled; unit depends on OFDM board type |
og_hardcoded.lightbridge_stm32.board_ad3_attenuation_tx1_fcc | Transceiver attenuation value for board type 3 with Analog Devices chip, change by 1 means 0.25 dBm |
og_hardcoded.lightbridge_stm32.board_ad3_attenuation_tx2_fcc | Transceiver attenuation value for board type 3 with Analog Devices chip, change by 1 means 0.25 dBm |
og_hardcoded.lightbridge_stm32.board_ar0_attenuation_tx1_ce | Transceiver attenuation value for board type 0 with Artosyn chip, change by 1 means 1 dBm |
og_hardcoded.lightbridge_stm32.board_ar0_attenuation_tx2_ce | Transceiver attenuation value for board type 0 with Artosyn chip, change by 1 means 1 dBm |
og_hardcoded.lightbridge_stm32.board_ad3_attenuation_tx1_ce | Transceiver attenuation value for board type 4 with Analog Devices chip, change by 1 means 0.25 dBm |
og_hardcoded.lightbridge_stm32.board_ad3_attenuation_tx2_ce | Transceiver attenuation value for board type 4 with Analog Devices chip, change by 1 means 0.25 dBm |
og_hardcoded.lightbridge_stm32.power_zone_selection_override | What to do when power zone is about to be selected from geo coordinates; 0 - set the value based on geolocation, 1 - override the value and set to FCC |
You can also use the tool comm_serialtalk.py to send commands to the RC to see the status or change status.
These are commands to the RC plugged in via USB to PC using comm_serialtalk.py.
Need to add install steps for FW.
P1765Fw3.bin means something, service file name? gs_ofdm.bin? 1400 is probably used only by GL300a/b; the c version likely uses m1401