summaryrefslogtreecommitdiffstats
path: root/lib/libufs
diff options
context:
space:
mode:
authorkib <kib@FreeBSD.org>2011-02-12 12:46:00 +0000
committerkib <kib@FreeBSD.org>2011-02-12 12:46:00 +0000
commitabc49a2c3bfb657cb507d120fe2f896d5f50aa44 (patch)
tree1f4a6dfe93b8c208a51d4e5ac609046e0248ac43 /lib/libufs
parent419b2b4687c784f99be6772ca53fcb97bd8820f0 (diff)
downloadFreeBSD-src-abc49a2c3bfb657cb507d120fe2f896d5f50aa44.zip
FreeBSD-src-abc49a2c3bfb657cb507d120fe2f896d5f50aa44.tar.gz
Replace ERROR() macro with inline function. In-tree gcc cannot tolerate
the construct like printf("%\s", NULL) resulting from macroexpand of ERROR(u, NULL), making it impossible to use LIBUFS_DEBUGGING. With inline function, compiler cannot detect the NULL argument to known function and does not try to convert it into puts(). In collaboration with: pho
Diffstat (limited to 'lib/libufs')
-rw-r--r--lib/libufs/libufs.h52
1 files changed, 24 insertions, 28 deletions
diff --git a/lib/libufs/libufs.h b/lib/libufs/libufs.h
index c3541a0..a16d82b 100644
--- a/lib/libufs/libufs.h
+++ b/lib/libufs/libufs.h
@@ -31,34 +31,6 @@
#define __LIBUFS_H__
/*
- * libufs macros (internal, non-exported).
- */
-#ifdef _LIBUFS
-#ifdef _LIBUFS_DEBUGGING
-/*
- * Trace steps through libufs, to be used at entry and erroneous return.
- */
-#define ERROR(uufsd, str) \
-do { \
- fprintf(stderr, "libufs in %s", __func__); \
- if (str != NULL) \
- fprintf(stderr, ": %s", str); \
- if (errno) \
- fprintf(stderr, ": %s", strerror(errno)); \
- fprintf(stderr, "\n"); \
- if ((uufsd) != NULL) \
- (uufsd)->d_error = str; \
-} while (0)
-#else /* _LIBUFS_DEBUGGING */
-#define ERROR(uufsd, str) \
-do { \
- if ((uufsd) != NULL) \
- (uufsd)->d_error = str; \
-} while (0)
-#endif /* _LIBUFS_DEBUGGING */
-#endif /* _LIBUFS */
-
-/*
* libufs structures.
*/
@@ -94,6 +66,30 @@ struct uufsd {
#define d_cg d_cgunion.d_cg
};
+/*
+ * libufs macros (internal, non-exported).
+ */
+#ifdef _LIBUFS
+/*
+ * Trace steps through libufs, to be used at entry and erroneous return.
+ */
+static inline void
+ERROR(struct uufsd *u, const char *str)
+{
+
+#ifdef _LIBUFS_DEBUGGING
+ if (str != NULL) {
+ fprintf(stderr, "libufs: %s", str);
+ if (errno != 0)
+ fprintf(stderr, ": %s", strerror(errno));
+ fprintf(stderr, "\n");
+ }
+#endif
+ if (u != NULL)
+ u->d_error = str;
+}
+#endif /* _LIBUFS */
+
__BEGIN_DECLS
/*
OpenPOWER on IntegriCloud