diff options
author | H. Peter Anvin <hpa@zytor.com> | 2007-10-03 21:30:57 -0700 |
---|---|---|
committer | H. Peter Anvin <hpa@zytor.com> | 2007-10-03 21:30:57 -0700 |
commit | 12e46510bc185fff839530bba0c7becaaf307037 (patch) | |
tree | 79f9a970aeb4d224f5ad8113e6ebfd9e84911c0a | |
parent | bfc17121378b315399f1df25e902f40884ba7506 (diff) | |
download | nasm-12e46510bc185fff839530bba0c7becaaf307037.tar.gz nasm-12e46510bc185fff839530bba0c7becaaf307037.tar.bz2 nasm-12e46510bc185fff839530bba0c7becaaf307037.zip |
Change cloc_t to struct location, and reorder the members
Change cloc_t to struct location, and reorder the members so that it
should fit in 16 bytes instead of needing 8 bytes of extra padding on
64-bit machines.
-rw-r--r-- | eval.c | 4 | ||||
-rw-r--r-- | eval.h | 2 | ||||
-rw-r--r-- | nasm.c | 2 | ||||
-rw-r--r-- | nasm.h | 6 | ||||
-rw-r--r-- | parser.c | 4 | ||||
-rw-r--r-- | parser.h | 2 |
6 files changed, 10 insertions, 10 deletions
@@ -44,7 +44,7 @@ static struct tokenval *tokval; /* The current token */ static int i; /* The t_type of tokval */ static void *scpriv; -static cloc_t *location; /* Pointer to current line's segment,offset */ +static struct location *location; /* Pointer to current line's segment,offset */ static int *opflags; static struct eval_hints *hint; @@ -813,7 +813,7 @@ static expr *expr6(int critical) } void eval_global_info(struct ofmt *output, lfunc lookup_label, - cloc_t * locp) + struct location * locp) { outfmt = output; labelfunc = lookup_label; @@ -15,7 +15,7 @@ * look labels up. */ void eval_global_info(struct ofmt *output, lfunc lookup_label, - cloc_t * locp); + struct location * locp); /* * The evaluator itself. @@ -69,7 +69,7 @@ static uint32_t cmd_cpu = IF_PLEVEL; /* highest level by default */ static uint32_t cpu = IF_PLEVEL; /* passed to insn_size & assemble.c */ int global_offset_changed; /* referenced in labels.c */ -static cloc_t location; +static struct location location; int in_abs_seg; /* Flag we are in ABSOLUTE seg */ int32_t abs_seg; /* ABSOLUTE segment basis */ int32_t abs_offset; /* ABSOLUTE offset */ @@ -190,11 +190,11 @@ enum floatize { FLOAT_128H, }; -typedef struct { - int32_t segment; +struct location { int64_t offset; + int32_t segment; int known; -} cloc_t; +}; /* * Expression-evaluator datatype. Expressions, within the @@ -36,9 +36,9 @@ static int i; static struct tokenval tokval; static efunc error; static struct ofmt *outfmt; /* Structure of addresses of output routines */ -static cloc_t *location; /* Pointer to current line's segment,offset */ +static struct location *location; /* Pointer to current line's segment,offset */ -void parser_global_info(struct ofmt *output, cloc_t * locp) +void parser_global_info(struct ofmt *output, struct location * locp) { outfmt = output; location = locp; @@ -10,7 +10,7 @@ #ifndef NASM_PARSER_H #define NASM_PARSER_H -void parser_global_info(struct ofmt *output, cloc_t * locp); +void parser_global_info(struct ofmt *output, struct location * locp); insn *parse_line(int pass, char *buffer, insn * result, efunc error, evalfunc evaluate, ldfunc ldef); void cleanup_insn(insn * instruction); |