|
@@ -34,9 +34,14 @@ struct bug_entry {
|
|
|
#ifndef __WARN
|
|
|
#ifndef __ASSEMBLY__
|
|
|
extern void warn_on_slowpath(const char *file, const int line);
|
|
|
+extern void warn_slowpath(const char *file, const int line,
|
|
|
+ const char *fmt, ...) __attribute__((format(printf, 3, 4)));
|
|
|
#define WANT_WARN_ON_SLOWPATH
|
|
|
#endif
|
|
|
#define __WARN() warn_on_slowpath(__FILE__, __LINE__)
|
|
|
+#define __WARN_printf(arg...) warn_slowpath(__FILE__, __LINE__, arg)
|
|
|
+#else
|
|
|
+#define __WARN_printf(arg...) __WARN()
|
|
|
#endif
|
|
|
|
|
|
#ifndef WARN_ON
|
|
@@ -48,6 +53,15 @@ extern void warn_on_slowpath(const char *file, const int line);
|
|
|
})
|
|
|
#endif
|
|
|
|
|
|
+#ifndef WARN
|
|
|
+#define WARN(condition, format...) ({ \
|
|
|
+ int __ret_warn_on = !!(condition); \
|
|
|
+ if (unlikely(__ret_warn_on)) \
|
|
|
+ __WARN_printf(format); \
|
|
|
+ unlikely(__ret_warn_on); \
|
|
|
+})
|
|
|
+#endif
|
|
|
+
|
|
|
#else /* !CONFIG_BUG */
|
|
|
#ifndef HAVE_ARCH_BUG
|
|
|
#define BUG()
|
|
@@ -63,6 +77,14 @@ extern void warn_on_slowpath(const char *file, const int line);
|
|
|
unlikely(__ret_warn_on); \
|
|
|
})
|
|
|
#endif
|
|
|
+
|
|
|
+#ifndef WARN
|
|
|
+#define WARN(condition, format...) ({ \
|
|
|
+ int __ret_warn_on = !!(condition); \
|
|
|
+ unlikely(__ret_warn_on); \
|
|
|
+})
|
|
|
+#endif
|
|
|
+
|
|
|
#endif
|
|
|
|
|
|
#define WARN_ON_ONCE(condition) ({ \
|