summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMike Frysinger <vapier@gentoo.org>2005-12-20 00:45:48 +0000
committerMike Frysinger <vapier@gentoo.org>2005-12-20 00:45:48 +0000
commitf32725ff3315c3974e02ab82a6669a6dde46a216 (patch)
tree83e987e2537aa357c582bf1b244f4c9507ef8f85 /dev-lang/nasm/files
parentAdded ~x86 keyword. (diff)
downloadgentoo-2-f32725ff3315c3974e02ab82a6669a6dde46a216.tar.gz
gentoo-2-f32725ff3315c3974e02ab82a6669a6dde46a216.tar.bz2
gentoo-2-f32725ff3315c3974e02ab82a6669a6dde46a216.zip
update patch
(Portage version: 2.0.53)
Diffstat (limited to 'dev-lang/nasm/files')
-rw-r--r--dev-lang/nasm/files/nasm-0.98.39-elf-visibility.patch42
1 files changed, 22 insertions, 20 deletions
diff --git a/dev-lang/nasm/files/nasm-0.98.39-elf-visibility.patch b/dev-lang/nasm/files/nasm-0.98.39-elf-visibility.patch
index 9065f9f193db..07320eb35467 100644
--- a/dev-lang/nasm/files/nasm-0.98.39-elf-visibility.patch
+++ b/dev-lang/nasm/files/nasm-0.98.39-elf-visibility.patch
@@ -2,7 +2,7 @@ Add support for declaring elf visibility attributes. Used to
help cleanup TEXTRELs in misc libraries (like libsdl).
Syntax to declare function foo hidden:
-GLOBAL foo:function:hidden
+GLOBAL foo:function hidden
Patch by Mike Frysinger <vapier@gentoo.org>
@@ -42,18 +42,14 @@ http://sourceforge.net/mailarchive/forum.php?thread_id=9230919&forum_id=4978
sym->size = 0;
if (segment == NO_SEG)
sym->section = SHN_ABS;
-@@ -571,16 +579,40 @@ static void elf_deflabel(char *name, lon
+@@ -570,18 +578,41 @@ static void elf_deflabel(char *name, lon
+ sym->next = sects[sym->section - 1]->gsyms;
sects[sym->section - 1]->gsyms = sym;
++ /* ELF syntax: GLOBAL name[:type [visibility]] */
if (special) {
- int n = strcspn(special, " ");
-+ char *visibility = NULL;
-+ int n;
-+ n = strcspn(special, ":");
-+ if (special[n]) {
-+ visibility = special + n + 1;
-+ } else
-+ n = strcspn(special, " ");
++ int n = strcspn(special, " \t");
if (!nasm_strnicmp(special, "function", n))
sym->type |= SYM_FUNCTION;
@@ -65,26 +61,32 @@ http://sourceforge.net/mailarchive/forum.php?thread_id=9230919&forum_id=4978
else
error(ERR_NONFATAL, "unrecognised symbol type `%.*s'",
n, special);
-+ if (visibility) {
-+ n = strcspn(visibility, " ");
-+ if (!nasm_strnicmp(visibility, "default", n))
++ special += n;
++
++ while (isspace(*special))
++ ++special;
++ if (*special) {
++ n = strcspn(special, " \t");
++ if (!nasm_strnicmp(special, "default", n))
+ sym->other = STV_DEFAULT;
-+ else if (!nasm_strnicmp(visibility, "internal", n))
++ else if (!nasm_strnicmp(special, "internal", n))
+ sym->other = STV_INTERNAL;
-+ else if (!nasm_strnicmp(visibility, "hidden", n))
++ else if (!nasm_strnicmp(special, "hidden", n))
+ sym->other = STV_HIDDEN;
-+ else if (!nasm_strnicmp(visibility, "protected", n))
++ else if (!nasm_strnicmp(special, "protected", n))
+ sym->other = STV_PROTECTED;
+ else
+ error(ERR_NONFATAL, "unrecognised symbol type `%.*s'",
-+ n, visibility);
-+ n = strcspn(special, " ");
++ n, special);
++ special += n;
+ }
+
- if (special[n]) {
+- if (special[n]) {
++ if (*special) {
struct tokenval tokval;
expr *e;
-@@ -1120,7 +1152,8 @@ static struct SAA *elf_build_symtab(long
+ int fwd = FALSE;
+@@ -1120,7 +1150,8 @@ static struct SAA *elf_build_symtab(long
WRITELONG(p, sym->strpos);
WRITELONG(p, sym->value);
WRITELONG(p, sym->size);
@@ -94,7 +96,7 @@ http://sourceforge.net/mailarchive/forum.php?thread_id=9230919&forum_id=4978
WRITESHORT(p, sym->section);
saa_wbytes(s, entry, 16L);
*len += 16;
-@@ -1138,7 +1171,8 @@ static struct SAA *elf_build_symtab(long
+@@ -1138,7 +1169,8 @@ static struct SAA *elf_build_symtab(long
WRITELONG(p, sym->strpos);
WRITELONG(p, sym->value);
WRITELONG(p, sym->size);