From: Nicola Vetrini <nicola.vetrini@bugseng.com>
To: Jan Beulich <jbeulich@suse.com>
Cc: Julien Grall <julien@xen.org>,
Stefano Stabellini <sstabellini@kernel.org>,
Xen Devel <xen-devel@lists.xenproject.org>,
Consulting <consulting@bugseng.com>,
Bertrand Marquis <bertrand.marquis@arm.com>,
Michal Orzel <michal.orzel@amd.com>,
Andrew Cooper3 <andrew.cooper3@citrix.com>,
Roger Pau <roger.pau@citrix.com>,
George Dunlap <george.dunlap@citrix.com>, Wei Liu <wl@xen.org>
Subject: Re: Return type of clean_and_invalidate_dcache_va_range
Date: Mon, 12 Feb 2024 15:56:06 +0100 [thread overview]
Message-ID: <99faac70440a68824a17fcaaea55ef48@bugseng.com> (raw)
In-Reply-To: <02446758-a5a9-4a8a-8ce6-15abdc9ede65@suse.com>
On 2024-02-12 09:26, Jan Beulich wrote:
> On 10.02.2024 11:17, Julien Grall wrote:
>> Hi,
>>
>> On 09/02/2024 22:02, Stefano Stabellini wrote:
>>> On Fri, 9 Feb 2024, Nicola Vetrini wrote:
>>>> Hi all,
>>>>
>>>> In the context of violations of MISRA C:2012 Rule 17.7: "The value
>>>> returned by
>>>> a function having non-void return type shall be used", I was looking
>>>> at the
>>>> function "clean_and_invalidate_dcache_va_range". It has the
>>>> following
>>>> signature on both arm and x86:
>>>>
>>>> static inline int clean_and_invalidate_dcache_va_range
>>>> (const void *p, unsigned long size)
>>>>
>>>> The commit that introduced it for Arm ~9 years ago (71d64afe3e12:
>>>> "arm: return
>>>> int from *_dcache_va_range") [1] mentions that on Arm it can't fail,
>>>> but
>>>> supposedly it can on x86.
>>>>
>>>> However, as far as I can tell, for both arch-es the implementation
>>>> now always
>>>> returns 0 [2][3], so perhaps the mention of -EOPNOTSUPP for x86 is
>>>> no longer
>>>> true (I wasn't able to reconstruct if there was a time at which this
>>>> was true,
>>>> even in the same commit that changed the return type to int).
>>>>
>>>> The question is: should the return type be void, since it appears
>>>> that every
>>>> user is ignoring the returned value (violating the rule), except the
>>>> one in
>>>> common/grant_table.c [4]?
>>>
>>> Looking at the implementation on both ARM and x86, I am in favor of
>>> changing the return type to void
>> I think we need some consistency between all the cache flush helpers
>> (clean_and_invalidate_dcache_va_range, invalidate_dcache_va_range()
>> and
>> clean_dcache_va_range()). They should all return a values or not
>> return any.
>
> +1
>
I agree. I took this helper as an example, but e.g.
invalidate_dcache_va_range returns -EOPNOTSUPP on x86 and it's only used
in common/grant_table.
Perhaps the signatures should remain as is for consistency, especially
given the remark below about the other architectures, and this would
entail a deviation.
>> That said, we have two other architectures in development. Are we
>> saying
>> this helpers will not need to (initially) return -EOPNOTSUPP?
>
> For "(initially)" that's not an issue - such a stub can as well be
> filled
> for BUG_ON("unimplemented"). The question there is what the ultimate
> implementations are going to look like.
>
Should I CC them in this thread?
--
Nicola Vetrini, BSc
Software Engineer, BUGSENG srl (https://bugseng.com)
next prev parent reply other threads:[~2024-02-12 14:56 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-02-09 15:52 Return type of clean_and_invalidate_dcache_va_range Nicola Vetrini
2024-02-09 22:02 ` Stefano Stabellini
2024-02-10 10:17 ` Julien Grall
2024-02-12 8:26 ` Jan Beulich
2024-02-12 14:56 ` Nicola Vetrini [this message]
2024-02-12 18:38 ` Julien Grall
2024-02-13 7:13 ` Jan Beulich
2024-02-13 17:14 ` Julien Grall
2024-02-15 14:31 ` Nicola Vetrini
2024-02-15 15:23 ` Nicola Vetrini
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=99faac70440a68824a17fcaaea55ef48@bugseng.com \
--to=nicola.vetrini@bugseng.com \
--cc=andrew.cooper3@citrix.com \
--cc=bertrand.marquis@arm.com \
--cc=consulting@bugseng.com \
--cc=george.dunlap@citrix.com \
--cc=jbeulich@suse.com \
--cc=julien@xen.org \
--cc=michal.orzel@amd.com \
--cc=roger.pau@citrix.com \
--cc=sstabellini@kernel.org \
--cc=wl@xen.org \
--cc=xen-devel@lists.xenproject.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.