diff --git a/tool/microkit/src/sdf.rs b/tool/microkit/src/sdf.rs index 4933150c..73ee65c9 100644 --- a/tool/microkit/src/sdf.rs +++ b/tool/microkit/src/sdf.rs @@ -1201,6 +1201,22 @@ pub fn parse(filename: &str, xml: &str, config: &Config) -> Result= pd_b.priority { + return Err(format!( + "Error: PPCs must be to protection domains of strictly higher priorities; \ + channel with PPC exists from pd {} (priority: {}) to pd {} (priority: {})", + pd_a.name, pd_a.priority, pd_b.name, pd_b.priority + )); + } else if ch.end_b.pp && pd_b.priority >= pd_a.priority { + return Err(format!( + "Error: PPCs must be to protection domains of strictly higher priorities; \ + channel with PPC exists from pd {} (priority: {}) to pd {} (priority: {})", + pd_b.name, pd_b.priority, pd_a.name, pd_a.priority + )); + } + ch_ids[ch.end_a.pd].push(ch.end_a.id); ch_ids[ch.end_b.pd].push(ch.end_b.id); } diff --git a/tool/microkit/tests/sdf/ch_ppcall_priority.xml b/tool/microkit/tests/sdf/ch_ppcall_priority.xml new file mode 100644 index 00000000..6524fee5 --- /dev/null +++ b/tool/microkit/tests/sdf/ch_ppcall_priority.xml @@ -0,0 +1,19 @@ + + + + + + + + + + + + + + + diff --git a/tool/microkit/tests/test.rs b/tool/microkit/tests/test.rs index a281aa89..9c1a34de 100644 --- a/tool/microkit/tests/test.rs +++ b/tool/microkit/tests/test.rs @@ -368,6 +368,14 @@ mod channel { "Error: cannot ppc bidirectionally on element 'channel': ", ) } + + #[test] + fn test_ppcall_priority() { + check_error( + "ch_ppcall_priority.xml", + "Error: PPCs must be to protection domains of strictly higher priorities; channel with PPC exists from pd test1 (priority: 2) to pd test2 (priority: 1)", + ) + } } #[cfg(test)]