aboutsummaryrefslogtreecommitdiffstats
path: root/sys/linux/xattr.txt
diff options
context:
space:
mode:
authorDmitry Vyukov <dvyukov@google.com>2020-01-23 14:07:01 +0100
committerDmitry Vyukov <dvyukov@google.com>2020-01-23 15:05:21 +0100
commit0e8428d26ffd80789aa83442676e6fb800e9c0ff (patch)
tree5d110f7952fcdc8a64e0acb1f714d6d54505d3ff /sys/linux/xattr.txt
parent9ab9b329d9c8d1477d5b2921671701d9a7a6d2cd (diff)
tools/syz-check: add limited checking of varlen structs
Stop at the fist varlen field, but check the preceeding ones. Frequently the varlen array is the last field, so we should get good checking for these cases. Update #590
Diffstat (limited to 'sys/linux/xattr.txt')
-rw-r--r--sys/linux/xattr.txt15
1 files changed, 8 insertions, 7 deletions
diff --git a/sys/linux/xattr.txt b/sys/linux/xattr.txt
index df1c05f88..1a014e9e9 100644
--- a/sys/linux/xattr.txt
+++ b/sys/linux/xattr.txt
@@ -126,7 +126,7 @@ signature_v2_hdr {
keyid int32be
sig_size bytesize[sig, int16be]
sig array[int8]
-}
+} [packed]
evm_xattr_type = EVM_IMA_XATTR_DIGSIG, EVM_XATTR_PORTABLE_DIGSIG
@@ -162,9 +162,9 @@ setxattr$trusted_overlay_nlink(path ptr[in, filename], name ptr[in, string["trus
lsetxattr$trusted_overlay_nlink(path ptr[in, filename], name ptr[in, string["trusted.overlay.nlink"]], val ptr[in, xattr_overlay_nlink], size len[val], flags flags[setxattr_flags])
fsetxattr$trusted_overlay_nlink(fd fd, name ptr[in, string["trusted.overlay.nlink"]], val ptr[in, xattr_overlay_nlink], size len[val], flags flags[setxattr_flags])
-setxattr$trusted_overlay_upper(path ptr[in, filename], name ptr[in, string["trusted.overlay.upper"]], val ptr[in, ovl_fh], size len[val], flags flags[setxattr_flags])
-lsetxattr$trusted_overlay_upper(path ptr[in, filename], name ptr[in, string["trusted.overlay.upper"]], val ptr[in, ovl_fh], size len[val], flags flags[setxattr_flags])
-fsetxattr$trusted_overlay_upper(fd fd, name ptr[in, string["trusted.overlay.upper"]], val ptr[in, ovl_fh], size len[val], flags flags[setxattr_flags])
+setxattr$trusted_overlay_upper(path ptr[in, filename], name ptr[in, string["trusted.overlay.upper"]], val ptr[in, ovl_fb], size len[val], flags flags[setxattr_flags])
+lsetxattr$trusted_overlay_upper(path ptr[in, filename], name ptr[in, string["trusted.overlay.upper"]], val ptr[in, ovl_fb], size len[val], flags flags[setxattr_flags])
+fsetxattr$trusted_overlay_upper(fd fd, name ptr[in, string["trusted.overlay.upper"]], val ptr[in, ovl_fb], size len[val], flags flags[setxattr_flags])
xattr_overlay_nlink {
prefix stringnoz[xattr_overlay_nlink_prefix]
@@ -173,11 +173,12 @@ xattr_overlay_nlink {
xattr_overlay_nlink_prefix = "U+", "U-", "L+", "L-"
-ovl_fh {
+# TODO: do these attrs accept ovl_fb or ovl_fh?..
+ovl_fb {
version const[0, int8]
magic const[OVL_FH_MAGIC, int8]
len bytesize[parent, int8]
- flags flags[ovl_fh_flags, int8]
+ flags flags[ovl_fb_flags, int8]
type int8
uuid uuid_t
fid array[int8]
@@ -185,4 +186,4 @@ ovl_fh {
type uuid_t array[int8, UUID_SIZE]
-ovl_fh_flags = OVL_FH_FLAG_BIG_ENDIAN, OVL_FH_FLAG_ANY_ENDIAN, OVL_FH_FLAG_PATH_UPPER
+ovl_fb_flags = OVL_FH_FLAG_BIG_ENDIAN, OVL_FH_FLAG_ANY_ENDIAN, OVL_FH_FLAG_PATH_UPPER