Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

nRF52: update from 0.33 -> 0.34 causes 500x idle-current #4597

Open
perttierkkila opened this issue Nov 13, 2024 · 6 comments
Open

nRF52: update from 0.33 -> 0.34 causes 500x idle-current #4597

perttierkkila opened this issue Nov 13, 2024 · 6 comments
Labels
nRF Nordic Semi

Comments

@perttierkkila
Copy link
Contributor

perttierkkila commented Nov 13, 2024

For ultra-low power applications where all peripherials are disabled and usually under 1.5uA SystemON currents, update to 0.34 was a bad mistake which caused 600uA idle current. After debugging, something keeps requesting HF-clock.

I tried to check diffs between 0.33 and 0.34 and I can't find any changes related to nRF52-parts. The problem is caused under initAll()-code. I tried to dig that part also but no luck as it goes to compiler-part.

Example code:

func main() {
	arm.EnableIRQ(uint32(nrf.IRQ_RTC1)) // workaround to keep IRQs running, already fixed in dev

	led := machine.P0_20
	led.Configure(machine.PinConfig{Mode: machine.PinOutput})
	for {
		led.Set(nrf.CLOCK.HFCLKSTAT.Get()>>16 == 1)
		time.Sleep(10 * time.Millisecond)
		led.Low()
		time.Sleep(500 * time.Millisecond)
	}
}

Serial, GC and scheduler disabled, flashing with command:
tinygo flash -size=short -scheduler=none -gc=none -serial=none -target=pca10040 -programmer command main.go

Output:

  • 0.34: led blinks, current 600uA+ (led uses minimal current compared to HF-clock)
  • 0.33: no blinking, current under 1.5uA

Also tried to play with -opt values, no effect. Except -opt=0 which keeps current under 1.5uA but code is not running either. Any ideas which causes this issue?

@sago35
Copy link
Member

sago35 commented Dec 7, 2024

@aykevl Please give some hints.

@aykevl
Copy link
Member

aykevl commented Dec 14, 2024

How do I reproduce this issue?
It makes sense that HFCLK is running while the code is running. So I think when reading from this register, it will always be set to "1".

I have the following test code, flashed on a PCA10056:

package main

import (
	"device/nrf"
	"machine"
	"time"
)

func main() {
	led := machine.LED
	led.Configure(machine.PinConfig{Mode: machine.PinOutput})
	for {
		led.Set(nrf.CLOCK.HFCLKSTAT.Get()>>16 == 1)
		time.Sleep(500 * time.Millisecond)
		led.Low()
		time.Sleep(500 * time.Millisecond)
	}
}

It blinks in both v0.33.0 and v0.34.0.

@aykevl
Copy link
Member

aykevl commented Dec 14, 2024

After debugging, something keeps requesting HF-clock.

What do you mean by this? After running tinygo gdb?
Yes, the chip will continue to use lots of current after doing on-chip debugging. The only way to get to normal (low current) behavior is by power cycling. This is a hardware limitation, not a TinyGo bug.

@perttierkkila
Copy link
Contributor Author

You must use option -serial=none to test actual consumption. Default setting with UART always requires HF-clock and hides a problem.

I just tried to find issues with gdb, no luck. Actual tests were done in standard-mode with option -serial=none

@deadprogram deadprogram added the nRF Nordic Semi label Jan 13, 2025
@perttierkkila
Copy link
Contributor Author

Tested with 0.35, behaves like 0.34 => 600uA+ sleep-current.

I assume there is now something running extensively in background which causes CPU wakeups and this requests HF-clock.

Measurement from 0.35:
Image

@perttierkkila
Copy link
Contributor Author

And same measurement, ONLY changed thing is tinygo version 0.35->0.33. Same code, same hardware and same command.

Image

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
nRF Nordic Semi
Projects
None yet
Development

No branches or pull requests

4 participants