Mag-hack ng CFA735 / CFA835: 4 na Hakbang
Mag-hack ng CFA735 / CFA835: 4 na Hakbang
Anonim
Mag-hack ng CFA735 / CFA835
Mag-hack ng CFA735 / CFA835

Mayroon ka bang isang proyekto na nangangailangan ng isang display, isang key pad, at ilang memorya, ngunit ang naunang preloaded firmware sa CrystalFontz CFA735 o CFA835 module ay hindi masyadong kung ano ang iyong hinahanap? Swerte ka - maaari mong i-hack ang mga modyul na ito upang mai-load ang pasadyang firmware.

Ang CFA735 at CFA835 ay maraming nalalaman matalinong mga module ng LCD. Parehong batay sa module ng hardware ng CFA10052 ang Crystalshez CFA735 at CFA835, kaya habang sa tutorial na ito ang CFA735 at / o CFA835 ay tinukoy bilang CFA10052. Ang CFA10052 ay maaaring muling ma-program upang patakbuhin ang iyong sariling pasadyang firmware.

  • STMicroelectronics STM32F401 microcontroller
  • ARM 32-bit Cortex ™ -M4 CPU @ 84 MHz
  • 256K Flash, 64K RAM
  • 244 x 68 pixel backlit LCD
  • Sitronix ST7529 32 grayscale graphic LCD controller
  • Pinapayagan ng suplay ng paglipat ng Buck-boost na malawak na saklaw ng boltahe ng suplay
  • Paghiwalayin ang paglipat ng LED Controller ng ilaw para sa keypad at LCD backlight
  • 6 na button na backlit keypad
  • 4x bi-kulay (pula / berde) LEDs
  • Interface ng USB2
  • slot ng microSD card
  • 5 pangkalahatang layunin IO pin (GPIO)
  • Maramihang mga serial / SPI / I2C / CAN interface (depende sa paggamit ng GPIO).

Ipapakita sa iyo ng tutorial na ito kung paano palitan ang firmware na nagpapadala sa isang CFA10052 ng bagong firmware na:

  1. Ipakita sa LCD ang isang alternating grid, na may kasalukuyang mga backlight, LCD kaibahan at impormasyon sa katayuan ng keypad;
  2. Kontrolin ang mga backlight at LCD na kaibahan gamit ang keypad.
  3. Baguhin ang kulay ng apat na LEDs mula pula hanggang berde nang magkakasunod.
  4. Paganahin ang serial port ng USART sa Header-1 pin 1 & 2 (115200 baud), at i-echo ang anumang natanggap na data.
  5. Paganahin ang USB virtual serial port, at i-echo ang anumang natanggap na data pabalik sa host.
  6. May kasamang, ngunit hindi nagpapakita, basahin / isulat ang pag-access ng file.

Siyempre, maaari mong isulat ang iyong sariling firmware at i-load ito gamit ang mga hakbang na ito.

MAHALAGANG PAALAALA:

Ang mga barko ng module ng hardware ng Crystalbestz CFA10052 na naka-program sa isang bootloader at CFA735 / CFA835 firmware. Ang bootloader at CFA735 / CFA835 firmware ay hindi bukas na mapagkukunan, at hindi makopya mula sa CFA10052 ng gumagamit, at hindi rin mai-program sa CFA10052 ng gumagamit. Kung nauuwi ka sa kagustuhan na bumalik sa CFA735 / CFA835 firmware, kailangan mong ipadala ito pabalik sa Crystalfontz upang mai-program ito muli.

Mga gamit

  • Crystalfontz CFA10052 (hardware v1.1 o mas bago) Module (CFA735 / CFA835)
  • PC (Windows / Linux / OSX) na naka-install ang STM32CubeIDE at STM32 ST-LINK Utility
  • STMicroelectronics ST-LINK (V2 o V3) interface ng programa
  • CFA10052 programming cable (mga detalye sa ibaba)
  • Pasadyang firmware (o gamitin ang amin dito)
  • Kung gumagamit ka ng Windows 7/8 / 8.1 / 10 (o katumbas na mga bersyon ng Server) at nais na subukan ang USB virtual serial port, kakailanganin mong mag-download ng mga driver mula dito. Ang USB serial port ay gagana nang hindi nangangailangan ng mga karagdagang driver sa Windows 10+, Linux, OS-X.

Hakbang 1: Kolektahin / Lumikha ng Mga Pantustos

Kolektahin / Lumikha ng Mga Pantustos
Kolektahin / Lumikha ng Mga Pantustos

Inirerekumenda namin ang paggamit ng STM32CubeIDE upang mai-load at magamit ang halimbawang proyekto ng firmware na ito. Ang STM32CubeIDE ay isang libreng IDE batay sa Eclipse na binago ng STMicroelectronics upang isama ang mga tukoy na tool ng STM32. Ang IDE ay maaaring ma-download sa STM32CubeIDE webpage.

Upang mapanatili ang tamang pagpapatakbo ng tool ng pagsasaayos ng aparato ng STM, dapat mo lamang i-edit ang tool sa pagsasaayos ng aparato na nilikha source-code sa pagitan ng pagtutugma ng "USER CODE BEGIN xxx" at "USER CODE END xxx" na mga bloke ng komento.

Susunod, magpasya kung makipag-ugnay sa amin para sa isang CFA10052 programming cable o upang gawin ang iyong sarili. Hindi namin pupunta sa paggawa ng detalye ng cable sa tutorial na ito, ngunit kung nais mong gumawa ng iyong sariling CFA10052 programming cable, mahahanap mo ang mga koneksyon sa pahina ng GitHub, ang pinakamahusay na paraan upang magawa ito ay magsimula sa isang labing-anim na pin ribbon cable at i-splice ito sa cable para sa ST Link.

Hakbang 2: Burahin ang Umiiral na Firmware

Burahin ang Umiiral na Firmware
Burahin ang Umiiral na Firmware
Burahin ang Umiiral na Firmware
Burahin ang Umiiral na Firmware

Kung ang iyong module ng CFA10052 ay puno ng ibinigay na CFA735 o CFA835 firmware kailangan mo munang burahin ang lumalabas na firmware bago mag-install ng bagong firmware. Ang flash memory ay nabasa at isinulat na protektado at dapat na alisin bago ma-load ang pasadyang firmware.

Mayroong dalawang pamamaraan para sa pagtanggal ng naka-install na firmware:

  1. Idiskonekta ang USB cable (o power supply) mula sa module ng CFA10052.
  2. Ikonekta ang CFA10052 sa ST-LINK gamit ang programming cable (tingnan sa itaas), at ang ST-LINK sa host PC.
  3. Hawakan ang mga pindutan ng pataas at pababa sa CFA10052 habang isinasaksak ang USB cable sa CFA10052 (o supply ng kuryente). Ang CFA10052 ay dapat na ipakita ang screen ng Crystalfontz Bootloader.
  4. Patakbuhin ang STM32 ST-LINK Utility. Sa menu na "Target", buksan ang window na "Option Bytes". Sa kahon na "Basahin ang Proteksyon", piliin ang "Antas 0". I-click ang Ilapat. Ang Crystalfontz firmware ay tinanggal na ngayon at ang anumang pasadyang firmware ay maaaring ma-program na ngayon.

Alternatibong pamamaraan (kung hindi mo mailagay ang Crystalfontz Bootloader sa pamamagitan ng paghawak ng mga key):

  1. Idiskonekta ang USB cable (o power supply) mula sa module ng CFA10052.
  2. Ikonekta ang BOOT0 test-point (isang maliit na pad sa likod ng module ng CFA10052, malapit sa konektor ng H1) sa 3.3V o 5V.
  3. Ikonekta ang CFA10052 sa ST-LINK gamit ang programming cable (tingnan sa itaas), at ang ST-LINK sa host PC.
  4. Lakas sa CFA10052 (o ikonekta ito sa USB power). Dapat na blangko ang display.
  5. Patakbuhin ang STM32 ST-LINK Utility. Sa menu na "Target", buksan ang window na "Option Bytes". Sa kahon na "Read Out Protection", piliin ang "Antas 0". I-click ang Ilapat. Ang Crystalfontz firmware ay tinanggal na ngayon at ang anumang pasadyang firmware ay maaaring ma-program na ngayon.
  6. Ang koneksyon ng BOOT0 pin sa 3.3V / 5V ay hindi na kinakailangan.

Hakbang 3: Ipunin at I-load ang Iyong Firmware Sa CFA10052

Compile and Load Your Firmware Onto the CFA10052
Compile and Load Your Firmware Onto the CFA10052

Kapag natanggal ang naibigay na firmware ng Crystalshez, handa ka nang mag-compile at mag-load ng iyong sariling firmware. Para sa mga layunin ng tutorial na ito, nagsuplay kami ng ilang mga alternatibong firmware na nagbibigay sa kontrol ng keypad ng liwanag ng backlight at pagpapakita ng kaibahan.

Upang maipon ang firmware:

  1. Buksan ang STM32CubeIDE
  2. Sa menu ng File, piliin ang I-import, pagkatapos ay "I-import ang Mga Umiiral na Mga Proyto Sa Workspace".
  3. Sa root Directory box, piliin ang direktoryo ng halimbawang firmware na ito.
  4. I-click ang Tapos na pindutan.
  5. Sa Project Explorer, piliin ang cfa10052_example na proyekto, pagkatapos buksan ang Src, at "main.c" na file.
  6. Sa menu ng Project, piliin ang "Build Project".

Upang mai-program at patakbuhin ang firmware sa CFA10052:

  1. Idiskonekta ang USB cable (o power supply) mula sa module ng CFA10052.
  2. Ikonekta ang CFA10052 sa ST-LINK gamit ang programming cable (tingnan sa itaas), at ang ST-LINK sa host PC.
  3. Ikonekta ang USB cable (o power supply) sa CFA10052.
  4. Tiyaking naitayo ang proyekto ng firmware (tingnan ang mga hakbang sa itaas), at lilitaw ang "Mga binary" sa ilalim ng "cfa10052_example" sa Project Explorer.
  5. Kung hindi nakikita ang "Mga Binary", i-right click ang proyektong "cfa10052_example" at piliin ang Refresh.
  6. Piliin ang Run menu, pagkatapos ay ang "Mga Pag-configure ng Pag-debug".
  7. Sa kahon ng pagpipilian ng mga uri ng target na debug sa kaliwa, Mag-right-click sa "STM32 Cortex-M Application", at piliin ang "Bagong Configuration".
  8. Ipapakita ang isang window ng pagsasaayos. OK ang mga default na setting. I-click ang Ilapat pagkatapos ang Close button.
  9. Sa Run menu, piliin ang "Debug As", pagkatapos ang "STM32 Cortex Application". Dapat na kumonekta ang STM32CubeIDE sa ST-LINK, at i-upload at patakbuhin ang firmware sa CFA10052.

Ang mga hakbang sa itaas ay kinakailangan lamang sa paglo-load ng proyekto sa unang pagkakataon sa STM32CubeIDE. Matapos magawa ang mga pagbabago sa source-code ng firmware, muling itatayo ang proyekto (pintasan ng Ctrl-B) at pag-program ng CFA10052 (F11 key shortcut) ang kinakailangan.

Maaari ding mai-load ang firmware gamit ang alinman sa normal na mga pamamaraan ng bootloader ng STM32 (magagamit lamang ang pag-debug gamit ang interface ng SWD at isang ST-LINK). Halimbawa, kung gumagamit ng serial connection, maaaring magamit ang USART1 (RX = H1-Pin1 at TX = H1-Pin2). Para sa mas detalyadong impormasyon tungkol sa bootloader at mga interface ng STM32, tingnan ang PDF dito.

Hakbang 4: Mga Lisensya

Ang mapagkukunang-code na ibinigay ng Crystalbestz ay ibinibigay gamit ang The Unlicense, isang lisensya na walang mga kundisyon na kung saan ay naglalaan ng mga gawa sa pampublikong domain. Ang mga hindi lisensyang gawa, pagbabago, at mas malalaking gawa ay maaaring maipamahagi sa ilalim ng iba't ibang mga termino at walang source code. Tingnan ang UNLICENCE file, o unlicense.org para sa mga detalye.

Ang STM32CubeIDE ay lumikha ng source-code at mga aklatan ng STMicroelectronics ay Copyright (c) 2019 STMicroelectronics. Nakalaan ang lahat ng mga karapatan. Ang sangkap ng software ay lisensyado ng ST sa ilalim ng lisensya ng BSD 3-Clause, ang "Lisensya"; Maaaring hindi mo magamit ang mga file na ito maliban sa pagsunod sa Lisensya. Maaari kang makakuha ng isang kopya ng Lisensya sa opensource.org/licenses/BSD-3- Clause.