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

tests/periph_timer_timeout0: Regression test for timer callbacks setting new timers #10019

Open
wants to merge 2 commits into
base: master
Choose a base branch
from

Conversation

jnohlgard
Copy link
Member

@jnohlgard jnohlgard commented Sep 24, 2018

Contribution description

This test is designed to catch an implementation bug where a timer
callback is called directly from inside timer_set if the given
timeout=0, leading to a stack overflow if timer_set is called from
within the callback of the same timer.

The bug is present on the current revision of the Kinetis LPTMR periph
driver. A bug fix is provided in #10020.

Testing procedure

build and flash tests/periph_timer_timeout0, run make test

Issues/PRs references

#10020 for the bug fix

@jnohlgard jnohlgard added Type: enhancement The issue suggests enhanceable parts / The PR enhances parts of the codebase / documentation Area: tests Area: tests and testing framework CI: ready for build If set, CI server will compile all applications for all available boards for the labeled PR Area: timers Area: timer subsystems CI: run tests If set, CI server will run tests on hardware for the labeled PR labels Sep 24, 2018
@jnohlgard jnohlgard added this to the Release 2018.10 milestone Sep 24, 2018
@jnohlgard jnohlgard force-pushed the pr/test-periph-timer-timeout0 branch from a974b23 to 0dc18fd Compare September 24, 2018 07:23
@MrKevinWeiss MrKevinWeiss self-assigned this May 28, 2019
@kb2ma kb2ma removed this from the Release 2019.10 milestone Oct 8, 2019
@stale
Copy link

stale bot commented Apr 10, 2020

This issue has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. If you want me to ignore this issue, please mark it with the "State: don't stale" label. Thank you for your contributions.

@stale stale bot added the State: stale State: The issue / PR has no activity for >185 days label Apr 10, 2020
@MrKevinWeiss MrKevinWeiss added the State: don't stale State: Tell state-bot to ignore this issue label Apr 14, 2020
@stale stale bot removed the State: stale State: The issue / PR has no activity for >185 days label Apr 14, 2020
@MrKevinWeiss
Copy link
Contributor

This is useful just needs some review time.

@MrKevinWeiss MrKevinWeiss added this to the Release 2021.07 milestone Jun 22, 2021
@MrKevinWeiss MrKevinWeiss removed this from the Release 2021.07 milestone Jul 15, 2021
@MrKevinWeiss
Copy link
Contributor

I rebased and reran but it seems like some things are not so happy

@Teufelchen1 Teufelchen1 force-pushed the pr/test-periph-timer-timeout0 branch from 0dc18fd to 6cdf4c9 Compare January 25, 2024 14:01
@github-actions github-actions bot added Area: doc Area: Documentation and removed Area: timers Area: timer subsystems labels Jan 25, 2024
@Teufelchen1
Copy link
Contributor

Rebased and moved in the new test folder. Test passed on my nrf52dk.

@riot-ci
Copy link

riot-ci commented Jan 25, 2024

Murdock results

FAILED

8f00189 tests: Integrate zero timeout test into timer test

Success Failures Total Runtime
57 1 59 01m:48s
Test failures (1)
Application Target Toolchain Runtime (s) Worker
tests/periph/timer samr21-xpro gnu 24.15 pi-ef3229ad

Artifacts

@Teufelchen1
Copy link
Contributor

The newly introduced tests fails on the samr21-xpro. I think the timer on that board might have a bug.

@maribu
Copy link
Member

maribu commented Mar 18, 2024

I have that board at hands. I do like the test, but I dislike that it creates a new app rather than extending the existing tests/periph/timer app with a new test case. The app isn't that large and will still fit RAM and ROM of all relevant boards.

Consolidating the number of apps a bit reduces CI time and increase the life of boards used for testing by reducing the number of flash cycles per full test run.

@github-actions github-actions bot removed the Area: doc Area: Documentation label Mar 19, 2024
@Teufelchen1
Copy link
Contributor

Teufelchen1 commented Mar 19, 2024

@maribu like this? (And still fails on the samr21xpro)

@Teufelchen1
Copy link
Contributor

There have been some recent CI failures for the tests/sys/shell. I think that is related as the failure occurs on the samr21-xpro when compiled using LLVM inside a periodic timer test.

E.g. see this.


-- running on worker pi-68cf63c4 thread 1, build number 3102.
-- executing tests for tests/sys/shell on samr21-xpro (compiled with llvm toolchain):
- executing hook run_test_pre
- resetting USB power...
- waiting for tty to re-attach...
- hook run_test_pre finished
make: Entering directory '/tmp/dwq.0.8417650337034919/b0edffdfccc3b6b961cda4d7e8c9893f/tests/sys/shell'
/bin/sh: 1: arm-none-eabi-gcc: not found
/tmp/dwq.0.8417650337034919/b0edffdfccc3b6b961cda4d7e8c9893f/dist/tools/edbg/edbg.sh flash /tmp/dwq.0.8417650337034919/b0edffdfccc3b6b961cda4d7e8c9893f/build/tests_shell.bin
### Flashing Target ###
Debugger: ATMEL EDBG CMSIS-DAP ATML2127031800002288 02.01.0157 (S)
Clock frequency: 16.0 MHz
Target: SAM R21G18 (Rev B)
Verification...... done.
Done flashing
make: Nothing to be done for 'termdeps'.
make: Leaving directory '/tmp/dwq.0.8417650337034919/b0edffdfccc3b6b961cda4d7e8c9893f/tests/sys/shell'
make: Entering directory '/tmp/dwq.0.8417650337034919/b0edffdfccc3b6b961cda4d7e8c9893f/tests/sys/shell'
/bin/sh: 1: arm-none-eabi-gcc: not found


/bin/sh: 1: arm-none-eabi-gcc: not found
socat - open:/dev/ttyACM0,b115200,echo=0,raw,cs8,parenb=0,cstopb=0 


> 

> bufsize
bufsize

60
> ____________________________________________________verylong
____________________________________________________verylong

shell: maximum line length exceeded
> garbage1234��
garbage1234

> 

> ��
shell exited
> 

> ��
periodic 5
> 

> periodic 5

> test
Timeout in expect script at "child.expect_exact('test')" (tests/sys/shell/tests/01-run.py:214)

make: *** [/tmp/dwq.0.8417650337034919/b0edffdfccc3b6b961cda4d7e8c9893f/makefiles/tests/tests.inc.mk:26: test] Error 1
make: Leaving directory '/tmp/dwq.0.8417650337034919/b0edffdfccc3b6b961cda4d7e8c9893f/tests/sys/shell'

Joakim Nohlgård and others added 2 commits May 7, 2024 15:59
…ing new timers

This test is designed to catch an implementation bug where a timer
callback is called directly from inside timer_set if the given
timeout=0, leading to a stack overflow if timer_set is called from
within the callback of the same timer.

The bug is present on the current revision of the Kinetis LPTMR periph
driver. A bug fix is provided in a separate commit.
@Teufelchen1 Teufelchen1 force-pushed the pr/test-periph-timer-timeout0 branch from 23de238 to 8f00189 Compare May 7, 2024 13:59
@mguetschow mguetschow added this to the Release 2024.07 milestone Jun 11, 2024
@@ -207,6 +239,53 @@ static int test_timer(unsigned num, uint32_t timer_freq)
return 1;
}


Copy link
Contributor

Choose a reason for hiding this comment

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

Suggested change

timer_set(ctx->dev, chan, 20000u);
timer_set(ctx->dev, chan, 0);
}
mutex_unlock(&ctx->mtx);
Copy link
Contributor

Choose a reason for hiding this comment

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

Can someone explain to me the purpose of the mutex? It is locked in test_timer_timeout and unlocked in the timer callback?

Copy link
Member

Choose a reason for hiding this comment

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

That's a common pattern in RIOT for a thread to wait for an IRQ. Unlike a POSIX mutex, a RIOT mutex can be unlocked from a different context (and even from IRQ context).

The idea is that locking an already locked mutex will block. Unlocking that mutex from the ISR will unblock the thread.

/* Wait until we have executed the zero timeout callback enough times */
while (ctx.counter < TEST_ITERATIONS) {
mutex_lock(&ctx.mtx);
++switches;
Copy link
Contributor

Choose a reason for hiding this comment

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

switches is unused from here on?

@mguetschow mguetschow removed this from the Release 2024.07 milestone Jul 15, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Area: tests Area: tests and testing framework CI: ready for build If set, CI server will compile all applications for all available boards for the labeled PR CI: run tests If set, CI server will run tests on hardware for the labeled PR State: don't stale State: Tell state-bot to ignore this issue Type: enhancement The issue suggests enhanceable parts / The PR enhances parts of the codebase / documentation
Projects
None yet
Development

Successfully merging this pull request may close these issues.

10 participants