aboutsummaryrefslogtreecommitdiff
path: root/rtic-macros/src/syntax/parse.rs
diff options
context:
space:
mode:
authorGravatar Román Cárdenas <rcardenas.rod@gmail.com> 2023-03-29 21:07:36 +0200
committerGravatar GitHub <noreply@github.com> 2023-03-29 21:07:36 +0200
commitce508a1882b1cc8735c4fd901a0ad868da5fe77b (patch)
treee17930b11f05f3bfaba59f3e579dd4f49aae4b91 /rtic-macros/src/syntax/parse.rs
parent06ddfb7ab8d04fa519bf66a40ec7a98a5e04aa07 (diff)
parent31055fa64a6e178caa45f8a8e862ded6a68d3e55 (diff)
downloadrtic-ce508a1882b1cc8735c4fd901a0ad868da5fe77b.tar.gz
rtic-ce508a1882b1cc8735c4fd901a0ad868da5fe77b.tar.zst
rtic-ce508a1882b1cc8735c4fd901a0ad868da5fe77b.zip
Merge branch 'master' into master
Diffstat (limited to 'rtic-macros/src/syntax/parse.rs')
-rw-r--r--rtic-macros/src/syntax/parse.rs7
1 files changed, 6 insertions, 1 deletions
diff --git a/rtic-macros/src/syntax/parse.rs b/rtic-macros/src/syntax/parse.rs
index 72eeeaf6..823bd82e 100644
--- a/rtic-macros/src/syntax/parse.rs
+++ b/rtic-macros/src/syntax/parse.rs
@@ -289,11 +289,13 @@ fn task_args(tokens: TokenStream2) -> parse::Result<Either<HardwareTaskArgs, Sof
// Handle comma: ,
let _: Token![,] = content.parse()?;
}
- let priority = priority.unwrap_or(1);
let shared_resources = shared_resources.unwrap_or_default();
let local_resources = local_resources.unwrap_or_default();
Ok(if let Some(binds) = binds {
+ // Hardware tasks can't run at anything lower than 1
+ let priority = priority.unwrap_or(1);
+
if priority == 0 {
return Err(parse::Error::new(
prio_span.unwrap(),
@@ -308,6 +310,9 @@ fn task_args(tokens: TokenStream2) -> parse::Result<Either<HardwareTaskArgs, Sof
local_resources,
})
} else {
+ // Software tasks start at idle priority
+ let priority = priority.unwrap_or(0);
+
Either::Right(SoftwareTaskArgs {
priority,
shared_resources,