From: Peter Johnson Date: Wed, 26 Sep 2001 20:54:37 +0000 (-0000) Subject: Add SAVE_*, READ_*, and LOAD_* families of little-endian macros. X-Git-Tag: v0.1.0~294 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=fa1654f7b91cead25cfccc93b7949c4a0b08635d;p=yasm Add SAVE_*, READ_*, and LOAD_* families of little-endian macros. svn path=/trunk/yasm/; revision=230 --- diff --git a/libyasm/file.h b/libyasm/file.h index 262be66b..71cf66f7 100644 --- a/libyasm/file.h +++ b/libyasm/file.h @@ -41,6 +41,25 @@ *((ptr)++) = ((val) >> 24) & 0xFF; \ } while (0) +/* Non-incrementing versions of the above. */ + +#define SAVE_BYTE(ptr, val) \ + *(ptr) = (val) & 0xFF + +#define SAVE_SHORT(ptr, val) \ + do { \ + *(ptr) = (val) & 0xFF; \ + *((ptr)+1) = ((val) >> 8) & 0xFF; \ + } while (0) + +#define SAVE_LONG(ptr, val) \ + do { \ + *(ptr) = (val) & 0xFF; \ + *((ptr)+1) = ((val) >> 8) & 0xFF; \ + *((ptr)+2) = ((val) >> 16) & 0xFF; \ + *((ptr)+3) = ((val) >> 24) & 0xFF; \ + } while (0) + /* Direct-to-file versions of the above. Using the above macros and a single * fwrite() will probably be faster than calling these functions many times. * These functions return 1 if the write was successful, 0 if not (so their @@ -50,4 +69,42 @@ size_t fwrite_short(unsigned short val, FILE *f); size_t fwrite_long(unsigned long val, FILE *f); +/* Read/Load versions. val is the variable to receive the data. */ + +#define READ_BYTE(val, ptr) \ + (val) = *((ptr)++) & 0xFF + +#define READ_SHORT(val, ptr) \ + do { \ + (val) = *((ptr)++) & 0xFF; \ + (val) |= (*((ptr)++) & 0xFF) << 8; \ + } while (0) + +#define READ_LONG(val, ptr) \ + do { \ + (val) = *((ptr)++) & 0xFF; \ + (val) |= (*((ptr)++) & 0xFF) << 8; \ + (val) |= (*((ptr)++) & 0xFF) << 16; \ + (val) |= (*((ptr)++) & 0xFF) << 24; \ + } while (0) + +/* Non-incrementing versions of the above. */ + +#define LOAD_BYTE(val, ptr) \ + (val) = *(ptr) & 0xFF + +#define LOAD_SHORT(val, ptr) \ + do { \ + (val) = *(ptr) & 0xFF; \ + (val) |= (*((ptr)+1) & 0xFF) << 8; \ + } while (0) + +#define LOAD_LONG(val, ptr) \ + do { \ + (val) = *(ptr) & 0xFF; \ + (val) |= (*((ptr)+1) & 0xFF) << 8; \ + (val) |= (*((ptr)+2) & 0xFF) << 16; \ + (val) |= (*((ptr)+3) & 0xFF) << 24; \ + } while (0) + #endif diff --git a/src/file.h b/src/file.h index 262be66b..71cf66f7 100644 --- a/src/file.h +++ b/src/file.h @@ -41,6 +41,25 @@ *((ptr)++) = ((val) >> 24) & 0xFF; \ } while (0) +/* Non-incrementing versions of the above. */ + +#define SAVE_BYTE(ptr, val) \ + *(ptr) = (val) & 0xFF + +#define SAVE_SHORT(ptr, val) \ + do { \ + *(ptr) = (val) & 0xFF; \ + *((ptr)+1) = ((val) >> 8) & 0xFF; \ + } while (0) + +#define SAVE_LONG(ptr, val) \ + do { \ + *(ptr) = (val) & 0xFF; \ + *((ptr)+1) = ((val) >> 8) & 0xFF; \ + *((ptr)+2) = ((val) >> 16) & 0xFF; \ + *((ptr)+3) = ((val) >> 24) & 0xFF; \ + } while (0) + /* Direct-to-file versions of the above. Using the above macros and a single * fwrite() will probably be faster than calling these functions many times. * These functions return 1 if the write was successful, 0 if not (so their @@ -50,4 +69,42 @@ size_t fwrite_short(unsigned short val, FILE *f); size_t fwrite_long(unsigned long val, FILE *f); +/* Read/Load versions. val is the variable to receive the data. */ + +#define READ_BYTE(val, ptr) \ + (val) = *((ptr)++) & 0xFF + +#define READ_SHORT(val, ptr) \ + do { \ + (val) = *((ptr)++) & 0xFF; \ + (val) |= (*((ptr)++) & 0xFF) << 8; \ + } while (0) + +#define READ_LONG(val, ptr) \ + do { \ + (val) = *((ptr)++) & 0xFF; \ + (val) |= (*((ptr)++) & 0xFF) << 8; \ + (val) |= (*((ptr)++) & 0xFF) << 16; \ + (val) |= (*((ptr)++) & 0xFF) << 24; \ + } while (0) + +/* Non-incrementing versions of the above. */ + +#define LOAD_BYTE(val, ptr) \ + (val) = *(ptr) & 0xFF + +#define LOAD_SHORT(val, ptr) \ + do { \ + (val) = *(ptr) & 0xFF; \ + (val) |= (*((ptr)+1) & 0xFF) << 8; \ + } while (0) + +#define LOAD_LONG(val, ptr) \ + do { \ + (val) = *(ptr) & 0xFF; \ + (val) |= (*((ptr)+1) & 0xFF) << 8; \ + (val) |= (*((ptr)+2) & 0xFF) << 16; \ + (val) |= (*((ptr)+3) & 0xFF) << 24; \ + } while (0) + #endif