[異常解決] How to build a gcc toolchain for nRF51 on linux (very detailed!!!)

 

一、Install gcc-arm-none-eabihtml

https://devzone.nordicsemi.com/tutorials/7/ This link shows that development with GCC and Eclipse, As it say we should download 、extract and configure arm-none-eabi-gcc. But I find it's hard to download arm-none-eabi-gcc in China(You can chose XunLei to download). Besides I find a easy way to install it in Ubuntu-16.04 as following:
linux

beautifulzzzz@lpc:~$ arm-none-eabi-gcc --version
The program 'arm-none-eabi-gcc' is currently not installed. You can install it by typing:
sudo apt install gcc-arm-none-eabi
beautifulzzzz@lpc:~$ sudo apt install gcc-arm-none-eabi

 

二、Download Nordic nRF5x SDKubuntu

Download the least nRF5x SDK from http://developer.nordicsemi.com/nRF5_SDK/ (the same to the arm-none-eabi-gcc, you can chose the XunLei to download) ,and then extract it in SDK-DIR(as you wish). The following shows the composition of SDK:windows

beautifulzzzz@lpc:~/Documents/nRF5_SDK_12.2.0_f012efa$ tree -L 2
. ├── components │   ├── ant │   ├── ble │   ├── boards │   ├── device │   ├── drivers_ext │   ├── drivers_nrf │   ├── libraries │   ├── nfc │   ├── proprietary_rf │   ├── sdk_validation.h │   ├── serialization │   ├── softdevice │   └── toolchain ├── documentation │   ├── index.html │   ├── license.txt │   ├── NordicS.jpg │   ├── nRF5x_series_logo.png │   └── release_notes.txt ├── examples │   ├── ant │   ├── ble_central │   ├── ble_central_and_peripheral │   ├── ble_peripheral │   ├── crypto │   ├── dfu │   ├── dtm │   ├── multiprotocol │   ├── nfc │   ├── peripheral │   ├── proprietary_rf │   └── readme.txt ├── external │   ├── cifra_AES128-EAX │   ├── fatfs │   ├── freertos │   ├── licenses_external.txt │   ├── micro-ecc │   ├── nano-pb │   ├── nfc_adafruit_library │   ├── nrf_cc310 │   ├── protothreads │   ├── rtx │   ├── segger_rtt │   └── tiny-AES128 ├── licenses.txt ├── nRF5x_MDK_8_11_1_IAR.msi ├── nRF5x_MDK_8_11_1_Keil4.msi └── svd ├── nrf51.svd ├── nrf52840.svd └── nrf52.svd

 

三、Before Use Makefile To Bulid nRF51 Projectapp

To build an example in the SDK you first need to set the toolchain path in makefile.windows or makefile.posix depending on platform you are using. That is, the .posix should be edited if your are working on either Linux or OS X. These files are located in:ide

<SDK>/components/toolchain/gcc

Open the file in a text editor, and make sure that the GNU_INSTALL_ROOT variable is pointing to your Gnu tools for ARM embedded Processors install directory.post

Correct values for my current setup(my arm-none-eabi-gcc install in /usr/bin):ui

GNU_INSTALL_ROOT :=/usr
GNU_VERSION := 4.9.3
GNU_PREFIX := arm-none-eabi

 

四、Use Makefile To Bulid nRF51 Projectthis

Now you can try to build one of the example projects. Will use the blinky example here to keep it simple:url

Open terminal and change directory to:

<SDK>/examples/peripheral/<board name>/blank/armgcc/

Type 'make'. GNU Make should start the build using the Makefile and output the result in the _build directory. If everything works you should get the output shown in the screenshot below. 

If you instead get an error saying something like "the sysem cannot find the files specified" it typically means that the GNU toolchain path is set incorrectly. Verify the path in makefile.windows/posix if you get this.

 

五、Install JLink-driver-for-linux

Refer to the blog: [異常解決] ubuntu上安裝JLink驅動遇到的坑及給後來者的建議,downloading the corresponding version driver is ok. But I find that the older version driver(older then 5.12) cna't find!!!

Unfortunately my JLink version is 4.80. Finally, I find a Jlink-Linux-v480h-x64  in CSDN: http://download.csdn.net/download/u013903297/6990853 and I also upload it in: https://pan.baidu.com/s/1qXN2uOc. This file is not *.deb file, so we should install it as following:

beautifulzzzz@lpc:~/Downloads$ sudo cp JLink_Linux_V480h_x86_64.tgz /dev/bus
...
beautifulzzzz@lpc:/dev/bus$ sudo tar zxvf JLink_Linux_V480h_x86_64.tgz
beautifulzzzz@lpc:/dev/bus$ sudo rm JLink_Linux_V480h_x86_64.tgz 

Now plug the JLink device into the USB and then goto the install-path(here is /dev/bus/JLink_Linux_V480h_x86_64), type ./JLinkExe command, you will see(as following screenshot) a Contex-M0 device was fond and the target interface speed is 100khz. If could not find a device, please check whether the JLink device is inserted or the JLink driver version is correct.

 

六、Loadfile into nRf5x

Now you can use some JLink commands to erase、load、run、quit...

/* Open Jlink Commander from terminal in _build directory */ 
JLinkExe  -device <nRF51/nRF52>
> erase // Optional: erase target if not already blank
> loadfile <name>.hex // loads FW
> r // Reset and halt
> g // Run
> q //  Exit

If you get an error (Error: Programming failed @ address 0x00000000 (block verification error)) when tpye erase\loadfile command, you should write one and two to the memory at 4001E50C and 4001E504:(get this from: Getting started with nRF51 development on Mac OS X)

Afer erase whole chip, loading the file into nRF51 is simple—— For simplicity in this tutorial copy the softdevice (S110) .hex file to the _build folder of the Heart Rate Monitor example. The programming is performed from the _build folder:

_build em$ JLinkExe -device nrf51822_xxaa -if swd -speed 4000
[...]
J-Link>loadbin s110_nrf51822_7.0.0_softdevice.bin 0
J-Link>loadbin ble_app_hrs_s110_xxaa.hex 0x16000
J-Link>r
J-Link>g
J-Link>exit

Setting the correct device is crucial, and the speed setting is needed to make the programming fast enough. The softdevice is first programmed in the beginning (location 0) and the application is programmed immediately after (0x16000 for S110 v7.0). After the programming a reset is needed ('r' + 'g').

 

Next I will write use MakeFile to achieve automating tasks~

 


@beautifulzzzz
智能硬件、物聯網,熱愛技術,關注產品
博客:http://blog.beautifulzzzz.com
sina:http://weibo.com/beautifulzzzz?is_all=1
相關文章
相關標籤/搜索