* deffilep.y (tokens): Add upper and lower case versions of DATA,
CONSTANT, NONAME and PRIVATE tokens. (command): Use DATAU. (expline): Allow for drectve syntax as well. (exp_opt_list): Likewise. (exp_opt): Likewise. * pe-dll.c (make_one): Only generate the idata entries for data symbols.
This commit is contained in:
parent
ce195b4280
commit
7c9e78f8e4
3 changed files with 43 additions and 16 deletions
11
ld/ChangeLog
11
ld/ChangeLog
|
@ -1,3 +1,14 @@
|
||||||
|
1999-09-28 Mumit Khan <khan@xraylith.wisc.edu>
|
||||||
|
|
||||||
|
* deffilep.y (tokens): Add upper and lower case versions of DATA,
|
||||||
|
CONSTANT, NONAME and PRIVATE tokens.
|
||||||
|
(command): Use DATAU.
|
||||||
|
(expline): Allow for drectve syntax as well.
|
||||||
|
(exp_opt_list): Likewise.
|
||||||
|
(exp_opt): Likewise.
|
||||||
|
* pe-dll.c (make_one): Only generate the idata entries for data
|
||||||
|
symbols.
|
||||||
|
|
||||||
1999-09-28 Geoffrey Keating <geoffk@cygnus.com>
|
1999-09-28 Geoffrey Keating <geoffk@cygnus.com>
|
||||||
|
|
||||||
* scripttempl/elf.sc (.sdata): Include .gnu.linkonce.s.* sections
|
* scripttempl/elf.sc (.sdata): Include .gnu.linkonce.s.* sections
|
||||||
|
|
|
@ -106,9 +106,10 @@ static const char *lex_parse_string_end = 0;
|
||||||
int number;
|
int number;
|
||||||
};
|
};
|
||||||
|
|
||||||
%token NAME, LIBRARY, DESCRIPTION, STACKSIZE, HEAPSIZE, CODE, DATA
|
%token NAME, LIBRARY, DESCRIPTION, STACKSIZE, HEAPSIZE, CODE, DATAU, DATAL
|
||||||
%token SECTIONS, EXPORTS, IMPORTS, VERSIONK, BASE, CONSTANT, PRIVATE
|
%token SECTIONS, EXPORTS, IMPORTS, VERSIONK, BASE, CONSTANTU, CONSTANTL
|
||||||
%token READ WRITE EXECUTE SHARED NONAME DIRECTIVE
|
%token PRIVATEU, PRIVATEL
|
||||||
|
%token READ WRITE EXECUTE SHARED NONAMEU NONAMEL DIRECTIVE
|
||||||
%token <id> ID
|
%token <id> ID
|
||||||
%token <number> NUMBER
|
%token <number> NUMBER
|
||||||
%type <number> opt_base opt_ordinal
|
%type <number> opt_base opt_ordinal
|
||||||
|
@ -128,7 +129,7 @@ command:
|
||||||
| STACKSIZE NUMBER opt_number { def_stacksize ($2, $3);}
|
| STACKSIZE NUMBER opt_number { def_stacksize ($2, $3);}
|
||||||
| HEAPSIZE NUMBER opt_number { def_heapsize ($2, $3);}
|
| HEAPSIZE NUMBER opt_number { def_heapsize ($2, $3);}
|
||||||
| CODE attr_list { def_section ("CODE", $2);}
|
| CODE attr_list { def_section ("CODE", $2);}
|
||||||
| DATA attr_list { def_section ("DATA", $2);}
|
| DATAU attr_list { def_section ("DATA", $2);}
|
||||||
| SECTIONS seclist
|
| SECTIONS seclist
|
||||||
| EXPORTS explist
|
| EXPORTS explist
|
||||||
| IMPORTS implist
|
| IMPORTS implist
|
||||||
|
@ -145,18 +146,28 @@ explist:
|
||||||
;
|
;
|
||||||
|
|
||||||
expline:
|
expline:
|
||||||
ID opt_equal_name opt_ordinal exp_opt_list
|
/* The opt_comma is necessary to support both the usual
|
||||||
{ def_exports ($1, $2, $3, $4); }
|
DEF file syntax as well as .drectve syntax which
|
||||||
|
mandates <expsym>,<expoptlist>. */
|
||||||
|
ID opt_equal_name opt_ordinal opt_comma exp_opt_list
|
||||||
|
{ def_exports ($1, $2, $3, $5); }
|
||||||
;
|
;
|
||||||
exp_opt_list:
|
exp_opt_list:
|
||||||
exp_opt exp_opt_list { $$ = $1 | $2; }
|
/* The opt_comma is necessary to support both the usual
|
||||||
|
DEF file syntax as well as .drectve syntax which
|
||||||
|
allows for comma separated opt list. */
|
||||||
|
exp_opt opt_comma exp_opt_list { $$ = $1 | $3; }
|
||||||
| { $$ = 0; }
|
| { $$ = 0; }
|
||||||
;
|
;
|
||||||
exp_opt:
|
exp_opt:
|
||||||
NONAME { $$ = 1; }
|
NONAMEU { $$ = 1; }
|
||||||
| CONSTANT { $$ = 2; }
|
| NONAMEL { $$ = 1; }
|
||||||
| DATA { $$ = 4; }
|
| CONSTANTU { $$ = 2; }
|
||||||
| PRIVATE { $$ = 8; }
|
| CONSTANTL { $$ = 2; }
|
||||||
|
| DATAU { $$ = 4; }
|
||||||
|
| DATAL { $$ = 4; }
|
||||||
|
| PRIVATEU { $$ = 8; }
|
||||||
|
| PRIVATEL { $$ = 8; }
|
||||||
;
|
;
|
||||||
implist:
|
implist:
|
||||||
implist impline
|
implist impline
|
||||||
|
@ -827,8 +838,10 @@ tokens[] =
|
||||||
{
|
{
|
||||||
{ "BASE", BASE },
|
{ "BASE", BASE },
|
||||||
{ "CODE", CODE },
|
{ "CODE", CODE },
|
||||||
{ "CONSTANT", CONSTANT },
|
{ "CONSTANT", CONSTANTU },
|
||||||
{ "DATA", DATA },
|
{ "constant", CONSTANTL },
|
||||||
|
{ "DATA", DATAU },
|
||||||
|
{ "data", DATAL },
|
||||||
{ "DESCRIPTION", DESCRIPTION },
|
{ "DESCRIPTION", DESCRIPTION },
|
||||||
{ "DIRECTIVE", DIRECTIVE },
|
{ "DIRECTIVE", DIRECTIVE },
|
||||||
{ "EXECUTE", EXECUTE },
|
{ "EXECUTE", EXECUTE },
|
||||||
|
@ -837,8 +850,10 @@ tokens[] =
|
||||||
{ "IMPORTS", IMPORTS },
|
{ "IMPORTS", IMPORTS },
|
||||||
{ "LIBRARY", LIBRARY },
|
{ "LIBRARY", LIBRARY },
|
||||||
{ "NAME", NAME },
|
{ "NAME", NAME },
|
||||||
{ "NONAME", NONAME },
|
{ "NONAME", NONAMEU },
|
||||||
{ "PRIVATE", PRIVATE },
|
{ "noname", NONAMEL },
|
||||||
|
{ "PRIVATE", PRIVATEU },
|
||||||
|
{ "private", PRIVATEL },
|
||||||
{ "READ", READ },
|
{ "READ", READ },
|
||||||
{ "SECTIONS", SECTIONS },
|
{ "SECTIONS", SECTIONS },
|
||||||
{ "SEGMENTS", SECTIONS },
|
{ "SEGMENTS", SECTIONS },
|
||||||
|
|
|
@ -1307,6 +1307,7 @@ make_one (exp, parent)
|
||||||
id5 = quick_section (abfd, ".idata$5", SEC_HAS_CONTENTS, 2);
|
id5 = quick_section (abfd, ".idata$5", SEC_HAS_CONTENTS, 2);
|
||||||
id4 = quick_section (abfd, ".idata$4", SEC_HAS_CONTENTS, 2);
|
id4 = quick_section (abfd, ".idata$4", SEC_HAS_CONTENTS, 2);
|
||||||
id6 = quick_section (abfd, ".idata$6", SEC_HAS_CONTENTS, 2);
|
id6 = quick_section (abfd, ".idata$6", SEC_HAS_CONTENTS, 2);
|
||||||
|
if (! exp->flag_data)
|
||||||
quick_symbol (abfd, U(""), exp->internal_name, "", tx, BSF_GLOBAL, 0);
|
quick_symbol (abfd, U(""), exp->internal_name, "", tx, BSF_GLOBAL, 0);
|
||||||
quick_symbol (abfd, U("_head_"), dll_symname, "", UNDSEC, BSF_GLOBAL, 0);
|
quick_symbol (abfd, U("_head_"), dll_symname, "", UNDSEC, BSF_GLOBAL, 0);
|
||||||
quick_symbol (abfd, U("__imp_"), exp->internal_name, "", id5, BSF_GLOBAL, 0);
|
quick_symbol (abfd, U("__imp_"), exp->internal_name, "", id5, BSF_GLOBAL, 0);
|
||||||
|
|
Loading…
Reference in a new issue