1

Problem programming custom PCBs on nrf51822

Ali M gravatar image

asked 2014-02-23 02:01:03 +0200

Hi, I tried my best to solve my problem via forum but unfortunately no success. I got nrf51 DK and played with it a lot. successfully program the samples and tweak them a bit. using SDK 5.1 and s110 v6.

The problem starts when I try custom boards. I have made one based on QFAAC0 for which:

I have same problem with a board I purchased online, PTR5528 which is based on CEAA . Can program blinky but no BLE.

Is there something that I am doing wrong. I did connect the board to 3 V and connected the segger programmer pins as explained in the forum (That's how I program without an error)

Thanks in advanced for your help, Ali

edit retag flag offensive close delete report spam

8 answers

Sort by » oldest newest most voted
2
GerryO gravatar image

answered 2014-02-23 23:37:29 +0200

OK, good. Since blinky runs your custom board hardware is generally OK & this could be a Soft Device resource issue. I got bit at first because the custom board I was working with didn't have a 32 KHz crystal, so no BLE (SD-dependent) stuff worked until I changed the clock designation in ble_stack_init(). Since the advertising LED isn't even blinking (assuming you redefined the pin selection for your board) I'd guess that one of your SD stack calls is failing. You might want to modify the app_error_handler() & see if you can break there & get a stack trace. Good luck!

edit flag offensive delete publish link more

Thanks for the suggestion, I did add the proper lines for internal 32 kHz . NRF_CLOCK->XTALFREQ = CLOCK_XTALFREQ_XTALFREQ_16MHz; NRF_CLOCK->EVENTS_HFCLKSTARTED = 0; NRF_CLOCK->TASKS_HFCLKSTART = 1; while(NRF_CLOCK->EVENTS_HFCLKSTARTED == 0) {} nrf_gpio_pin_set(ALERT_PIN_NO); //use this pin to check if program halts BLE_STACK_HANDLER_INIT(NRF_CLOCK_LFCLKSRC_RC_250_PPM_8000MS_CALIBRATION, BLE_L2CAP_MTU_DEF, ble_evt_dispatch, false); The program runs smoothly on PCA10006 when I disconnect the external 32khz oscillator but when I test the same hex file and stack on my custom board, it stops in the while loop, i.e. the HF Clock does not start. any Idea? (The PCA10006 uses a QFAAG0 chip while mine is QFAAC0, use s110 v5.2.1 and SDK 4.4.2 that are supposed to be compatible with both chips according to the compatibility table of RM)

Ali Mahmoudzadeh ( 2014-02-25 05:46:39 +0200 )editconvert to answer
2
bobthebuilder gravatar image

answered 2014-04-08 07:39:26 +0200

Well, tracked it down. It was the board I was using only had the 16Mhz xtal, no 32khz, so had to make a small change for it to work. Note that I'm using the latest SDK (5.2) and SD (6.0) with the QFAAC0 and it is ok for this application... YMMV..

Modify the function below to use the NRF_CLOCK_LFCLKSRC_SYNTH_250_PPM instead.. This was for a Xuntong board..

static void ble_stack_init(void) { uint32_t err_code;

// Initialize the SoftDevice handler module.
SOFTDEVICE_HANDLER_INIT(NRF_CLOCK_LFCLKSRC_SYNTH_250_PPM, false);

// Register with the SoftDevice handler module for BLE events.
err_code = softdevice_ble_evt_handler_set(ble_evt_dispatch);
APP_ERROR_CHECK(err_code);

// Register with the SoftDevice handler module for BLE events.
err_code = softdevice_sys_evt_handler_set(sys_evt_dispatch);
APP_ERROR_CHECK(err_code);

}

edit flag offensive delete publish link more

Comments

1

Just FYI, I've been told that without having an external 32 KHz crystal, the 2 viable options for running the stack are (a) the synthesized 32 KHz source (as in, synthesized from 16 MHz) or (b) the internal 32 KHz oscillator. My understanding is that the synthesized source may be more accurate but will use more power than the internal oscillator. Nordic says the internal oscillator is sufficiently accurate for the BLE stack. If power consumption is a concern, you may wish to investigate. Also, I found (the hard way) that when using the synth source, the RTC wasn't running, but with the int osc it does. YMMV. Synth: NRF_CLOCK_LFCLKSRC_SYNTH_250_PPM Int osc: NRF_CLOCK_LFCLKSRC_RC_250_PPM_4000MS_CALIBRATION (there are other calibration interval options but allegedly this is accurate enough for the BLE stack)

Gerry Ortoli ( 2014-04-08 13:54:33 +0200 )editconvert to answer

Thanks for this! Saved me at the end of e very frustrating day bringing up a new board.

sd ( 2014-06-26 23:16:28 +0200 )editconvert to answer
1

answered 2014-05-07 01:30:44 +0200

Hi Chris

Thank you very much for tracking this down. Fixed the same perplexing problem for me.

I have a custom PCB based on the nRF51822 reference designs in the data sheet. The SoftDevice and memory map all were set up correctly. Test GPIO code integrated with inactive S110 SoftDevice and worked fine.

Yet when running ble_app_hrs example code, main() worked up to ble_stack_init. At that point line 231 of softdevice_handler.c ....

err_code = sd_softdevice_enable(clock_source, softdevice_assertion_handler);

... would cause a hang inside the SoftDevice in a loop between 0x237C to 0x2382.

Fix was as you describe:

SOFTDEVICE_HANDLER_INIT(NRF_CLOCK_LFCLKSRC_SYNTH_250_PPM, false);

I was not aware that SD110 was configured expecting an external 32KHz xtal. Looked again and didn't see reference to that in the nRF51822 data sheet, SDK or S110 documentation.

Liam

edit flag offensive delete publish link more
1
bluesea gravatar image

answered 2014-05-07 11:04:55 +0200

Hi,all

  if your  PCB based on the nRF51822 reference designs in the data sheet.

The SoftDevice and memory map all were set up correctly. Test GPIO code integrated with inactive S110 SoftDevice and worked fine.

Yet when running ble_app_hrs example code, main() worked up to ble_stack_init. At that point line 231 of softdevice_handler.c ....

1)please do it: if your PCB hasn't no xtal 32khz,you need to modify "ble_tack_init(void)" BLE_STACK_HANDLER_INIT(NRF_CLOCK_LFCLKSRC_RC_250_PPM_1000MS_CALIBRATION, BLE_L2CAP_MTU_DEF, ble_evt_dispatch, false);

2)the problem is still,please to do it.

the xtal 16M Crystal has broken,so you need to replace by a new xtal 16M .

edit flag offensive delete publish link more
0
GerryO gravatar image

answered 2014-02-23 07:40:41 +0200

OK, since you didn't explicitly mention it, have you loaded the Soft Device into your custom board using nRFgo Studio? You'll need to do that (at least once) as a separate step for your custom device.

edit flag offensive delete publish link more
0
Ali M gravatar image

answered 2014-02-23 10:57:48 +0200

Sorry if was not clear enough, Yes. I did load the soft device. I programmed the hex file for the soft device and the output hex file of the keil through nRFgo. This worked fine with DK breakout boards and EK board. I sucessfully loaded Blinky, Hrs and proximity examples on these boards using SDK 5.1 and s110 v6.

When I try my own pcbs, I know that I should go to lower versions of SDK and soft device, I installed SDK 4.4.2 (and 4.4.1) and compiled the examples through keil. Flashed s110 v5 (and then v5.2) and the keil output through nRFgo studio, but unfortunately the BLE examples does not run on my boards while the blinky works just fine.

edit flag offensive delete publish link more
0
bobthebuilder gravatar image

answered 2014-04-07 09:39:00 +0200

I'm having similar trouble with QFAAC0, it basically hangs on the SOFTDEVICE_HANDLER_INIT code... same sequence of loading works fine on the DK board (newer/diff rev chip)...

I'm running s110 v6 ..... bit annoying as I've just picked up 10 of these little boards to use and dead in the water with them at the mo.

Did you have any resolution to this problem?

edit flag offensive delete publish link more
0
bobthebuilder gravatar image

answered 2014-04-08 22:06:46 +0200

Ahh yeah, I read that about the power.. not sure how much worse it is. Problem getting cheap OEM boards is they cut every possible cost. I'm surprised that a simple RC is good for BLE.. would think it'd drift/be quite uncalibrated...

Good info tho, thanks for that.

edit flag offensive delete publish link more

Your Answer

Please start posting anonymously - your entry will be published after you log in or create a new account.

Add Answer. Do not ask a new question or reply to an answer here.

[hide preview]

User menu

    or sign up

Recent questions

Question Tools

1 follower

Stats

Asked: 2014-02-23 02:01:03 +0200

Seen: 7,168 times

Last updated: Feb 23 '14