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

up_rtc_gettime: add spinlock to protect up_rtc_gettime #15413

Merged
merged 3 commits into from
Jan 6, 2025

Conversation

hujun260
Copy link
Contributor

@hujun260 hujun260 commented Jan 3, 2025

Summary

up_rtc_gettime: add spinlock to protect up_rtc_gettime

Impact

up_rtc_gettime

Testing

ci

@github-actions github-actions bot added Arch: arm Issues related to ARM (32-bit) architecture Arch: renesas Issues related to the Renesas chips Arch: x86_64 Issues related to the x86_64 architecture Size: M The size of the change in this PR is medium labels Jan 3, 2025
@nuttxpr
Copy link

nuttxpr commented Jan 3, 2025

[Experimental Bot, please feedback here]

No, this PR does not fully meet the NuttX requirements. While it provides a summary of the change, it lacks crucial details. Here's a breakdown:

Missing Information:

  • Summary: While the title mentions adding a spinlock, the why is missing. What race condition or problem does this fix? Which part of the code is changed (the specific function is mentioned, but a more general area like "RTC driver" would be helpful)? How does the spinlock solve the problem? Issue numbers are missing.
  • Impact: The impact section is severely lacking. It just repeats the function name. All the YES/NO questions need to be answered with explanations. Does this change affect any particular architectures, boards, or drivers? Does it change the API? Does it require documentation updates? Are there security implications of adding this lock?
  • Testing: "ci" is insufficient. What specific targets were tested? What tests were run? Actual log output (or a link to it) demonstrating the problem before the change and the successful operation after the change is needed. Host build environment information is also missing.

Example of how to improve the Summary:

"The up_rtc_gettime function was prone to race conditions when accessed concurrently from multiple threads, potentially leading to incorrect time readings. This change adds a spinlock to protect access to the RTC hardware during the up_rtc_gettime operation within the common RTC driver code. This fixes [Issue #XYZ]. This change also affects the up_rtc_settime function, which now also acquires the same spinlock.

Example of how to improve the Impact:

  • Is new feature added? NO
  • Is existing feature changed? YES, the up_rtc_gettime and up_rtc_settime functions are now thread-safe.
  • Impact on user (will user need to adapt to change)? NO
  • Impact on build (will build process change)? NO
  • Impact on hardware (will arch(s) / board(s) / driver(s) change)? NO. This change is within the common RTC driver code, so all architectures using this driver benefit.
  • Impact on documentation (is update required / provided)? YES, the documentation for up_rtc_gettime and up_rtc_settime should mention the thread-safety improvements. A documentation update is included in this PR.
  • Impact on security (any sort of implications)? NO
  • Impact on compatibility (backward/forward/interoperability)? NO
  • Anything else to consider? The addition of the spinlock introduces a small performance overhead.

Example of how to improve the Testing:

  • Build Host(s): Linux (Ubuntu 20.04), x86_64, GCC 9.4.0
  • Target(s): sim:qemu-arm, stm32f4discovery:nsh

Testing logs before change: (demonstrate the race condition - e.g., inconsistent time readings from two threads accessing the RTC simultaneously)

... log output showing the problem ...

Testing logs after change: (show consistent time readings and no errors)

... log output showing the fix ...

Or:
Testing logs are available in the CI run for this PR: [Link to CI run]

By providing this level of detail, reviewers can quickly understand the change, its impact, and verify its correctness, leading to a faster and smoother review process.

arch/x86_64/src/intel64/intel64_rtc.c Outdated Show resolved Hide resolved
arch/x86_64/src/intel64/intel64_rtc.c Outdated Show resolved Hide resolved
arch/arm/src/cxd56xx/cxd56_rtc.c Outdated Show resolved Hide resolved
arch/arm/src/max326xx/max32660/max32660_rtc.c Outdated Show resolved Hide resolved
arch/arm/src/sam34/sam_rtc.c Outdated Show resolved Hide resolved
arch/arm/src/sam34/sam_rtc.c Outdated Show resolved Hide resolved
arch/renesas/src/rx65n/rx65n_rtc.c Show resolved Hide resolved
arch/renesas/src/rx65n/rx65n_rtc.c Outdated Show resolved Hide resolved
reason:
We have removed the critical section protection
for the up_rtc_gettime function in common code.

Signed-off-by: hujun5 <[email protected]>
@github-actions github-actions bot added the Area: Drivers Drivers issues label Jan 6, 2025
@xiaoxiang781216 xiaoxiang781216 merged commit 4e563e3 into apache:master Jan 6, 2025
27 checks passed
@lupyuen
Copy link
Member

lupyuen commented Jan 7, 2025

Sorry @hujun260 could you check if the PR above is causing these build errors in sim:segger? Thanks :-)
https://github.com/NuttX/nuttx/actions/runs/12637024742/job/35210493873#step:7:287

Configuration/Tool: sim/segger
In file included from segger/SystemView/SEGGER/SEGGER_SYSVIEW.h:65,
                 from segger/SystemView/SEGGER/SEGGER_SYSVIEW_Int.h:64,
                 from segger/SystemView/SEGGER/SEGGER_SYSVIEW.c:146:
segger/SystemView/SEGGER/SEGGER_SYSVIEW.c: In function '_VPrintHost':
Error: segger/SystemView/SEGGER/SEGGER_SYSVIEW_ConfDefaults.h:557:51: error: implicit declaration of function 'SEGGER_RTT_LOCK'; did you mean 'SEGGER_RTT_Read'? [-Werror=implicit-function-declaration]
  557 |   #define SEGGER_SYSVIEW_LOCK()                   SEGGER_RTT_LOCK()
      |                                                   ^~~~~~~~~~~~~~~
segger/SystemView/SEGGER/SEGGER_SYSVIEW.c:387:35: note: in expansion of macro 'SEGGER_SYSVIEW_LOCK'
  387 | #define RECORD_START(PacketSize)  SEGGER_SYSVIEW_LOCK();                            \
      |                                   ^~~~~~~~~~~~~~~~~~~
segger/SystemView/SEGGER/SEGGER_SYSVIEW.c:1005:5: note: in expansion of macro 'RECORD_START'
 1005 |     RECORD_START(SEGGER_SYSVIEW_INFO_SIZE + SEGGER_SYSVIEW_MAX_STRING_LEN + 2 * SEGGER_SYSVIEW_QUANTA_U32 + SEGGER_SYSVIEW_MAX_ARGUMENTS * SEGGER_SYSVIEW_QUANTA_U32);
      |     ^~~~~~~~~~~~
Error: segger/SystemView/SEGGER/SEGGER_SYSVIEW_ConfDefaults.h:570:51: error: implicit declaration of function 'SEGGER_RTT_UNLOCK'; did you mean 'SEGGER_RTT_Init'? [-Werror=implicit-function-declaration]
  570 |   #define SEGGER_SYSVIEW_UNLOCK()                 SEGGER_RTT_UNLOCK()
      |                                                   ^~~~~~~~~~~~~~~~~
segger/SystemView/SEGGER/SEGGER_SYSVIEW.c:390:35: note: in expansion of macro 'SEGGER_SYSVIEW_UNLOCK'
  390 | #define RECORD_END()              SEGGER_SYSVIEW_UNLOCK()
      |                                   ^~~~~~~~~~~~~~~~~~~~~
segger/SystemView/SEGGER/SEGGER_SYSVIEW.c:1015:5: note: in expansion of macro 'RECORD_END'
 1015 |     RECORD_END();
      |     ^~~~~~~~~~

Also for at32f437-mini:systemview
https://github.com/NuttX/nuttx/actions/runs/12637024742/job/35210486919#step:7:128

Configuration/Tool: at32f437-mini/systemview,CONFIG_ARM_TOOLCHAIN_GNU_EABI
In file included from segger/SystemView/SEGGER/SEGGER_SYSVIEW.h:65,
                 from segger/SystemView/SEGGER/SEGGER_SYSVIEW_Int.h:64,
                 from segger/SystemView/SEGGER/SEGGER_SYSVIEW.c:146:
segger/SystemView/SEGGER/SEGGER_SYSVIEW.c: In function '_VPrintHost':
Error: segger/SystemView/SEGGER/SEGGER_SYSVIEW_ConfDefaults.h:557:51: error: implicit declaration of function 'SEGGER_RTT_LOCK'; did you mean 'SEGGER_RTT_Read'? [-Werror=implicit-function-declaration]
  557 |   #define SEGGER_SYSVIEW_LOCK()                   SEGGER_RTT_LOCK()
      |                                                   ^~~~~~~~~~~~~~~

@hujun260
Copy link
Contributor Author

hujun260 commented Jan 7, 2025

Sorry @hujun260 could you check if the PR above is causing these build errors in sim:segger? Thanks :-) https://github.com/NuttX/nuttx/actions/runs/12637024742/job/35210493873#step:7:287

Configuration/Tool: sim/segger
In file included from segger/SystemView/SEGGER/SEGGER_SYSVIEW.h:65,
                 from segger/SystemView/SEGGER/SEGGER_SYSVIEW_Int.h:64,
                 from segger/SystemView/SEGGER/SEGGER_SYSVIEW.c:146:
segger/SystemView/SEGGER/SEGGER_SYSVIEW.c: In function '_VPrintHost':
Error: segger/SystemView/SEGGER/SEGGER_SYSVIEW_ConfDefaults.h:557:51: error: implicit declaration of function 'SEGGER_RTT_LOCK'; did you mean 'SEGGER_RTT_Read'? [-Werror=implicit-function-declaration]
  557 |   #define SEGGER_SYSVIEW_LOCK()                   SEGGER_RTT_LOCK()
      |                                                   ^~~~~~~~~~~~~~~
segger/SystemView/SEGGER/SEGGER_SYSVIEW.c:387:35: note: in expansion of macro 'SEGGER_SYSVIEW_LOCK'
  387 | #define RECORD_START(PacketSize)  SEGGER_SYSVIEW_LOCK();                            \
      |                                   ^~~~~~~~~~~~~~~~~~~
segger/SystemView/SEGGER/SEGGER_SYSVIEW.c:1005:5: note: in expansion of macro 'RECORD_START'
 1005 |     RECORD_START(SEGGER_SYSVIEW_INFO_SIZE + SEGGER_SYSVIEW_MAX_STRING_LEN + 2 * SEGGER_SYSVIEW_QUANTA_U32 + SEGGER_SYSVIEW_MAX_ARGUMENTS * SEGGER_SYSVIEW_QUANTA_U32);
      |     ^~~~~~~~~~~~
Error: segger/SystemView/SEGGER/SEGGER_SYSVIEW_ConfDefaults.h:570:51: error: implicit declaration of function 'SEGGER_RTT_UNLOCK'; did you mean 'SEGGER_RTT_Init'? [-Werror=implicit-function-declaration]
  570 |   #define SEGGER_SYSVIEW_UNLOCK()                 SEGGER_RTT_UNLOCK()
      |                                                   ^~~~~~~~~~~~~~~~~
segger/SystemView/SEGGER/SEGGER_SYSVIEW.c:390:35: note: in expansion of macro 'SEGGER_SYSVIEW_UNLOCK'
  390 | #define RECORD_END()              SEGGER_SYSVIEW_UNLOCK()
      |                                   ^~~~~~~~~~~~~~~~~~~~~
segger/SystemView/SEGGER/SEGGER_SYSVIEW.c:1015:5: note: in expansion of macro 'RECORD_END'
 1015 |     RECORD_END();
      |     ^~~~~~~~~~

Also for at32f437-mini:systemview https://github.com/NuttX/nuttx/actions/runs/12637024742/job/35210486919#step:7:128

Configuration/Tool: at32f437-mini/systemview,CONFIG_ARM_TOOLCHAIN_GNU_EABI
In file included from segger/SystemView/SEGGER/SEGGER_SYSVIEW.h:65,
                 from segger/SystemView/SEGGER/SEGGER_SYSVIEW_Int.h:64,
                 from segger/SystemView/SEGGER/SEGGER_SYSVIEW.c:146:
segger/SystemView/SEGGER/SEGGER_SYSVIEW.c: In function '_VPrintHost':
Error: segger/SystemView/SEGGER/SEGGER_SYSVIEW_ConfDefaults.h:557:51: error: implicit declaration of function 'SEGGER_RTT_LOCK'; did you mean 'SEGGER_RTT_Read'? [-Werror=implicit-function-declaration]
  557 |   #define SEGGER_SYSVIEW_LOCK()                   SEGGER_RTT_LOCK()
      |                                                   ^~~~~~~~~~~~~~~

ok

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Arch: arm Issues related to ARM (32-bit) architecture Arch: renesas Issues related to the Renesas chips Arch: x86_64 Issues related to the x86_64 architecture Area: Drivers Drivers issues Size: M The size of the change in this PR is medium
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants