16b3a45ccSpbrook /* 26b3a45ccSpbrook * Helper routines to provide target memory access for semihosting 36b3a45ccSpbrook * syscalls in system emulation mode. 46b3a45ccSpbrook * 56b3a45ccSpbrook * Copyright (c) 2007 CodeSourcery. 66b3a45ccSpbrook * 78e31bf38SMatthew Fernandez * This code is licensed under the GPL 86b3a45ccSpbrook */ 9175de524SMarkus Armbruster 10*f14eced5SPhilippe Mathieu-Daudé #ifndef SEMIHOSTING_UACCESS_H 11*f14eced5SPhilippe Mathieu-Daudé #define SEMIHOSTING_UACCESS_H 12*f14eced5SPhilippe Mathieu-Daudé 13*f14eced5SPhilippe Mathieu-Daudé #ifdef CONFIG_USER_ONLY 14*f14eced5SPhilippe Mathieu-Daudé #error Cannot include semihosting/uaccess.h from user emulation 15*f14eced5SPhilippe Mathieu-Daudé #endif 166b3a45ccSpbrook 17ec150c7eSMarkus Armbruster #include "cpu.h" 18ec150c7eSMarkus Armbruster 198ce5c644SRichard Henderson #define get_user_u64(val, addr) \ 208ce5c644SRichard Henderson ({ uint64_t val_ = 0; \ 218ce5c644SRichard Henderson int ret_ = cpu_memory_rw_debug(env_cpu(env), (addr), \ 228ce5c644SRichard Henderson &val_, sizeof(val_), 0); \ 238ce5c644SRichard Henderson (val) = tswap64(val_); ret_; }) 2444d4a499SPeter Maydell 258ce5c644SRichard Henderson #define get_user_u32(val, addr) \ 268ce5c644SRichard Henderson ({ uint32_t val_ = 0; \ 278ce5c644SRichard Henderson int ret_ = cpu_memory_rw_debug(env_cpu(env), (addr), \ 288ce5c644SRichard Henderson &val_, sizeof(val_), 0); \ 298ce5c644SRichard Henderson (val) = tswap32(val_); ret_; }) 3044d4a499SPeter Maydell 318ce5c644SRichard Henderson #define get_user_u8(val, addr) \ 328ce5c644SRichard Henderson ({ uint8_t val_ = 0; \ 338ce5c644SRichard Henderson int ret_ = cpu_memory_rw_debug(env_cpu(env), (addr), \ 348ce5c644SRichard Henderson &val_, sizeof(val_), 0); \ 358ce5c644SRichard Henderson (val) = val_; ret_; }) 366b3a45ccSpbrook 372f619698Sbellard #define get_user_ual(arg, p) get_user_u32(arg, p) 386b3a45ccSpbrook 398ce5c644SRichard Henderson #define put_user_u64(val, addr) \ 408ce5c644SRichard Henderson ({ uint64_t val_ = tswap64(val); \ 418ce5c644SRichard Henderson cpu_memory_rw_debug(env_cpu(env), (addr), &val_, sizeof(val_), 1); }) 4244d4a499SPeter Maydell 438ce5c644SRichard Henderson #define put_user_u32(val, addr) \ 448ce5c644SRichard Henderson ({ uint32_t val_ = tswap32(val); \ 458ce5c644SRichard Henderson cpu_memory_rw_debug(env_cpu(env), (addr), &val_, sizeof(val_), 1); }) 468ce5c644SRichard Henderson 472f619698Sbellard #define put_user_ual(arg, p) put_user_u32(arg, p) 486b3a45ccSpbrook 49*f14eced5SPhilippe Mathieu-Daudé void *uaccess_lock_user(CPUArchState *env, target_ulong addr, 500a922181SRichard Henderson target_ulong len, bool copy); 51*f14eced5SPhilippe Mathieu-Daudé #define lock_user(type, p, len, copy) uaccess_lock_user(env, p, len, copy) 528ce5c644SRichard Henderson 53*f14eced5SPhilippe Mathieu-Daudé char *uaccess_lock_user_string(CPUArchState *env, target_ulong addr); 54*f14eced5SPhilippe Mathieu-Daudé #define lock_user_string(p) uaccess_lock_user_string(env, p) 558ce5c644SRichard Henderson 56*f14eced5SPhilippe Mathieu-Daudé void uaccess_unlock_user(CPUArchState *env, void *p, 570a922181SRichard Henderson target_ulong addr, target_ulong len); 58*f14eced5SPhilippe Mathieu-Daudé #define unlock_user(s, args, len) uaccess_unlock_user(env, s, args, len) 59cb9c377fSPaolo Bonzini 60*f14eced5SPhilippe Mathieu-Daudé ssize_t uaccess_strlen_user(CPUArchState *env, target_ulong addr); 61*f14eced5SPhilippe Mathieu-Daudé #define target_strlen(p) uaccess_strlen_user(env, p) 625f9ca6f3SRichard Henderson 63c89a14adSRichard Henderson #endif /* SEMIHOSTING_SOFTMMU_UACCESS_H */ 64