Commit 737eab77 authored by Donald Hunter's avatar Donald Hunter Committed by Jakub Kicinski

netlink: specs: add display-hint to schema definitions

Add a display-hint property to the netlink schema that is for providing
optional hints to generic netlink clients about how to display attribute
values. A display-hint on an attribute definition is intended for
letting a client such as ynl know that, for example, a u32 should be
rendered as an ipv4 address. The display-hint enumeration includes a
small number of networking domain-specific value types.
Signed-off-by: default avatarDonald Hunter <donald.hunter@gmail.com>
Link: https://lore.kernel.org/r/20230623201928.14275-2-donald.hunter@gmail.comSigned-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent 2ffecf1a
...@@ -195,6 +195,12 @@ properties: ...@@ -195,6 +195,12 @@ properties:
description: Max length for a string or a binary attribute. description: Max length for a string or a binary attribute.
$ref: '#/$defs/len-or-define' $ref: '#/$defs/len-or-define'
sub-type: *attr-type sub-type: *attr-type
display-hint: &display-hint
description: |
Optional format indicator that is intended only for choosing
the right formatting mechanism when displaying values of this
type.
enum: [ hex, mac, fddi, ipv4, ipv6, uuid ]
# Start genetlink-c # Start genetlink-c
name-prefix: name-prefix:
type: string type: string
......
...@@ -119,7 +119,8 @@ properties: ...@@ -119,7 +119,8 @@ properties:
name: name:
type: string type: string
type: type:
enum: [ u8, u16, u32, u64, s8, s16, s32, s64, string ] description: The netlink attribute type
enum: [ u8, u16, u32, u64, s8, s16, s32, s64, string, binary ]
len: len:
$ref: '#/$defs/len-or-define' $ref: '#/$defs/len-or-define'
byte-order: byte-order:
...@@ -130,6 +131,12 @@ properties: ...@@ -130,6 +131,12 @@ properties:
enum: enum:
description: Name of the enum type used for the attribute. description: Name of the enum type used for the attribute.
type: string type: string
display-hint: &display-hint
description: |
Optional format indicator that is intended only for choosing
the right formatting mechanism when displaying values of this
type.
enum: [ hex, mac, fddi, ipv4, ipv6, uuid ]
# End genetlink-legacy # End genetlink-legacy
attribute-sets: attribute-sets:
...@@ -179,6 +186,7 @@ properties: ...@@ -179,6 +186,7 @@ properties:
name: name:
type: string type: string
type: &attr-type type: &attr-type
description: The netlink attribute type
enum: [ unused, pad, flag, binary, u8, u16, u32, u64, s32, s64, enum: [ unused, pad, flag, binary, u8, u16, u32, u64, s32, s64,
string, nest, array-nest, nest-type-value ] string, nest, array-nest, nest-type-value ]
doc: doc:
...@@ -226,6 +234,7 @@ properties: ...@@ -226,6 +234,7 @@ properties:
description: Max length for a string or a binary attribute. description: Max length for a string or a binary attribute.
$ref: '#/$defs/len-or-define' $ref: '#/$defs/len-or-define'
sub-type: *attr-type sub-type: *attr-type
display-hint: *display-hint
# Start genetlink-c # Start genetlink-c
name-prefix: name-prefix:
type: string type: string
......
...@@ -168,6 +168,12 @@ properties: ...@@ -168,6 +168,12 @@ properties:
description: Max length for a string or a binary attribute. description: Max length for a string or a binary attribute.
$ref: '#/$defs/len-or-define' $ref: '#/$defs/len-or-define'
sub-type: *attr-type sub-type: *attr-type
display-hint: &display-hint
description: |
Optional format indicator that is intended only for choosing
the right formatting mechanism when displaying values of this
type.
enum: [ hex, mac, fddi, ipv4, ipv6, uuid ]
# Make sure name-prefix does not appear in subsets (subsets inherit naming) # Make sure name-prefix does not appear in subsets (subsets inherit naming)
dependencies: dependencies:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment