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

Reduce the size of tcb #15345

Merged
merged 1 commit into from
Jan 2, 2025
Merged

Reduce the size of tcb #15345

merged 1 commit into from
Jan 2, 2025

Conversation

wangzhi-art
Copy link
Contributor

@wangzhi-art wangzhi-art commented Dec 26, 2024

Note: Please adhere to Contributing Guidelines.

Summary

Why the old code is not needed anymore?

There is a variable tcb->sigdeliver in the current tcb structure, which is used to determine whether there is a new signal to be processed. When there is a signal to be processed, the address of the nxsig_deliver function will be assigned to tcb->sigdeliver. At the same time, if there are other signals to be processed, it will first determine whether the value of tcb->sigdeliver is empty. All signal processing is in the nxsig_deliver function, so we can call this function directly; and when judging whether there is a new signal to be delivered, we can add a flag bit TCB_FLAG_SIGDELIVER in tcb->flags. Only one bit is needed to achieve the previous effect, which optimizes both execution time and space.

Is there some drawback after removing these lines of code?

There are no drawback so far.

Impact

None.

Testing

Testcase ostest is executed without failure in the smp environment of armv7a and armv8a.

@github-actions github-actions bot added Arch: arm Issues related to ARM (32-bit) architecture Arch: arm64 Issues related to ARM64 (64-bit) architecture Arch: avr Issues related to all AVR(8-bit or 32-bit) architectures Arch: ceva Issues related to CEVA architecture Arch: mips Issues related to the MIPS architecture Arch: openrisc Issues related to the OpenRISC architecture Arch: renesas Issues related to the Renesas chips Arch: risc-v Issues related to the RISC-V (32-bit or 64-bit) architecture Arch: simulator Issues related to the SIMulator Arch: sparc Issues related to the SPARC architecture Arch: tricore Issues related to the TriCore architecture from Infineon Arch: x86 Issues related to the x86 architecture Arch: x86_64 Issues related to the x86_64 architecture Arch: xtensa Issues related to the Xtensa architecture Arch: z16 Issues related to the Z16 architecture Arch: z80 Issues related to the Z80 architecture Area: Drivers Drivers issues Area: OS Components OS Components issues Size: L The size of the change in this PR is large labels Dec 26, 2024
@wangzhi-art wangzhi-art marked this pull request as draft December 26, 2024 04:00
@wangzhi-art wangzhi-art marked this pull request as ready for review December 26, 2024 04:00
@nuttxpr
Copy link

nuttxpr commented Dec 26, 2024

[Experimental Bot, please feedback here]

No, this PR description does not fully meet the NuttX requirements. While it provides a summary and testing information, it lacks crucial details required for proper review. Here's a breakdown of what's missing and how to improve it:

Missing Information & Suggested Improvements:

  • Summary:

    • Why is this change necessary? The summary states what the change does, but not why. Is nxsig_deliver causing a performance bottleneck? Is it a maintainability issue? Explain the motivation for this change.
    • What functional part of the code is being changed? Be more specific than "tcb". Which files are modified? Mentioning specific modules or subsystems within NuttX would be helpful.
    • How exactly does the change work? The summary is a bit vague. Describe the mechanism of using a flag bit. What flag bit is used? How does the logic change for signal delivery with this new flag?
    • Related Issues: Are there any related NuttX or NuttX Apps issues? If not, explicitly state "None."
  • Impact: While stating "Code modification is imperceptible to users" is a good start, you need to specifically address all the impact points with either "NO" or "YES (and explanation)":

    • New/Changed Feature: NO
    • Impact on User: NO
    • Impact on Build: Likely NO, but confirm. If there are any changes to Kconfig options or build dependencies, explain them.
    • Impact on Hardware: Specify the architectures tested (armv7a, armv8a). Were any specific boards used? State YES and list them if applicable. Otherwise, if it's architecture-generic, explain why.
    • Impact on Documentation: NO (unless documentation needs to be updated to reflect the internal code changes, in which case say YES and provide details).
    • Impact on Security: Carefully consider this! Does changing the signal handling mechanism introduce any potential security vulnerabilities? Justify your answer (NO/YES).
    • Impact on Compatibility: NO (presumably, but explain why you think so). Does this change affect any existing drivers or applications?
    • Anything else to consider: Mention any potential risks or edge cases that reviewers should be aware of.
  • Testing:

    • Build Host(s): Provide details about your build host environment: OS, CPU architecture, compiler version (e.g., "Linux x86_64, GCC 12.2.0").
    • Target(s): Be more specific: "sim:qemu-system-arm", "board:stm32f4discovery:default", etc.
    • Testing Logs: The provided logs are placeholders. Include actual logs or output demonstrating the test results before and after the change. If the output is too long, consider attaching a file or linking to a CI run. Show that the change works as expected and doesn't introduce regressions. What specific aspects of ostest were tested?

By addressing these points, you'll create a much more comprehensive and reviewable PR, increasing its chances of being accepted. Remember to follow the contributing guidelines carefully.

@hujun260
Copy link
Contributor

fix compile error

Copy link
Contributor

@acassis acassis left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@wangzhi-art please include more details in the git commit log message to explain why the old code is not needed anymore. Is there some drawback after removing these lines of code?

@wangzhi-art wangzhi-art force-pushed the dev branch 2 times, most recently from 5da65c8 to 817406d Compare December 30, 2024 06:11
@wangzhi-art
Copy link
Contributor Author

@wangzhi-art please include more details in the git commit log message to explain why the old code is not needed anymore. Is there some drawback after removing these lines of code?

Done

@wangzhi-art wangzhi-art reopened this Dec 31, 2024
@github-actions github-actions bot added Size: XS The size of the change in this PR is very small and removed Size: L The size of the change in this PR is large labels Dec 31, 2024
@wangzhi-art wangzhi-art reopened this Dec 31, 2024
@github-actions github-actions bot added Size: L The size of the change in this PR is large and removed Size: XS The size of the change in this PR is very small labels Dec 31, 2024
@wangzhi-art wangzhi-art reopened this Dec 31, 2024
arch/misoc/src/minerva/minerva_sigdeliver.c Outdated Show resolved Hide resolved
include/nuttx/sched.h Outdated Show resolved Hide resolved
arch/z80/src/z80/z80_sigdeliver.c Outdated Show resolved Hide resolved
arch/z80/src/z80/z80_sigdeliver.c Outdated Show resolved Hide resolved
arch/z80/src/z180/z180_sigdeliver.c Outdated Show resolved Hide resolved
arch/avr/src/avr/avr_sigdeliver.c Outdated Show resolved Hide resolved
arch/avr/src/avr32/avr_sigdeliver.c Outdated Show resolved Hide resolved
arch/ceva/src/common/ceva_sigdeliver.c Outdated Show resolved Hide resolved
arch/z80/src/ez80/ez80_sigdeliver.c Outdated Show resolved Hide resolved
@xiaoxiang781216 xiaoxiang781216 merged commit 893c5e9 into apache:master Jan 2, 2025
27 checks passed
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: arm64 Issues related to ARM64 (64-bit) architecture Arch: avr Issues related to all AVR(8-bit or 32-bit) architectures Arch: ceva Issues related to CEVA architecture Arch: mips Issues related to the MIPS architecture Arch: openrisc Issues related to the OpenRISC architecture Arch: renesas Issues related to the Renesas chips Arch: risc-v Issues related to the RISC-V (32-bit or 64-bit) architecture Arch: simulator Issues related to the SIMulator Arch: sparc Issues related to the SPARC architecture Arch: tricore Issues related to the TriCore architecture from Infineon Arch: x86 Issues related to the x86 architecture Arch: x86_64 Issues related to the x86_64 architecture Arch: xtensa Issues related to the Xtensa architecture Arch: z16 Issues related to the Z16 architecture Arch: z80 Issues related to the Z80 architecture Area: Drivers Drivers issues Area: OS Components OS Components issues Size: L The size of the change in this PR is large
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants