mirror of
https://github.com/netwide-assembler/nasm.git
synced 2025-03-19 18:00:23 +08:00
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.
This commit is contained in:
parent
bfc1712137
commit
12e46510bc
4
eval.c
4
eval.c
@ -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;
|
||||
|
2
eval.h
2
eval.h
@ -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.
|
||||
|
2
nasm.c
2
nasm.c
@ -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 */
|
||||
|
6
nasm.h
6
nasm.h
@ -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
|
||||
|
4
parser.c
4
parser.c
@ -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;
|
||||
|
2
parser.h
2
parser.h
@ -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);
|
||||
|
Loading…
x
Reference in New Issue
Block a user