diff options
-rw-r--r-- | drivers/misc/tegra-profiler/dwarf_unwind.c | 8 | ||||
-rw-r--r-- | drivers/misc/tegra-profiler/eh_unwind.c | 12 | ||||
-rw-r--r-- | drivers/misc/tegra-profiler/hrt.h | 2 | ||||
-rw-r--r-- | drivers/misc/tegra-profiler/quadd.h | 5 | ||||
-rw-r--r-- | drivers/misc/tegra-profiler/version.h | 2 |
5 files changed, 16 insertions, 13 deletions
diff --git a/drivers/misc/tegra-profiler/dwarf_unwind.c b/drivers/misc/tegra-profiler/dwarf_unwind.c index c71e26671577..8699becaa645 100644 --- a/drivers/misc/tegra-profiler/dwarf_unwind.c +++ b/drivers/misc/tegra-profiler/dwarf_unwind.c @@ -70,7 +70,7 @@ enum { DW_CFA_UNSET, DW_CFA_REG_OFFSET, DW_CFA_EXP, -} cfa_how; +}; struct dw_eh_frame_hdr { unsigned char version; @@ -104,7 +104,7 @@ struct dwarf_cpu_context { }; struct quadd_dwarf_context { - struct dwarf_cpu_context * __percpu cpu_ctx; + struct dwarf_cpu_context __percpu *cpu_ctx; atomic_t started; }; @@ -1634,7 +1634,7 @@ unwind_frame(struct ex_region_info *ri, if (!validate_stack_addr(addr, vma_sp, sizeof(unsigned long))) return -QUADD_URC_SP_INCORRECT; - err = read_user_data((unsigned long *)addr, return_addr); + err = read_user_data((unsigned long __user *)addr, return_addr); if (err < 0) return err; @@ -1656,7 +1656,7 @@ unwind_frame(struct ex_region_info *ri, if (!validate_stack_addr(addr, vma_sp, sizeof(unsigned long))) return -QUADD_URC_SP_INCORRECT; - err = read_user_data((unsigned long *)addr, fp); + err = read_user_data((unsigned long __user *)addr, fp); if (err < 0) return err; diff --git a/drivers/misc/tegra-profiler/eh_unwind.c b/drivers/misc/tegra-profiler/eh_unwind.c index a097fd8d1067..0fecf0b1059d 100644 --- a/drivers/misc/tegra-profiler/eh_unwind.c +++ b/drivers/misc/tegra-profiler/eh_unwind.c @@ -119,7 +119,7 @@ validate_mmap_addr(struct quadd_mmap_area *mmap, #define read_user_data(addr, retval) \ ({ \ - int ret; \ + long ret; \ \ pagefault_disable(); \ ret = __get_user(retval, addr); \ @@ -728,7 +728,7 @@ unwind_exec_insn(struct quadd_mmap_area *mmap, ((insn & 0x3f) << 2) + 4, ctrl->vrs[SP]); } else if ((insn & 0xf0) == 0x80) { unsigned long mask; - u32 *vsp = (u32 *)(unsigned long)ctrl->vrs[SP]; + u32 __user *vsp = (u32 __user *)(unsigned long)ctrl->vrs[SP]; int load_sp, reg = 4; insn = (insn << 8) | unwind_get_byte(mmap, ctrl, &err); @@ -764,7 +764,7 @@ unwind_exec_insn(struct quadd_mmap_area *mmap, ctrl->vrs[SP] = ctrl->vrs[insn & 0x0f]; pr_debug("CMD_REG_TO_SP: vsp = {r%lu}\n", insn & 0x0f); } else if ((insn & 0xf0) == 0xa0) { - u32 *vsp = (u32 *)(unsigned long)ctrl->vrs[SP]; + u32 __user *vsp = (u32 __user *)(unsigned long)ctrl->vrs[SP]; unsigned int reg; /* pop R4-R[4+bbb] */ @@ -795,7 +795,7 @@ unwind_exec_insn(struct quadd_mmap_area *mmap, pr_debug("CMD_FINISH\n"); } else if (insn == 0xb1) { unsigned long mask = unwind_get_byte(mmap, ctrl, &err); - u32 *vsp = (u32 *)(unsigned long)ctrl->vrs[SP]; + u32 __user *vsp = (u32 __user *)(unsigned long)ctrl->vrs[SP]; int reg = 0; if (err < 0) @@ -840,7 +840,7 @@ unwind_exec_insn(struct quadd_mmap_area *mmap, ctrl->vrs[SP]); } else if (insn == 0xb3 || insn == 0xc8 || insn == 0xc9) { unsigned long data, reg_from, reg_to; - u32 *vsp = (u32 *)(unsigned long)ctrl->vrs[SP]; + u32 __user *vsp = (u32 __user *)(unsigned long)ctrl->vrs[SP]; data = unwind_get_byte(mmap, ctrl, &err); if (err < 0) @@ -869,7 +869,7 @@ unwind_exec_insn(struct quadd_mmap_area *mmap, } else if ((insn & 0xf8) == 0xb8 || (insn & 0xf8) == 0xd0) { unsigned long reg_to; unsigned long data = insn & 0x07; - u32 *vsp = (u32 *)(unsigned long)ctrl->vrs[SP]; + u32 __user *vsp = (u32 __user *)(unsigned long)ctrl->vrs[SP]; reg_to = 8 + data; diff --git a/drivers/misc/tegra-profiler/hrt.h b/drivers/misc/tegra-profiler/hrt.h index 3361c61e6f3f..9fd9c97d238a 100644 --- a/drivers/misc/tegra-profiler/hrt.h +++ b/drivers/misc/tegra-profiler/hrt.h @@ -42,7 +42,7 @@ struct quadd_cpu_context { struct timecounter; struct quadd_hrt_ctx { - struct quadd_cpu_context * __percpu cpu_ctx; + struct quadd_cpu_context __percpu *cpu_ctx; u64 sample_period; unsigned long low_addr; diff --git a/drivers/misc/tegra-profiler/quadd.h b/drivers/misc/tegra-profiler/quadd.h index c25835e29f09..bb47f7114904 100644 --- a/drivers/misc/tegra-profiler/quadd.h +++ b/drivers/misc/tegra-profiler/quadd.h @@ -1,7 +1,7 @@ /* * drivers/misc/tegra-profiler/quadd.h * - * Copyright (c) 2014, NVIDIA CORPORATION. All rights reserved. + * Copyright (c) 2015, NVIDIA CORPORATION. All rights reserved. * * This program is free software; you can redistribute it and/or modify it * under the terms and conditions of the GNU General Public License, @@ -67,4 +67,7 @@ struct quadd_ctx { void quadd_get_state(struct quadd_module_state *state); +int tegra_profiler_try_lock(void); +void tegra_profiler_unlock(void); + #endif /* __QUADD_H */ diff --git a/drivers/misc/tegra-profiler/version.h b/drivers/misc/tegra-profiler/version.h index 98728a377e37..c96c50756d37 100644 --- a/drivers/misc/tegra-profiler/version.h +++ b/drivers/misc/tegra-profiler/version.h @@ -18,7 +18,7 @@ #ifndef __QUADD_VERSION_H #define __QUADD_VERSION_H -#define QUADD_MODULE_VERSION "1.86" +#define QUADD_MODULE_VERSION "1.87" #define QUADD_MODULE_BRANCH "Dev" #endif /* __QUADD_VERSION_H */ |