Skip to content
GitLab
Explore
Sign in
Register
Primary navigation
Search or go to…
Project
Skyward Boardcore
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Model registry
Analyze
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
Avionics
Software Development
Skyward Boardcore
Compare revisions
5ad59db48830f158deddf02284625cdadfbf05f7 to eaa8b77c4e5fafed2b3b561f2f11f929fdfc17f4
Compare revisions
Changes are shown as if the
source
revision was being merged into the
target
revision.
Learn more about comparing revisions.
Source
avn/swd/skyward-boardcore
Select target project
No results found
eaa8b77c4e5fafed2b3b561f2f11f929fdfc17f4
Select Git revision
Swap
Target
avn/swd/skyward-boardcore
Select target project
avn/swd/skyward-boardcore
emilio.corigliano/skyward-boardcore
ettore.pane/skyward-boardcore
giulia.facchi/skyward-boardcore
valerio.flamminii/skyward-boardcore
nicolo.caruso/skyward-boardcore
6 results
5ad59db48830f158deddf02284625cdadfbf05f7
Select Git revision
Show changes
Only incoming changes from source
Include changes to target since source was created
Compare
Commits on Source (1)
[WIZ5500, FIX] Enforcing exit from recv when timeout expires
· eaa8b77c
Nicolò Caruso
authored
6 months ago
There were missing checks with the timeout to exit from the recv function
eaa8b77c
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
src/shared/drivers/WIZ5500/WIZ5500.cpp
+6
-0
6 additions, 0 deletions
src/shared/drivers/WIZ5500/WIZ5500.cpp
with
6 additions
and
0 deletions
src/shared/drivers/WIZ5500/WIZ5500.cpp
View file @
eaa8b77c
...
...
@@ -25,6 +25,7 @@
#include
<drivers/interrupt/external_interrupts.h>
#include
<interfaces/endianness.h>
#include
<kernel/scheduler/scheduler.h>
#include
<utils/Debug.h>
#include
<utils/KernelTime.h>
#include
"WIZ5500Defs.h"
...
...
@@ -467,6 +468,8 @@ int Wiz5500::waitForSocketIrq(miosix::Lock<miosix::FastMutex>& l, int sock_n,
while
(
wait_infos
[
i
].
irq
==
0
&&
result
==
TimedWaitResult
::
NoTimeout
&&
interrupt_service_thread
!=
this_thread
)
{
if
(
Kernel
::
getOldTick
()
>
start
+
timeout
)
break
;
if
(
timeout
!=
-
1
)
{
result
=
Kernel
::
Thread
::
IRQenableIrqAndTimedWaitMs
(
...
...
@@ -487,6 +490,9 @@ int Wiz5500::waitForSocketIrq(miosix::Lock<miosix::FastMutex>& l, int sock_n,
while
(
interrupt_service_thread
==
this_thread
)
{
if
(
Kernel
::
getOldTick
()
>
start
+
timeout
)
break
;
// Run a single step of the ISR
runInterruptServiceRoutine
(
l
);
...
...
This diff is collapsed.
Click to expand it.