+2007-06-07 Martin Hunt <hunt@redhat.com>
+ PR 4075 fix from Ananth Mavinakayanahalli
+ * string.h (_stp_get_user): Define.
+ * string.c (_stp_text_str): Use _stp_get_user().
+
2007-05-30 Martin Hunt <hunt@redhat.com>
Patch from Quentin Barnes.
if (user) {
if (!access_ok(VERIFY_READ, (char __user *)in, 1))
goto bad;
- if (__get_user(c, in))
+ if (__stp_get_user(c, in))
goto bad;
} else
c = *in;
len -= num;
in++;
if (user) {
- if (__get_user(c, in))
+ if (__stp_get_user(c, in))
goto bad;
} else
c = *in;
void _stp_vsprintf (char *str, const char *fmt, va_list args);
void _stp_text_str(char *out, char *in, int len, int quoted, int user);
+/*
+ * Powerpc uses a paranoid user address check in __get_user() which
+ * spews warnings "BUG: Sleeping function...." when DEBUG_SPINLOCK_SLEEP
+ * is enabled. With 2.6.21 and above, a newer variant __get_user_inatomic
+ * is provided without the paranoid check. Use it if available, fall back
+ * to __get_user() if not. Other archs can use __get_user() as is
+ */
+#ifdef __powerpc64__
+#ifdef __get_user_inatomic(x, ptr)
+#define __stp_get_user(x, ptr) __get_user_inatomic(x, ptr)
+#else /* __get_user_inatomic */
+#define __stp_get_user(x, ptr) __get_user(x, ptr)
+#endif /* __get_user_inatomic */
+#else /* __powerpc64__ */
+#define __stp_get_user(x, ptr) __get_user(x, ptr)
+#endif /* __powerpc64__ */
+
#endif /* _STRING_H_ */