On Aug 2, 2023 Casey Schaufler <casey@xxxxxxxxxxxxxxxx> wrote: > > Add hooks for setselfattr and getselfattr. These hooks are not very > different from their setprocattr and getprocattr equivalents, and > much of the code is shared. > > Signed-off-by: Casey Schaufler <casey@xxxxxxxxxxxxxxxx> > Cc: selinux@xxxxxxxxxxxxxxx > Cc: Paul Moore <paul@xxxxxxxxxxxxxx> > --- > security/selinux/hooks.c | 136 +++++++++++++++++++++++++++++++-------- > 1 file changed, 109 insertions(+), 27 deletions(-) > > diff --git a/security/selinux/hooks.c b/security/selinux/hooks.c > index c900813fc8f7..f66a28f672b2 100644 > --- a/security/selinux/hooks.c > +++ b/security/selinux/hooks.c ... > @@ -6449,6 +6466,69 @@ static int selinux_setprocattr(const char *name, void *value, size_t size) > return error; > } > > +static int selinux_getselfattr(unsigned int attr, struct lsm_ctx __user *ctx, > + size_t *size, u32 flags) > +{ > + char *value; > + size_t total_len; > + int len; > + int rc; > + > + len = selinux_lsm_getattr(attr, current, &value); > + if (len < 0) > + return len; > + > + total_len = ALIGN(struct_size(ctx, ctx, len), 8); > + > + if (total_len > *size) > + rc = -E2BIG; > + else if (ctx) > + rc = lsm_fill_user_ctx(ctx, value, len, LSM_ID_SELINUX, 0); > + else > + rc = 1; I'd probably either set rc to zero when at declaration time and drop this final else, or explicitly set rc to one here to better fit what lsm_fill_user_ctx() does on success. However, the end result is the same so we can just fix that with a follow-up patch once this is merged into the lsm/next branch. > + kfree(value); > + *size = total_len; > + if (rc < 0) > + return rc; > + return 1; > +} -- paul-moore.com