|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [PATCH] misra: add ASSERT_UNREACHABLE() in default clauses
On 8/13/25 01:54, Julien Grall wrote:
> Hi Jan,
>
> On 12/08/2025 08:32, Jan Beulich wrote:
>> On 11.08.2025 23:21, Julien Grall wrote:
>>> On 11/08/2025 21:30, Dmytro Prokopchuk1 wrote:
>>>> --- a/xen/common/grant_table.c
>>>> +++ b/xen/common/grant_table.c
>>>> @@ -330,9 +330,12 @@ shared_entry_header(struct grant_table *t,
>>>> grant_ref_t ref)
>>>> /* Returned values should be independent of speculative
>>>> execution */
>>>> block_speculation();
>>>> return &shared_entry_v2(t, ref).hdr;
>>>> +
>>>> + default:
>>>> + ASSERT_UNREACHABLE();
>>>> + break;
>>>> }
>>>> - ASSERT_UNREACHABLE();
>>> > block_speculation();>
>>>> return NULL;
>>>
>>> I know you are trying to apply the MISRA rule. But this is odd that you
>>> move the ASSERT_UNREACHABLE() but then code after is still only
>>> reachable from the default. In fact, this is introducing a risk if
>>> someone decides to add a new case but then forgot to return a value.
>>>
>>> By moving the two other lines, the compiler should be able to throw an
>>> error if you forgot a return.
>>
>> I think we did discuss this pattern in the past. While moving
>> everything up
>> to the "return" into the default: handling will please Eclair / Misra,
>> we'll
>> then end up with no return statement at the end of a non-void function.
>> Beyond being good practice (imo) to have such a "main" return statement,
>> that's actually another rule, just one we apparently didn't accept
>> (15.5).
>
> Reading 15.5, this seems to be about having a single return in the
> function. Unless I misunderstood something, this is different from what
> you suggest.
>
> Anyway, my main problem with this change is that ASSERT_UNREACHABLE() is
> moved. I could possibly settle with:
>
> default:
> break;
> }
>
> ASSERT_UNREACHABLE();
> ...
>
> But at least to me, this pattern is more difficult to read because I
> have to look through the switch to understand the patch is only meant ot
> be used by the "default" case.
>
> Cheers,
>
Hi all!
Let's summarize the discussion.
1. There are two cases, where `switch' statement has a controlling
value that is completely covered by its labeled statements.
Here:
switch ( opB & 0x3 )
And here:
switch ( pte.walk.dt )
Originally it violates rule 16.4 "`switch' statement has no `default'
labels".
Well, adding empty
default: break;
is not a solution, because it starts to violate rule 2.1 "`break'
statement is unreachable".
Adding
default: ASSERT_UNREACHABLE(); break;
looks fine from Eclair point of view, but actually `default' case is
still unreachable.
I think the easiest way is to insert SAF-xx marker instead of the
`default' case.
Changing these to enums - not fine as for me.
Maybe there is a way to configure Eclair to ignore the rule 16.4 in such
cases.
Maybe Nicola can suggest something...
2. Regarding moving ASSERT_UNREACHABLE(); inside `default' case.
Actually switch check Granttable version.
switch ( gt->gt_version )
And it must be '1' or '2'. Other values are wrong.
I think `default' case should be with assert:
default:
ASSERT(false);
return;
This can catch wrong 'gt_version' values.
Dmytro.
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |