[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH 3/3] docs/doxygen: doxygen documentation for grant_table.h


  • To: Julien Grall <julien@xxxxxxx>
  • From: Luca Fancellu <luca.fancellu@xxxxxxx>
  • Date: Thu, 8 Apr 2021 14:13:57 +0100
  • Arc-authentication-results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none
  • Arc-message-signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=MCEtlsV4c+E+xeFipsp26PtPjOMFY6HsCWyCqiZIvZE=; b=QSxLKBhAgu6XU4LsN4PGqRa7d1VB/YMv/ALBlTfknXcckPGgh3VauEKt3AnXXQ2R3ZUJU2ZySrBrY6A1C7GhI/V2tJWwdn7zcbIs33+KmyR3+Zo9YsesqjzSK4ahpCGQyGV7VRnMbsTxCYN6fIJ+fKmrowW20jvnDqfKPMwrafuVobEwlbheHCU5R72rO9wkSbAooNRfQ30GmZEYUD+zwBLqbVEAe5FZpgplONQJBxk5wfg8MxPGX+K7r9YbCBra9RypweNOrlQkAsrsTbbe5KdctIMwWMZyi8LCsgjUYtoeGJJAKSRh+6gdOqrJeqZCkNMZNqPbZbER+6SyrnfafQ==
  • Arc-seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=OcqwhaIlO5VONt/aoTd4Pglo4M53Tqesbuht6TFLncpdqBFdjzu2XmcaHQzmJ4eJg+U7yD/XFxys4t4Ld6CE3u5ghYogYL80AkEb7/g1gvGcwIS9kRa92fmWX812emY/WGisOA2JnrV0wU2s2wgzBU7Y9dkM8yFavnKZtOsMCfjzL7nDCLijL/b5L/hIvg+A+Ciyx2ZyJWKR5rZ6scsCrJMq/dtnB+DUiSGWLeRYqEbwpLZLt3pdNDE6zzVsK8zIpKPc+4PBhchF/JizjjqPLfeVbB6050yOjI1sgETvxm8NNJWKziNgKATpLgpCB+N0+/ambOeY4yuztfTKrUwgyQ==
  • Authentication-results-original: xen.org; dkim=none (message not signed) header.d=none;xen.org; dmarc=none action=none header.from=arm.com;
  • Cc: Stefano Stabellini <sstabellini@xxxxxxxxxx>, Jan Beulich <jbeulich@xxxxxxxx>, Bertrand Marquis <bertrand.marquis@xxxxxxx>, wei.chen@xxxxxxx, Andrew Cooper <andrew.cooper3@xxxxxxxxxx>, George Dunlap <george.dunlap@xxxxxxxxxx>, Ian Jackson <iwj@xxxxxxxxxxxxxx>, Wei Liu <wl@xxxxxxx>, xen-devel@xxxxxxxxxxxxxxxxxxxx
  • Delivery-date: Thu, 08 Apr 2021 13:14:23 +0000
  • List-id: Xen developer discussion <xen-devel.lists.xenproject.org>
  • Nodisclaimer: true
  • Original-authentication-results: xen.org; dkim=none (message not signed) header.d=none;xen.org; dmarc=none action=none header.from=arm.com;


> On 8 Apr 2021, at 12:50, Julien Grall <julien@xxxxxxx> wrote:
> 
> 
> 
> On 08/04/2021 12:40, Julien Grall wrote:
>> Hi Luca,
>> On 08/04/2021 12:02, Luca Fancellu wrote:
>>> 
>>> 
>>>> On 7 Apr 2021, at 22:26, Stefano Stabellini <sstabellini@xxxxxxxxxx> wrote:
>>>> 
>>>> On Wed, 7 Apr 2021, Jan Beulich wrote:
>>>>> On 07.04.2021 10:42, Luca Fancellu wrote:
>>>>>> Just to be sure that we are in the same page, are you suggesting to 
>>>>>> modify the name
>>>>>> In this way?
>>>>>> 
>>>>>> struct gnttab_cache_flush {
>>>>>> -    union {
>>>>>> +    union xen_gnttab_cache_flush_a {
>>>>>>         uint64_t dev_bus_addr;
>>>>>>         grant_ref_t ref;
>>>>>>     } a;
>>>>>> 
>>>>>> Following this kind of pattern: xen_<upper struct name>_<member name> ?
>>>>> 
>>>>> While in general I would be fine with this scheme, for field names like
>>>>> "a" or "u" it doesn't fit well imo.
>>>> 
>>>> "a" is a bad name anyway, even for the member. We can take the
>>>> opportunity to find a better name. Almost anything would be better than
>>>> "a". Maybe "refaddr"?
>>>> 
>>>> 
>>>>> I'm also unconvinced this would be
>>>>> scalable to the case where there's further struct/union nesting.
>>>> 
>>>> How many of these instances of multilevel nesting do we have? Luca might
>>>> know. Probably not many? They could be special-cased.
>>> 
>>> There are not many multilevel nesting instances of anonymous struct/union 
>>> and the maximum level of nesting I found in the public headers is 2:
>>> 
>>> union {
>>>     union/struct {
>>>         …
>>>     } <name>
>>> } <name>
>>> 
>>> I also see that in the majority of cases the unions have not meaningful 
>>> names like “a” or “u” as member name, instead struct names are fine,
>>> It could be fine to keep the meaningful name the same for the struct type 
>>> name and use the pattern for the non-meaningful ones as long
>>> as the names doesn’t create compilation errors?
>>> 
>>> Example:
>>> 
>>> struct upper_level {
>>>     union {
>>>         struct {
>>> 
>>>         } meaningful_name1;
>>>         struct {
>>> 
>>>         } meaningful_name2;
>>>     } u;
>>> };
>>> 
>>> becomes:
>>> 
>>> struct upper_level {
>>>     union upper_level_u {
>>>         struct meaningful_name1 {
>>> 
>>>         } meaningful_name1;
>>>         struct meaningful_name2 {
>>> 
>>>         } meaningful_name2;
>>>     } u;
>>> };
>> If I understand correctly your proposal, the name of the structure would be 
>> the name of the field. The name of the fields are usually pretty generic so 
>> you will likely end up to redefine the structure name.
>> Unless we want to provide random name, the only safe naming would be to 
>> define the structure as upper_level_u_meaningful_name{1, 2}. But, this is 
>> going to be pretty awful to read.
>> But I am still a bit puzzled by the fact doxygen is not capable to deal with 
>> anynomous/unamed union. How do other projects deal with them?
> 
> While going through the list of anynomous union in Xen, I noticed we also 
> have something like:
> 
> struct test {
>    union {
>        int a;
>        int b;
>    };
> };
> 
> We can't name them because of syntactic reasons. What's your plan for them?

I would say that if the fields a and b are not meant to be described in the 
documentation, they can be hidden, so there is no need to change the structure 
itself but we might just add some comment containing
Doxygen tags for skipping them.
In Zephyr they have some kind of structures like that.

> 
> Cheers,
> 
> -- 
> Julien Grall




 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.