summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCyrill Gorcunov <gorcunov@gmail.com>2009-07-28 23:26:12 +0400
committerCyrill Gorcunov <gorcunov@gmail.com>2009-07-28 23:26:12 +0400
commita95a76a8685b5cb485b11c1c76c2a928d8f9b9a3 (patch)
tree9f413e90b33fb472d8bd4ee7948f1e2be9f081e6
parenta92a3a5c499773737c6e94d11a26520d19ac4c5c (diff)
downloadnasm-a95a76a8685b5cb485b11c1c76c2a928d8f9b9a3.tar.gz
nasm-a95a76a8685b5cb485b11c1c76c2a928d8f9b9a3.tar.bz2
nasm-a95a76a8685b5cb485b11c1c76c2a928d8f9b9a3.zip
outaout.c -- use list helpers
Note that we use list_for_each(var,var) sometime which actually brings in at least one redundant assignment in case of NULL being passed but save us a few lines of code. Signed-off-by: Cyrill Gorcunov <gorcunov@gmail.com>
-rw-r--r--output/outaout.c10
1 files changed, 4 insertions, 6 deletions
diff --git a/output/outaout.c b/output/outaout.c
index 8bff63e..f0a86ec 100644
--- a/output/outaout.c
+++ b/output/outaout.c
@@ -508,7 +508,7 @@ static int32_t aout_add_gsym_reloc(struct Section *sect,
/*
* Find a symbol pointing _exactly_ at this one.
*/
- for (sym = shead; sym; sym = sym->next)
+ list_for_each(sym, shead)
if (sym->value == offset)
break;
} else {
@@ -516,7 +516,7 @@ static int32_t aout_add_gsym_reloc(struct Section *sect,
* Find the nearest symbol below this one.
*/
sym = NULL;
- for (sm = shead; sm; sm = sm->next)
+ list_for_each(sm, shead)
if (sm->value <= offset && (!sym || sm->value > sym->value))
sym = sm;
}
@@ -774,7 +774,7 @@ static void aout_fixup_relocs(struct Section *sect)
struct Reloc *r;
saa_rewind(sect->data);
- for (r = sect->head; r; r = r->next) {
+ list_for_each(r, sect->head) {
uint8_t *p, *q, blk[4];
int32_t l;
@@ -843,7 +843,7 @@ static void aout_write(void)
static void aout_write_relocs(struct Reloc *r)
{
- while (r) {
+ list_for_each(r, r) {
uint32_t word2;
fwriteint32_t(r->address, ofile);
@@ -856,8 +856,6 @@ static void aout_write_relocs(struct Reloc *r)
word2 |= (r->bytes == 1 ? 0 :
r->bytes == 2 ? 0x2000000L : 0x4000000L);
fwriteint32_t(word2, ofile);
-
- r = r->next;
}
}