linux-user: Fix getresuid, getresgid if !USE_UID16
The size of the UID/GID types depends on whether USE_UID16 is defined. Define a new put_user_id() which writes a uid/gid type to guest memory. This fixes getresuid and getresgid, which were always storing 16 bits even if the uid type was 32 bits. Reported-by: Michael Matz <matz@suse.de> Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Riku Voipio <riku.voipio@linaro.org> Reviewed-by: Andreas Färber <afaerber@suse.de> Reviewed-by: Richard Henderson <rth@twiddle.net>
This commit is contained in:
		
							parent
							
								
									cd98d390ae
								
							
						
					
					
						commit
						76ca310a19
					
				| 
						 | 
					@ -4528,6 +4528,9 @@ static inline int tswapid(int id)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    return tswap16(id);
 | 
					    return tswap16(id);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define put_user_id(x, gaddr) put_user_u16(x, gaddr)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#else /* !USE_UID16 */
 | 
					#else /* !USE_UID16 */
 | 
				
			||||||
static inline int high2lowuid(int uid)
 | 
					static inline int high2lowuid(int uid)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
| 
						 | 
					@ -4549,6 +4552,9 @@ static inline int tswapid(int id)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    return tswap32(id);
 | 
					    return tswap32(id);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define put_user_id(x, gaddr) put_user_u32(x, gaddr)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif /* USE_UID16 */
 | 
					#endif /* USE_UID16 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void syscall_init(void)
 | 
					void syscall_init(void)
 | 
				
			||||||
| 
						 | 
					@ -7805,9 +7811,9 @@ abi_long do_syscall(void *cpu_env, int num, abi_long arg1,
 | 
				
			||||||
            uid_t ruid, euid, suid;
 | 
					            uid_t ruid, euid, suid;
 | 
				
			||||||
            ret = get_errno(getresuid(&ruid, &euid, &suid));
 | 
					            ret = get_errno(getresuid(&ruid, &euid, &suid));
 | 
				
			||||||
            if (!is_error(ret)) {
 | 
					            if (!is_error(ret)) {
 | 
				
			||||||
                if (put_user_u16(high2lowuid(ruid), arg1)
 | 
					                if (put_user_id(high2lowuid(ruid), arg1)
 | 
				
			||||||
                    || put_user_u16(high2lowuid(euid), arg2)
 | 
					                    || put_user_id(high2lowuid(euid), arg2)
 | 
				
			||||||
                    || put_user_u16(high2lowuid(suid), arg3))
 | 
					                    || put_user_id(high2lowuid(suid), arg3))
 | 
				
			||||||
                    goto efault;
 | 
					                    goto efault;
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
| 
						 | 
					@ -7826,9 +7832,9 @@ abi_long do_syscall(void *cpu_env, int num, abi_long arg1,
 | 
				
			||||||
            gid_t rgid, egid, sgid;
 | 
					            gid_t rgid, egid, sgid;
 | 
				
			||||||
            ret = get_errno(getresgid(&rgid, &egid, &sgid));
 | 
					            ret = get_errno(getresgid(&rgid, &egid, &sgid));
 | 
				
			||||||
            if (!is_error(ret)) {
 | 
					            if (!is_error(ret)) {
 | 
				
			||||||
                if (put_user_u16(high2lowgid(rgid), arg1)
 | 
					                if (put_user_id(high2lowgid(rgid), arg1)
 | 
				
			||||||
                    || put_user_u16(high2lowgid(egid), arg2)
 | 
					                    || put_user_id(high2lowgid(egid), arg2)
 | 
				
			||||||
                    || put_user_u16(high2lowgid(sgid), arg3))
 | 
					                    || put_user_id(high2lowgid(sgid), arg3))
 | 
				
			||||||
                    goto efault;
 | 
					                    goto efault;
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in New Issue