mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-10 23:20:05 +00:00
cifs: fix the format specifiers in sid_to_str
The format specifiers are for signed values, but these are unsigned. Given that '-' is a delimiter between fields, I don't think you'd get what you'd expect if you got a value here that would overflow the sign bit. The version and authority fields are 8 bit values so use a "hh" length modifier there. The subauths are 32 bit values, so there's no need to use a "l" length modifier there. Reviewed-by: Shirish Pargaonkar <shirishpargaonkar@gmail.com> Signed-off-by: Jeff Layton <jlayton@redhat.com> Signed-off-by: Steve French <smfrench@gmail.com>
This commit is contained in:
parent
30c9d6cca5
commit
ee13b2ba74
@ -199,27 +199,24 @@ static void
|
||||
sid_to_str(struct cifs_sid *sidptr, char *sidstr)
|
||||
{
|
||||
int i;
|
||||
unsigned long saval;
|
||||
unsigned int saval;
|
||||
char *strptr;
|
||||
|
||||
strptr = sidstr;
|
||||
|
||||
sprintf(strptr, "%s", "S");
|
||||
strptr = sidstr + strlen(sidstr);
|
||||
|
||||
sprintf(strptr, "-%d", sidptr->revision);
|
||||
sprintf(strptr, "S-%hhu", sidptr->revision);
|
||||
strptr = sidstr + strlen(sidstr);
|
||||
|
||||
for (i = 0; i < NUM_AUTHS; ++i) {
|
||||
if (sidptr->authority[i]) {
|
||||
sprintf(strptr, "-%d", sidptr->authority[i]);
|
||||
sprintf(strptr, "-%hhu", sidptr->authority[i]);
|
||||
strptr = sidstr + strlen(sidstr);
|
||||
}
|
||||
}
|
||||
|
||||
for (i = 0; i < sidptr->num_subauth; ++i) {
|
||||
saval = le32_to_cpu(sidptr->sub_auth[i]);
|
||||
sprintf(strptr, "-%ld", saval);
|
||||
sprintf(strptr, "-%u", saval);
|
||||
strptr = sidstr + strlen(sidstr);
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user