-
Notifications
You must be signed in to change notification settings - Fork 6.9k
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
Add clocks property to CPUs in nRF54L series which can be used to get CPU clock frequency #83527
base: main
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good, apart from the possible typo :)
dt_prop(clock-frequency PATH "/clocks/hfpll" PROPERTY "clock-frequency") | ||
math(EXPR clock_frequency_mhz "${clock_frequency} / 1000000") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The clock-frequency
on line 187 has a dash in it, ${clock_frequency}
on line 188 does not, is this expected?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
fixed.
e3978b4
to
1382123
Compare
Add clocks property to CPUs. nRF54Lx series is using hfpll as clock source for CPU (and fast peripherals). CPU clock frequency can be derived from frequency of the source clock so clock-frequency property is removed from cpu as it is redundant. nrfx/MDK expects that NRF_CONFIG_CPU_FREQ_MHZ define is set to correct CPU frequency. Modified nrfx CMakeLists.txt to use clock frequency of hfpll instead of CPU clock-frequency property. Signed-off-by: Krzysztof Chruściński <krzysztof.chruscinski@nordicsemi.no>
nrf54l20pdk and nrf54l09pdk must use 64 MHz for now. So far it was done by using SOC_NRF54LX_SKIP_CLOCK_CONFIG Kconfig option which was skipping oscillator configuration so that it was running the default frequency (which is 64 MHz). This approach was a bit cryptic because DT was indicating that CPU was running 128 MHz when actual frequency was different (and it was relying on assumption that default frequency is 64 MHz). After adding hfpll as clock source for CPU Kconfig option can be replaced with DT setting where actual frequency is correctly indicated. Since hfpll is a clock source for fast peripherals (e.g. TIMER00) it is possible to have single source of information regarding frequency. Signed-off-by: Krzysztof Chruściński <krzysztof.chruscinski@nordicsemi.no>
908a7eb
1382123
to
908a7eb
Compare
nrf54l09 was added recently. Updated PR to include nrf54l09. |
@anangl can you take a look? |
Use cpu clock source frequency as system core clock. Signed-off-by: Krzysztof Chruściński <krzysztof.chruscinski@nordicsemi.no>
47c3a5b
@masz-nordic @bjarki-andreasen @nordic-segl can you take another look? I've updated soc.c to use DT value for |
*/ | ||
SystemCoreClockUpdate(); | ||
SystemCoreClock = NRF_PERIPH_GET_FREQUENCY(DT_NODELABEL(cpu)); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't quite get this change. It will only correct the SystemCoreClock
value until the first call to SystemCoreClockUpdate()
. Is that the intention?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nrf54l will have fixed clock configured at compile time (64M or 128M) so we can read from DT (this will work for Secure and Non-Secure builds). Reading directly from oscillator will return the same value but it might not be available for Non-Secure target.
nRF54L CPUs and fast peripherals can run at 64 MHz or 128 MHz. So far DT was indicating that CPU is running at 128 MHz and changing that to 64 MHz did not result in changing actual CPU frequency. On the other hand to use 64 MHz a cryptic Kconfig had to be set (
CONFIG_SOC_NRF54LX_SKIP_CLOCK_CONFIG=y
).Added
clocks = <&hfpll>
property to CPU cores in nRF54L and reworked cmake file so that changinghfpll
frequency in DT results in changing CPU frequency.#82901 is adding same property to TIMERs so that there will be a single source of truth regarding frequency of peripherals clocked by the same source.