summaryrefslogtreecommitdiffstats
path: root/hivex
diff options
context:
space:
mode:
authorRichard Jones <rjones@redhat.com>2010-02-03 17:41:15 +0000
committerRichard Jones <rjones@redhat.com>2010-02-04 10:26:11 +0000
commite8ad7d2e1b1422680f9f862e7443de67328de135 (patch)
treee8aef6df864bc1a96a6bb212156a414b9bed45a8 /hivex
parent187651c138666d0555bc8ccdd129bb0f51caa72b (diff)
downloadlibguestfs-e8ad7d2e1b1422680f9f862e7443de67328de135.tar.gz
libguestfs-e8ad7d2e1b1422680f9f862e7443de67328de135.tar.xz
libguestfs-e8ad7d2e1b1422680f9f862e7443de67328de135.zip
Move htole*/le*toh macros into a separate header file.
This allows us to reuse these macros in hivexsh later.
Diffstat (limited to 'hivex')
-rw-r--r--hivex/Makefile.am3
-rw-r--r--hivex/byte_conversions.h89
-rw-r--r--hivex/hivex.c43
3 files changed, 93 insertions, 42 deletions
diff --git a/hivex/Makefile.am b/hivex/Makefile.am
index ae7dbac7..1adbbd81 100644
--- a/hivex/Makefile.am
+++ b/hivex/Makefile.am
@@ -21,7 +21,8 @@ lib_LTLIBRARIES = libhivex.la
libhivex_la_SOURCES = \
hivex.c \
- hivex.h
+ hivex.h \
+ byte_conversions.h
libhivex_la_LDFLAGS = -version-info 0:0:0
libhivex_la_CFLAGS = \
diff --git a/hivex/byte_conversions.h b/hivex/byte_conversions.h
new file mode 100644
index 00000000..84e9e2de
--- /dev/null
+++ b/hivex/byte_conversions.h
@@ -0,0 +1,89 @@
+/* Useful byte conversion macros, not available on all platforms.
+ * Copyright (C) 2009-2010 Red Hat Inc.
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation;
+ * version 2.1 of the License.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ */
+
+#ifndef hivex_byteorder_h
+#define hivex_byteorder_h
+
+#ifdef HAVE_ENDIAN_H
+#include <endian.h>
+#endif
+#ifdef HAVE_BYTESWAP_H
+#include <byteswap.h>
+#endif
+
+#if __BYTE_ORDER == __LITTLE_ENDIAN
+#ifndef be32toh
+#define be32toh(x) __bswap_32 (x)
+#endif
+#ifndef htobe32
+#define htobe32(x) __bswap_32 (x)
+#endif
+#ifndef be64toh
+#define be64toh(x) __bswap_64 (x)
+#endif
+#ifndef htobe64
+#define htobe64(x) __bswap_64 (x)
+#endif
+#ifndef le16toh
+#define le16toh(x) (x)
+#endif
+#ifndef htole16
+#define htole16(x) (x)
+#endif
+#ifndef le32toh
+#define le32toh(x) (x)
+#endif
+#ifndef htole32
+#define htole32(x) (x)
+#endif
+#ifndef le64toh
+#define le64toh(x) (x)
+#endif
+#ifndef htole64
+#define htole64(x) (x)
+#endif
+#else /* __BYTE_ORDER == __BIG_ENDIAN */
+#ifndef be32toh
+#define be32toh(x) (x)
+#endif
+#ifndef htobe32
+#define htobe32(x) (x)
+#endif
+#ifndef be64toh
+#define be64toh(x) (x)
+#endif
+#ifndef htobe64
+#define htobe64(x) (x)
+#endif
+#ifndef le16toh
+#define le16toh(x) __bswap_16 (x)
+#endif
+#ifndef htole16
+#define htole16(x) __bswap_16 (x)
+#endif
+#ifndef le32toh
+#define le32toh(x) __bswap_32 (x)
+#endif
+#ifndef htole32
+#define htole32(x) __bswap_32 (x)
+#endif
+#ifndef le64toh
+#define le64toh(x) __bswap_64 (x)
+#endif
+#ifndef htole64
+#define htole64(x) __bswap_64 (x)
+#endif
+#endif /* __BYTE_ORDER == __BIG_ENDIAN */
+
+#endif /* hivex_byteorder_h */
diff --git a/hivex/hivex.c b/hivex/hivex.c
index d2c450fe..4cf3ad99 100644
--- a/hivex/hivex.c
+++ b/hivex/hivex.c
@@ -1,5 +1,5 @@
/* hivex - Windows Registry "hive" extraction library.
- * Copyright (C) 2009 Red Hat Inc.
+ * Copyright (C) 2009-2010 Red Hat Inc.
* Derived from code by Petter Nordahl-Hagen under a compatible license:
* Copyright (c) 1997-2007 Petter Nordahl-Hagen.
* Derived from code by Markus Stephany under a compatible license:
@@ -33,12 +33,6 @@
#include <sys/mman.h>
#include <sys/stat.h>
#include <assert.h>
-#ifdef HAVE_ENDIAN_H
-#include <endian.h>
-#endif
-#ifdef HAVE_BYTESWAP_H
-#include <byteswap.h>
-#endif
#define STREQ(a,b) (strcmp((a),(b)) == 0)
#define STRCASEEQ(a,b) (strcasecmp((a),(b)) == 0)
@@ -50,41 +44,8 @@
//#define STRCASENEQLEN(a,b,n) (strncasecmp((a),(b),(n)) != 0)
//#define STRPREFIX(a,b) (strncmp((a),(b),strlen((b))) == 0)
-#if __BYTE_ORDER == __LITTLE_ENDIAN
-#ifndef be32toh
-#define be32toh(x) __bswap_32 (x)
-#endif
-#ifndef be64toh
-#define be64toh(x) __bswap_64 (x)
-#endif
-#ifndef le16toh
-#define le16toh(x) (x)
-#endif
-#ifndef le32toh
-#define le32toh(x) (x)
-#endif
-#ifndef le64toh
-#define le64toh(x) (x)
-#endif
-#else
-#ifndef be32toh
-#define be32toh(x) (x)
-#endif
-#ifndef be64toh
-#define be64toh(x) (x)
-#endif
-#ifndef le16toh
-#define le16toh(x) __bswap_16 (x)
-#endif
-#ifndef le32toh
-#define le32toh(x) __bswap_32 (x)
-#endif
-#ifndef le64toh
-#define le64toh(x) __bswap_64 (x)
-#endif
-#endif
-
#include "hivex.h"
+#include "byte_conversions.h"
static char *windows_utf16_to_utf8 (/* const */ char *input, size_t len);