compiler.h: unify system ifdef cruft here

Shove a lot of the HOSTCC and related #ifdef checking crap into the new
compiler.h header so that we can keep all other headers nice and clean.

Also introduce custom uswap functions so we don't have to rely on the non
standard implementations that a host may (or may not in the case of OS X)
provide.  This allows mkimage to finally build cleanly on an OS X system.

Signed-off-by: Mike Frysinger <vapier@gentoo.org>
master
Mike Frysinger 16 years ago committed by Wolfgang Denk
parent 2a2ed845c0
commit 3756609076
  1. 125
      include/compiler.h
  2. 10
      include/elf.h
  3. 6
      include/environment.h
  4. 13
      include/image.h
  5. 53
      include/libfdt_env.h
  6. 2
      include/u-boot/md5.h
  7. 8
      lib_generic/md5.c
  8. 13
      tools/bmp_logo.c
  9. 3
      tools/img2srec.c
  10. 3
      tools/mingw_support.h
  11. 14
      tools/mkimage.c
  12. 33
      tools/mkimage.h
  13. 1
      tools/os_support.c
  14. 2
      tools/os_support.h
  15. 13
      tools/ubsha1.c

@ -0,0 +1,125 @@
/*
* Keep all the ugly #ifdef for system stuff here
*/
#ifndef __COMPILER_H__
#define __COMPILER_H__
#include <stddef.h>
#ifdef USE_HOSTCC
#if defined(__BEOS__) || \
defined(__NetBSD__) || \
defined(__FreeBSD__) || \
defined(__sun__) || \
defined(__APPLE__)
# include <inttypes.h>
#elif defined(__linux__) || defined(__WIN32__) || defined(__MINGW32__)
# include <stdint.h>
#endif
#include <errno.h>
#include <stdlib.h>
#include <stdint.h>
#include <stdio.h>
#include <string.h>
extern int errno;
#if !defined(__WIN32__) && !defined(__MINGW32__)
# include <sys/mman.h>
#endif
/* Not all systems (like Windows) has this define, and yes
* we do replace/emulate mmap() on those systems ...
*/
#ifndef MAP_FAILED
# define MAP_FAILED ((void *)-1)
#endif
#include <fcntl.h>
#ifndef O_BINARY /* should be define'd on __WIN32__ */
#define O_BINARY 0
#endif
#ifdef __linux__
# include <endian.h>
# include <byteswap.h>
#elif defined(__MACH__)
# include <machine/endian.h>
typedef unsigned long ulong;
typedef unsigned int uint;
#endif
typedef uint8_t __u8;
typedef uint16_t __u16;
typedef uint32_t __u32;
#define uswap_16(x) \
((((x) & 0xff00) >> 8) | \
(((x) & 0x00ff) << 8))
#define uswap_32(x) \
((((x) & 0xff000000) >> 24) | \
(((x) & 0x00ff0000) >> 8) | \
(((x) & 0x0000ff00) << 8) | \
(((x) & 0x000000ff) << 24))
#define _uswap_64(x, sfx) \
((((x) & 0xff00000000000000##sfx) >> 56) | \
(((x) & 0x00ff000000000000##sfx) >> 40) | \
(((x) & 0x0000ff0000000000##sfx) >> 24) | \
(((x) & 0x000000ff00000000##sfx) >> 8) | \
(((x) & 0x00000000ff000000##sfx) << 8) | \
(((x) & 0x0000000000ff0000##sfx) << 24) | \
(((x) & 0x000000000000ff00##sfx) << 40) | \
(((x) & 0x00000000000000ff##sfx) << 56))
#if defined(__GNUC__)
# define uswap_64(x) _uswap_64(x, ull)
#else
# define uswap_64(x) _uswap_64(x, )
#endif
#if __BYTE_ORDER == __LITTLE_ENDIAN
# define cpu_to_le16(x) (x)
# define cpu_to_le32(x) (x)
# define cpu_to_le64(x) (x)
# define le16_to_cpu(x) (x)
# define le32_to_cpu(x) (x)
# define le64_to_cpu(x) (x)
# define cpu_to_be16(x) uswap_16(x)
# define cpu_to_be32(x) uswap_32(x)
# define cpu_to_be64(x) uswap_64(x)
# define be16_to_cpu(x) uswap_16(x)
# define be32_to_cpu(x) uswap_32(x)
# define be64_to_cpu(x) uswap_64(x)
#else
# define cpu_to_le16(x) uswap_16(x)
# define cpu_to_le32(x) uswap_32(x)
# define cpu_to_le64(x) uswap_64(x)
# define le16_to_cpu(x) uswap_16(x)
# define le32_to_cpu(x) uswap_32(x)
# define le64_to_cpu(x) uswap_64(x)
# define cpu_to_be16(x) (x)
# define cpu_to_be32(x) (x)
# define cpu_to_be64(x) (x)
# define be16_to_cpu(x) (x)
# define be32_to_cpu(x) (x)
# define be64_to_cpu(x) (x)
#endif
#else /* !USE_HOSTCC */
#include <linux/string.h>
#include <linux/types.h>
#include <asm/byteorder.h>
/* Types for `void *' pointers. */
#if __WORDSIZE == 64
typedef unsigned long int uintptr_t;
#else
typedef unsigned int uintptr_t;
#endif
#endif
#endif

@ -33,15 +33,7 @@
#ifndef _ELF_H #ifndef _ELF_H
#define _ELF_H #define _ELF_H
#if defined(__BEOS__) || \ #include "compiler.h"
defined(__NetBSD__) || \
defined(__FreeBSD__) || \
defined(__sun__) || \
defined(__APPLE__)
#include <inttypes.h>
#elif (defined(__linux__) && defined(USE_HOSTCC)) || defined(__WIN32__)
#include <stdint.h>
#endif
/* /*
* This version doesn't work for 64-bit ABIs - Erik. * This version doesn't work for 64-bit ABIs - Erik.

@ -96,11 +96,7 @@
# endif # endif
#endif /* CONFIG_ENV_IS_IN_MG_DISK */ #endif /* CONFIG_ENV_IS_IN_MG_DISK */
#ifdef USE_HOSTCC #include "compiler.h"
# include <stdint.h>
#else
# include <linux/types.h>
#endif
#ifdef CONFIG_SYS_REDUNDAND_ENVIRONMENT #ifdef CONFIG_SYS_REDUNDAND_ENVIRONMENT
# define ENV_HEADER_SIZE (sizeof(uint32_t) + 1) # define ENV_HEADER_SIZE (sizeof(uint32_t) + 1)

@ -33,10 +33,9 @@
#ifndef __IMAGE_H__ #ifndef __IMAGE_H__
#define __IMAGE_H__ #define __IMAGE_H__
#if USE_HOSTCC #include "compiler.h"
#ifndef __MINGW32__
#include <endian.h> #ifdef USE_HOSTCC
#endif
/* new uImage format support enabled on host */ /* new uImage format support enabled on host */
#define CONFIG_FIT 1 #define CONFIG_FIT 1
@ -46,9 +45,7 @@
#else #else
#include <lmb.h> #include <lmb.h>
#include <linux/string.h>
#include <asm/u-boot.h> #include <asm/u-boot.h>
#include <asm/byteorder.h>
#endif /* USE_HOSTCC */ #endif /* USE_HOSTCC */
@ -284,8 +281,8 @@ typedef struct bootm_headers {
#define CHUNKSZ_SHA1 (64 * 1024) #define CHUNKSZ_SHA1 (64 * 1024)
#endif #endif
#define uimage_to_cpu(x) ntohl(x) #define uimage_to_cpu(x) be32_to_cpu(x)
#define cpu_to_uimage(x) htonl(x) #define cpu_to_uimage(x) cpu_to_be32(x)
const char *genimg_get_os_name (uint8_t os); const char *genimg_get_os_name (uint8_t os);
const char *genimg_get_arch_name (uint8_t arch); const char *genimg_get_arch_name (uint8_t arch);

@ -21,56 +21,13 @@
#ifndef _LIBFDT_ENV_H #ifndef _LIBFDT_ENV_H
#define _LIBFDT_ENV_H #define _LIBFDT_ENV_H
#ifdef USE_HOSTCC #include "compiler.h"
#include <stdint.h>
#include <string.h>
#ifdef __MINGW32__
#include <linux/types.h>
#include <linux/byteorder/swab.h>
#else
#include <endian.h>
#include <byteswap.h>
#endif /* __MINGW32__ */
#else
#include <linux/string.h>
#include <linux/types.h>
#include <asm/byteorder.h>
#endif /* USE_HOSTCC */
#include <stddef.h>
extern struct fdt_header *working_fdt; /* Pointer to the working fdt */ extern struct fdt_header *working_fdt; /* Pointer to the working fdt */
#if __BYTE_ORDER == __LITTLE_ENDIAN #define fdt32_to_cpu(x) be32_to_cpu(x)
#ifdef __MINGW32__ #define cpu_to_fdt32(x) cpu_to_be32(x)
#define fdt32_to_cpu(x) ___swab32(x) #define fdt64_to_cpu(x) be64_to_cpu(x)
#define cpu_to_fdt32(x) ___swab32(x) #define cpu_to_fdt64(x) cpu_to_be64(x)
#define fdt64_to_cpu(x) ___swab64(x)
#define cpu_to_fdt64(x) ___swab64(x)
#else
#define fdt32_to_cpu(x) bswap_32(x)
#define cpu_to_fdt32(x) bswap_32(x)
#define fdt64_to_cpu(x) bswap_64(x)
#define cpu_to_fdt64(x) bswap_64(x)
#endif
#else
#define fdt32_to_cpu(x) (x)
#define cpu_to_fdt32(x) (x)
#define fdt64_to_cpu(x) (x)
#define cpu_to_fdt64(x) (x)
#endif
#ifndef USE_HOSTCC
/*
* Types for `void *' pointers.
*
* Note: libfdt uses this definition from /usr/include/stdint.h.
* Define it here rather than pulling in all of stdint.h.
*/
#if __WORDSIZE == 64
typedef unsigned long int uintptr_t;
#else
typedef unsigned int uintptr_t;
#endif
#endif /* not USE_HOSTCC */
#endif /* _LIBFDT_ENV_H */ #endif /* _LIBFDT_ENV_H */

@ -6,7 +6,7 @@
#ifndef _MD5_H #ifndef _MD5_H
#define _MD5_H #define _MD5_H
#include <linux/types.h> #include "compiler.h"
struct MD5Context { struct MD5Context {
__u32 buf[4]; __u32 buf[4];

@ -25,14 +25,12 @@
and to fit the cifs vfs by and to fit the cifs vfs by
Steve French sfrench@us.ibm.com */ Steve French sfrench@us.ibm.com */
#include "compiler.h"
#ifndef USE_HOSTCC #ifndef USE_HOSTCC
#include <common.h> #include <common.h>
#include <linux/string.h>
#else
#include <string.h>
#endif /* USE_HOSTCC */
#include <watchdog.h> #include <watchdog.h>
#include <linux/types.h> #endif /* USE_HOSTCC */
#include <u-boot/md5.h> #include <u-boot/md5.h>
static void static void

@ -1,15 +1,4 @@
#include <stdio.h> #include "compiler.h"
#include <stdlib.h>
#if defined(__linux__)
#include <stdint.h>
#else
#ifdef __CYGWIN__
#include "elf.h"
#else
#include <inttypes.h>
#endif
#endif
typedef struct bitmap_s { /* bitmap description */ typedef struct bitmap_s { /* bitmap description */
uint16_t width; uint16_t width;

@ -52,6 +52,7 @@
| INCLUDES | INCLUDES
|*************************************************************************/ |*************************************************************************/
#include "os_support.h"
#include <stddef.h> #include <stddef.h>
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
@ -61,8 +62,6 @@
#include <unistd.h> #include <unistd.h>
#include <errno.h> #include <errno.h>
extern int errno;
/************************************************************************* /*************************************************************************
| DEFINES | DEFINES
|*************************************************************************/ |*************************************************************************/

@ -34,9 +34,6 @@
#define MAP_SHARED 0x01 /* Share changes */ #define MAP_SHARED 0x01 /* Share changes */
#define MAP_PRIVATE 0x02 /* Changes are private */ #define MAP_PRIVATE 0x02 /* Changes are private */
/* Return value of `mmap' in case of an error */
#define MAP_FAILED ((void *) -1)
/* Windows 64-bit access macros */ /* Windows 64-bit access macros */
#define LODWORD(x) ((DWORD)((DWORDLONG)(x))) #define LODWORD(x) ((DWORD)((DWORDLONG)(x)))
#define HIDWORD(x) ((DWORD)(((DWORDLONG)(x) >> 32) & 0xffffffff)) #define HIDWORD(x) ((DWORD)(((DWORDLONG)(x) >> 32) & 0xffffffff))

@ -25,12 +25,6 @@
#include "mkimage.h" #include "mkimage.h"
#include <image.h> #include <image.h>
extern int errno;
#ifndef MAP_FAILED
#define MAP_FAILED (void *)(-1)
#endif
extern unsigned long crc32 (unsigned long crc, const char *buf, unsigned int len); extern unsigned long crc32 (unsigned long crc, const char *buf, unsigned int len);
static void copy_file (int, const char *, int); static void copy_file (int, const char *, int);
static void usage (void); static void usage (void);
@ -502,7 +496,7 @@ image_verify_header (char *ptr, int image_size)
*/ */
memcpy (hdr, ptr, sizeof(image_header_t)); memcpy (hdr, ptr, sizeof(image_header_t));
if (ntohl(hdr->ih_magic) != IH_MAGIC) { if (be32_to_cpu(hdr->ih_magic) != IH_MAGIC) {
fprintf (stderr, fprintf (stderr,
"%s: Bad Magic Number: \"%s\" is no valid image\n", "%s: Bad Magic Number: \"%s\" is no valid image\n",
cmdname, imagefile); cmdname, imagefile);
@ -512,8 +506,8 @@ image_verify_header (char *ptr, int image_size)
data = (char *)hdr; data = (char *)hdr;
len = sizeof(image_header_t); len = sizeof(image_header_t);
checksum = ntohl(hdr->ih_hcrc); checksum = be32_to_cpu(hdr->ih_hcrc);
hdr->ih_hcrc = htonl(0); /* clear for re-calculation */ hdr->ih_hcrc = cpu_to_be32(0); /* clear for re-calculation */
if (crc32 (0, data, len) != checksum) { if (crc32 (0, data, len) != checksum) {
fprintf (stderr, fprintf (stderr,
@ -525,7 +519,7 @@ image_verify_header (char *ptr, int image_size)
data = ptr + sizeof(image_header_t); data = ptr + sizeof(image_header_t);
len = image_size - sizeof(image_header_t) ; len = image_size - sizeof(image_header_t) ;
if (crc32 (0, data, len) != ntohl(hdr->ih_dcrc)) { if (crc32 (0, data, len) != be32_to_cpu(hdr->ih_dcrc)) {
fprintf (stderr, fprintf (stderr,
"%s: ERROR: \"%s\" has corrupted data!\n", "%s: ERROR: \"%s\" has corrupted data!\n",
cmdname, imagefile); cmdname, imagefile);

@ -26,14 +26,6 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#ifndef __WIN32__
#include <netinet/in.h> /* for host / network byte order conversions */
#endif
#ifdef __MINGW32__
#include <stdint.h>
#else
#include <sys/mman.h>
#endif
#include <sys/stat.h> #include <sys/stat.h>
#include <time.h> #include <time.h>
#include <unistd.h> #include <unistd.h>
@ -53,28 +45,3 @@
#define MKIMAGE_DEFAULT_DTC_OPTIONS "-I dts -O dtb -p 500" #define MKIMAGE_DEFAULT_DTC_OPTIONS "-I dts -O dtb -p 500"
#define MKIMAGE_MAX_DTC_CMDLINE_LEN 512 #define MKIMAGE_MAX_DTC_CMDLINE_LEN 512
#define MKIMAGE_DTC "dtc" /* assume dtc is in $PATH */ #define MKIMAGE_DTC "dtc" /* assume dtc is in $PATH */
#if defined(__BEOS__) || defined(__NetBSD__) || defined(__APPLE__)
#include <inttypes.h>
#endif
#ifdef __WIN32__
typedef unsigned int __u32;
#define SWAP_LONG(x) \
((__u32)( \
(((__u32)(x) & (__u32)0x000000ffUL) << 24) | \
(((__u32)(x) & (__u32)0x0000ff00UL) << 8) | \
(((__u32)(x) & (__u32)0x00ff0000UL) >> 8) | \
(((__u32)(x) & (__u32)0xff000000UL) >> 24) ))
typedef unsigned char uint8_t;
typedef unsigned short uint16_t;
typedef unsigned int uint32_t;
#define ntohl(a) SWAP_LONG(a)
#define htonl(a) SWAP_LONG(a)
#endif /* __WIN32__ */
#ifndef O_BINARY /* should be define'd on __WIN32__ */
#define O_BINARY 0
#endif

@ -19,6 +19,7 @@
/* /*
* Include additional files required for supporting different operating systems * Include additional files required for supporting different operating systems
*/ */
#include "compiler.h"
#ifdef __MINGW32__ #ifdef __MINGW32__
#include "mingw_support.c" #include "mingw_support.c"
#endif #endif

@ -19,6 +19,8 @@
#ifndef __OS_SUPPORT_H_ #ifndef __OS_SUPPORT_H_
#define __OS_SUPPORT_H_ #define __OS_SUPPORT_H_
#include "compiler.h"
/* /*
* Include additional files required for supporting different operating systems * Include additional files required for supporting different operating systems
*/ */

@ -28,9 +28,6 @@
#include <fcntl.h> #include <fcntl.h>
#include <errno.h> #include <errno.h>
#include <string.h> #include <string.h>
#ifndef __MINGW32__
#include <sys/mman.h>
#endif
#include <sys/stat.h> #include <sys/stat.h>
#include "sha1.h" #include "sha1.h"
@ -40,16 +37,6 @@
#include <config.h> #include <config.h>
#undef __ASSEMBLY__ #undef __ASSEMBLY__
#ifndef O_BINARY /* should be define'd on __WIN32__ */
#define O_BINARY 0
#endif
#ifndef MAP_FAILED
#define MAP_FAILED (-1)
#endif
extern int errno;
extern void sha1_csum (unsigned char *input, int ilen, unsigned char output[20]); extern void sha1_csum (unsigned char *input, int ilen, unsigned char output[20]);
int main (int argc, char **argv) int main (int argc, char **argv)

Loading…
Cancel
Save