summaryrefslogtreecommitdiff
path: root/kernel/events/internal.h
diff options
context:
space:
mode:
authorScott Wood <scottwood@freescale.com>2014-04-07 23:49:35 (GMT)
committerScott Wood <scottwood@freescale.com>2014-04-07 23:49:35 (GMT)
commit62b8c978ee6b8d135d9e7953221de58000dba986 (patch)
tree683b04b2e627f6710c22c151b23c8cc9a165315e /kernel/events/internal.h
parent78fd82238d0e5716578c326404184a27ba67fd6e (diff)
downloadlinux-fsl-qoriq-62b8c978ee6b8d135d9e7953221de58000dba986.tar.xz
Rewind v3.13-rc3+ (78fd82238d0e5716) to v3.12
Diffstat (limited to 'kernel/events/internal.h')
-rw-r--r--kernel/events/internal.h35
1 files changed, 9 insertions, 26 deletions
diff --git a/kernel/events/internal.h b/kernel/events/internal.h
index 569b2187..ca65997 100644
--- a/kernel/events/internal.h
+++ b/kernel/events/internal.h
@@ -82,16 +82,16 @@ static inline unsigned long perf_data_size(struct ring_buffer *rb)
}
#define DEFINE_OUTPUT_COPY(func_name, memcpy_func) \
-static inline unsigned long \
+static inline unsigned int \
func_name(struct perf_output_handle *handle, \
- const void *buf, unsigned long len) \
+ const void *buf, unsigned int len) \
{ \
unsigned long size, written; \
\
do { \
- size = min(handle->size, len); \
+ size = min_t(unsigned long, handle->size, len); \
+ \
written = memcpy_func(handle->addr, buf, size); \
- written = size - written; \
\
len -= written; \
handle->addr += written; \
@@ -110,37 +110,20 @@ func_name(struct perf_output_handle *handle, \
return len; \
}
-static inline unsigned long
-memcpy_common(void *dst, const void *src, unsigned long n)
+static inline int memcpy_common(void *dst, const void *src, size_t n)
{
memcpy(dst, src, n);
- return 0;
+ return n;
}
DEFINE_OUTPUT_COPY(__output_copy, memcpy_common)
-static inline unsigned long
-memcpy_skip(void *dst, const void *src, unsigned long n)
-{
- return 0;
-}
+#define MEMCPY_SKIP(dst, src, n) (n)
-DEFINE_OUTPUT_COPY(__output_skip, memcpy_skip)
+DEFINE_OUTPUT_COPY(__output_skip, MEMCPY_SKIP)
#ifndef arch_perf_out_copy_user
-#define arch_perf_out_copy_user arch_perf_out_copy_user
-
-static inline unsigned long
-arch_perf_out_copy_user(void *dst, const void *src, unsigned long n)
-{
- unsigned long ret;
-
- pagefault_disable();
- ret = __copy_from_user_inatomic(dst, src, n);
- pagefault_enable();
-
- return ret;
-}
+#define arch_perf_out_copy_user __copy_from_user_inatomic
#endif
DEFINE_OUTPUT_COPY(__output_copy_user, arch_perf_out_copy_user)