Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
go
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
go
Commits
9c2ade35
Commit
9c2ade35
authored
Aug 08, 2008
by
Ken Thompson
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mp constants
R=r DELTA=381 (142 added, 26 deleted, 213 changed) OCL=14011 CL=14016
parent
7924b386
Changes
12
Hide whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
343 additions
and
227 deletions
+343
-227
src/cmd/6g/cgen.c
src/cmd/6g/cgen.c
+2
-1
src/cmd/6g/gen.c
src/cmd/6g/gen.c
+10
-9
src/cmd/6g/gsubr.c
src/cmd/6g/gsubr.c
+88
-76
src/cmd/6g/obj.c
src/cmd/6g/obj.c
+1
-1
src/cmd/gc/Makefile
src/cmd/gc/Makefile
+1
-1
src/cmd/gc/const.c
src/cmd/gc/const.c
+87
-60
src/cmd/gc/export.c
src/cmd/gc/export.c
+9
-6
src/cmd/gc/go.h
src/cmd/gc/go.h
+82
-13
src/cmd/gc/go.y
src/cmd/gc/go.y
+5
-5
src/cmd/gc/lex.c
src/cmd/gc/lex.c
+43
-40
src/cmd/gc/subr.c
src/cmd/gc/subr.c
+13
-12
src/cmd/gc/walk.c
src/cmd/gc/walk.c
+2
-3
No files found.
src/cmd/6g/cgen.c
View file @
9c2ade35
...
@@ -454,7 +454,8 @@ bgen(Node *n, int true, Prog *to)
...
@@ -454,7 +454,8 @@ bgen(Node *n, int true, Prog *to)
goto
ret
;
goto
ret
;
case
OLITERAL
:
case
OLITERAL
:
if
(
!
true
==
!
n
->
val
.
vval
)
// need to ask if it is bool?
if
(
!
true
==
!
n
->
val
.
u
.
bval
)
patch
(
gbranch
(
AJMP
,
T
),
to
);
patch
(
gbranch
(
AJMP
,
T
),
to
);
goto
ret
;
goto
ret
;
...
...
src/cmd/6g/gen.c
View file @
9c2ade35
...
@@ -312,7 +312,7 @@ agen_inter(Node *n, Node *res)
...
@@ -312,7 +312,7 @@ agen_inter(Node *n, Node *res)
// stack offset
// stack offset
memset
(
&
nodo
,
0
,
sizeof
(
nodo
));
memset
(
&
nodo
,
0
,
sizeof
(
nodo
));
nodo
.
op
=
OINDREG
;
nodo
.
op
=
OINDREG
;
nodo
.
val
.
vval
=
D_SP
;
nodo
.
val
.
u
.
reg
=
D_SP
;
nodo
.
addable
=
1
;
nodo
.
addable
=
1
;
nodo
.
type
=
types
[
tptr
];
nodo
.
type
=
types
[
tptr
];
...
@@ -745,7 +745,7 @@ cgen_callret(Node *n, Node *res)
...
@@ -745,7 +745,7 @@ cgen_callret(Node *n, Node *res)
memset
(
&
nod
,
0
,
sizeof
(
nod
));
memset
(
&
nod
,
0
,
sizeof
(
nod
));
nod
.
op
=
OINDREG
;
nod
.
op
=
OINDREG
;
nod
.
val
.
vval
=
D_SP
;
nod
.
val
.
u
.
reg
=
D_SP
;
nod
.
addable
=
1
;
nod
.
addable
=
1
;
nod
.
xoffset
=
fp
->
width
;
nod
.
xoffset
=
fp
->
width
;
...
@@ -770,7 +770,7 @@ cgen_aret(Node *n, Node *res)
...
@@ -770,7 +770,7 @@ cgen_aret(Node *n, Node *res)
memset
(
&
nod1
,
0
,
sizeof
(
nod1
));
memset
(
&
nod1
,
0
,
sizeof
(
nod1
));
nod1
.
op
=
OINDREG
;
nod1
.
op
=
OINDREG
;
nod1
.
val
.
vval
=
D_SP
;
nod1
.
val
.
u
.
reg
=
D_SP
;
nod1
.
addable
=
1
;
nod1
.
addable
=
1
;
nod1
.
xoffset
=
fp
->
width
;
nod1
.
xoffset
=
fp
->
width
;
...
@@ -894,31 +894,32 @@ cgen_as(Node *nl, Node *nr, int op)
...
@@ -894,31 +894,32 @@ cgen_as(Node *nl, Node *nr, int op)
case
TUINT32
:
case
TUINT32
:
case
TINT64
:
case
TINT64
:
case
TUINT64
:
case
TUINT64
:
nr
->
val
.
u
.
xval
=
mal
(
sizeof
(
*
nr
->
val
.
u
.
xval
));
mpmovecfix
(
nr
->
val
.
u
.
xval
,
0
);
nr
->
val
.
ctype
=
CTINT
;
nr
->
val
.
ctype
=
CTINT
;
nr
->
val
.
vval
=
0
;
break
;
break
;
case
TFLOAT32
:
case
TFLOAT32
:
case
TFLOAT64
:
case
TFLOAT64
:
case
TFLOAT80
:
case
TFLOAT80
:
nr
->
val
.
u
.
fval
=
mal
(
sizeof
(
*
nr
->
val
.
u
.
fval
));
mpmovecflt
(
nr
->
val
.
u
.
fval
,
0
.
0
);
nr
->
val
.
ctype
=
CTFLT
;
nr
->
val
.
ctype
=
CTFLT
;
nr
->
val
.
dval
=
0
.
0
;
break
;
break
;
case
TBOOL
:
case
TBOOL
:
nr
->
val
.
u
.
bval
=
0
;
nr
->
val
.
ctype
=
CTBOOL
;
nr
->
val
.
ctype
=
CTBOOL
;
nr
->
val
.
vval
=
0
;
break
;
break
;
case
TPTR32
:
case
TPTR32
:
case
TPTR64
:
case
TPTR64
:
if
(
isptrto
(
tl
,
TSTRING
))
{
if
(
isptrto
(
tl
,
TSTRING
))
{
nr
->
val
.
sval
=
mal
(
8
);
nr
->
val
.
u
.
sval
=
mal
(
8
);
nr
->
val
.
ctype
=
CTSTR
;
nr
->
val
.
ctype
=
CTSTR
;
break
;
break
;
}
}
nr
->
val
.
ctype
=
CTNIL
;
nr
->
val
.
ctype
=
CTNIL
;
nr
->
val
.
vval
=
0
;
break
;
break
;
// case TINTER:
// case TINTER:
...
@@ -954,7 +955,7 @@ samereg(Node *a, Node *b)
...
@@ -954,7 +955,7 @@ samereg(Node *a, Node *b)
return
0
;
return
0
;
if
(
b
->
op
!=
OREGISTER
)
if
(
b
->
op
!=
OREGISTER
)
return
0
;
return
0
;
if
(
a
->
val
.
vval
!=
b
->
val
.
vval
)
if
(
a
->
val
.
u
.
reg
!=
b
->
val
.
u
.
reg
)
return
0
;
return
0
;
return
1
;
return
1
;
}
}
...
...
src/cmd/6g/gsubr.c
View file @
9c2ade35
...
@@ -151,7 +151,7 @@ regalloc(Node *n, Type *t, Node *o)
...
@@ -151,7 +151,7 @@ regalloc(Node *n, Type *t, Node *o)
case
TPTR64
:
case
TPTR64
:
case
TBOOL
:
case
TBOOL
:
if
(
o
!=
N
&&
o
->
op
==
OREGISTER
)
{
if
(
o
!=
N
&&
o
->
op
==
OREGISTER
)
{
i
=
o
->
val
.
vval
;
i
=
o
->
val
.
u
.
reg
;
if
(
i
>=
D_AX
&&
i
<=
D_R15
)
if
(
i
>=
D_AX
&&
i
<=
D_R15
)
goto
out
;
goto
out
;
}
}
...
@@ -166,7 +166,7 @@ regalloc(Node *n, Type *t, Node *o)
...
@@ -166,7 +166,7 @@ regalloc(Node *n, Type *t, Node *o)
case
TFLOAT64
:
case
TFLOAT64
:
case
TFLOAT80
:
case
TFLOAT80
:
if
(
o
!=
N
&&
o
->
op
==
OREGISTER
)
{
if
(
o
!=
N
&&
o
->
op
==
OREGISTER
)
{
i
=
o
->
val
.
vval
;
i
=
o
->
val
.
u
.
reg
;
if
(
i
>=
D_X0
&&
i
<=
D_X7
)
if
(
i
>=
D_X0
&&
i
<=
D_X7
)
goto
out
;
goto
out
;
}
}
...
@@ -194,7 +194,7 @@ regfree(Node *n)
...
@@ -194,7 +194,7 @@ regfree(Node *n)
if
(
n
->
op
!=
OREGISTER
&&
n
->
op
!=
OINDREG
)
if
(
n
->
op
!=
OREGISTER
&&
n
->
op
!=
OINDREG
)
fatal
(
"regfree: not a register"
);
fatal
(
"regfree: not a register"
);
i
=
n
->
val
.
vval
;
i
=
n
->
val
.
u
.
reg
;
if
(
i
<
0
||
i
>=
sizeof
(
reg
))
if
(
i
<
0
||
i
>=
sizeof
(
reg
))
fatal
(
"regfree: reg out of range"
);
fatal
(
"regfree: reg out of range"
);
if
(
reg
[
i
]
<=
0
)
if
(
reg
[
i
]
<=
0
)
...
@@ -220,7 +220,7 @@ nodreg(Node *n, Type *t, int r)
...
@@ -220,7 +220,7 @@ nodreg(Node *n, Type *t, int r)
n
->
op
=
OREGISTER
;
n
->
op
=
OREGISTER
;
n
->
addable
=
1
;
n
->
addable
=
1
;
ullmancalc
(
n
);
ullmancalc
(
n
);
n
->
val
.
vval
=
r
;
n
->
val
.
u
.
reg
=
r
;
n
->
type
=
t
;
n
->
type
=
t
;
}
}
...
@@ -248,7 +248,7 @@ nodarg(Type *t, int fp)
...
@@ -248,7 +248,7 @@ nodarg(Type *t, int fp)
switch
(
fp
)
{
switch
(
fp
)
{
case
0
:
// output arg
case
0
:
// output arg
n
->
op
=
OINDREG
;
n
->
op
=
OINDREG
;
n
->
val
.
vval
=
D_SP
;
n
->
val
.
u
.
reg
=
D_SP
;
break
;
break
;
case
1
:
// input arg
case
1
:
// input arg
...
@@ -258,7 +258,7 @@ nodarg(Type *t, int fp)
...
@@ -258,7 +258,7 @@ nodarg(Type *t, int fp)
case
2
:
// offset output arg
case
2
:
// offset output arg
fatal
(
"shpuldnt be used"
);
fatal
(
"shpuldnt be used"
);
n
->
op
=
OINDREG
;
n
->
op
=
OINDREG
;
n
->
val
.
vval
=
D_SP
;
n
->
val
.
u
.
reg
=
D_SP
;
n
->
xoffset
+=
types
[
tptr
]
->
width
;
n
->
xoffset
+=
types
[
tptr
]
->
width
;
break
;
break
;
}
}
...
@@ -272,7 +272,8 @@ nodconst(Node *n, Type *t, vlong v)
...
@@ -272,7 +272,8 @@ nodconst(Node *n, Type *t, vlong v)
n
->
op
=
OLITERAL
;
n
->
op
=
OLITERAL
;
n
->
addable
=
1
;
n
->
addable
=
1
;
ullmancalc
(
n
);
ullmancalc
(
n
);
n
->
val
.
vval
=
v
;
n
->
val
.
u
.
xval
=
mal
(
sizeof
(
*
n
->
val
.
u
.
xval
));
mpmovecfix
(
n
->
val
.
u
.
xval
,
v
);
n
->
val
.
ctype
=
CTINT
;
n
->
val
.
ctype
=
CTINT
;
n
->
type
=
t
;
n
->
type
=
t
;
...
@@ -373,7 +374,7 @@ gmove(Node *f, Node *t)
...
@@ -373,7 +374,7 @@ gmove(Node *f, Node *t)
f
->
op
,
ft
,
t
->
op
,
tt
);
f
->
op
,
ft
,
t
->
op
,
tt
);
if
(
isfloat
[
ft
]
&&
f
->
op
==
OCONST
)
{
if
(
isfloat
[
ft
]
&&
f
->
op
==
OCONST
)
{
/* TO DO: pick up special constants, possibly preloaded */
/* TO DO: pick up special constants, possibly preloaded */
if
(
f
->
val
.
dval
==
0
.
0
)
{
if
(
mpgetflt
(
f
->
val
.
u
.
fval
)
==
0
.
0
)
{
regalloc
(
&
nod
,
t
->
type
,
t
);
regalloc
(
&
nod
,
t
->
type
,
t
);
gins
(
AXORPD
,
&
nod
,
&
nod
);
gins
(
AXORPD
,
&
nod
,
&
nod
);
gmove
(
&
nod
,
t
);
gmove
(
&
nod
,
t
);
...
@@ -582,22 +583,22 @@ gmove(Node *f, Node *t)
...
@@ -582,22 +583,22 @@ gmove(Node *f, Node *t)
case
CASE
(
TINT32
,
TINT64
):
case
CASE
(
TINT32
,
TINT64
):
case
CASE
(
TINT32
,
TPTR64
):
case
CASE
(
TINT32
,
TPTR64
):
a
=
AMOVLQSX
;
a
=
AMOVLQSX
;
if
(
f
->
op
==
OCONST
)
{
//
if(f->op == OCONST) {
f
->
val
.
vval
&=
(
uvlong
)
0xffffffffU
;
//
f->val.vval &= (uvlong)0xffffffffU;
if
(
f
->
val
.
vval
&
0x80000000
)
//
if(f->val.vval & 0x80000000)
f
->
val
.
vval
|=
(
vlong
)
0xffffffff
<<
32
;
//
f->val.vval |= (vlong)0xffffffff << 32;
a
=
AMOVQ
;
//
a = AMOVQ;
}
//
}
break
;
break
;
case
CASE
(
TUINT32
,
TINT64
):
case
CASE
(
TUINT32
,
TINT64
):
case
CASE
(
TUINT32
,
TUINT64
):
case
CASE
(
TUINT32
,
TUINT64
):
case
CASE
(
TUINT32
,
TPTR64
):
case
CASE
(
TUINT32
,
TPTR64
):
a
=
AMOVL
;
/* same effect as AMOVLQZX */
a
=
AMOVL
;
/* same effect as AMOVLQZX */
if
(
f
->
op
==
OCONST
)
{
//
if(f->op == OCONST) {
f
->
val
.
vval
&=
(
uvlong
)
0xffffffffU
;
//
f->val.vval &= (uvlong)0xffffffffU;
a
=
AMOVQ
;
//
a = AMOVQ;
}
//
}
break
;
break
;
case
CASE
(
TPTR64
,
TINT64
):
case
CASE
(
TPTR64
,
TINT64
):
...
@@ -615,45 +616,45 @@ gmove(Node *f, Node *t)
...
@@ -615,45 +616,45 @@ gmove(Node *f, Node *t)
case
CASE
(
TINT16
,
TINT32
):
case
CASE
(
TINT16
,
TINT32
):
case
CASE
(
TINT16
,
TUINT32
):
case
CASE
(
TINT16
,
TUINT32
):
a
=
AMOVWLSX
;
a
=
AMOVWLSX
;
if
(
f
->
op
==
OCONST
)
{
//
if(f->op == OCONST) {
f
->
val
.
vval
&=
0xffff
;
//
f->val.vval &= 0xffff;
if
(
f
->
val
.
vval
&
0x8000
)
//
if(f->val.vval & 0x8000)
f
->
val
.
vval
|=
0xffff0000
;
//
f->val.vval |= 0xffff0000;
a
=
AMOVL
;
//
a = AMOVL;
}
//
}
break
;
break
;
case
CASE
(
TINT16
,
TINT64
):
case
CASE
(
TINT16
,
TINT64
):
case
CASE
(
TINT16
,
TUINT64
):
case
CASE
(
TINT16
,
TUINT64
):
case
CASE
(
TINT16
,
TPTR64
):
case
CASE
(
TINT16
,
TPTR64
):
a
=
AMOVWQSX
;
a
=
AMOVWQSX
;
if
(
f
->
op
==
OCONST
)
{
//
if(f->op == OCONST) {
f
->
val
.
vval
&=
0xffff
;
//
f->val.vval &= 0xffff;
if
(
f
->
val
.
vval
&
0x8000
){
//
if(f->val.vval & 0x8000){
f
->
val
.
vval
|=
0xffff0000
;
//
f->val.vval |= 0xffff0000;
f
->
val
.
vval
|=
(
vlong
)
~
0
<<
32
;
//
f->val.vval |= (vlong)~0 << 32;
}
//
}
a
=
AMOVL
;
//
a = AMOVL;
}
//
}
break
;
break
;
case
CASE
(
TUINT16
,
TINT32
):
case
CASE
(
TUINT16
,
TINT32
):
case
CASE
(
TUINT16
,
TUINT32
):
case
CASE
(
TUINT16
,
TUINT32
):
a
=
AMOVWLZX
;
a
=
AMOVWLZX
;
if
(
f
->
op
==
OCONST
)
{
//
if(f->op == OCONST) {
f
->
val
.
vval
&=
0xffff
;
//
f->val.vval &= 0xffff;
a
=
AMOVL
;
//
a = AMOVL;
}
//
}
break
;
break
;
case
CASE
(
TUINT16
,
TINT64
):
case
CASE
(
TUINT16
,
TINT64
):
case
CASE
(
TUINT16
,
TUINT64
):
case
CASE
(
TUINT16
,
TUINT64
):
case
CASE
(
TUINT16
,
TPTR64
):
case
CASE
(
TUINT16
,
TPTR64
):
a
=
AMOVWQZX
;
a
=
AMOVWQZX
;
if
(
f
->
op
==
OCONST
)
{
//
if(f->op == OCONST) {
f
->
val
.
vval
&=
0xffff
;
//
f->val.vval &= 0xffff;
a
=
AMOVL
;
/* MOVL also zero-extends to 64 bits */
//
a = AMOVL; /* MOVL also zero-extends to 64 bits */
}
//
}
break
;
break
;
case
CASE
(
TINT8
,
TINT16
):
case
CASE
(
TINT8
,
TINT16
):
...
@@ -661,26 +662,26 @@ gmove(Node *f, Node *t)
...
@@ -661,26 +662,26 @@ gmove(Node *f, Node *t)
case
CASE
(
TINT8
,
TINT32
):
case
CASE
(
TINT8
,
TINT32
):
case
CASE
(
TINT8
,
TUINT32
):
case
CASE
(
TINT8
,
TUINT32
):
a
=
AMOVBLSX
;
a
=
AMOVBLSX
;
if
(
f
->
op
==
OCONST
)
{
//
if(f->op == OCONST) {
f
->
val
.
vval
&=
0xff
;
//
f->val.vval &= 0xff;
if
(
f
->
val
.
vval
&
0x80
)
//
if(f->val.vval & 0x80)
f
->
val
.
vval
|=
0xffffff00
;
//
f->val.vval |= 0xffffff00;
a
=
AMOVL
;
//
a = AMOVL;
}
//
}
break
;
break
;
case
CASE
(
TINT8
,
TINT64
):
case
CASE
(
TINT8
,
TINT64
):
case
CASE
(
TINT8
,
TUINT64
):
case
CASE
(
TINT8
,
TUINT64
):
case
CASE
(
TINT8
,
TPTR64
):
case
CASE
(
TINT8
,
TPTR64
):
a
=
AMOVBQSX
;
a
=
AMOVBQSX
;
if
(
f
->
op
==
OCONST
)
{
//
if(f->op == OCONST) {
f
->
val
.
vval
&=
0xff
;
//
f->val.vval &= 0xff;
if
(
f
->
val
.
vval
&
0x80
){
//
if(f->val.vval & 0x80){
f
->
val
.
vval
|=
0xffffff00
;
//
f->val.vval |= 0xffffff00;
f
->
val
.
vval
|=
(
vlong
)
~
0
<<
32
;
//
f->val.vval |= (vlong)~0 << 32;
}
//
}
a
=
AMOVQ
;
//
a = AMOVQ;
}
//
}
break
;
break
;
case
CASE
(
TBOOL
,
TINT16
):
case
CASE
(
TBOOL
,
TINT16
):
...
@@ -692,10 +693,10 @@ gmove(Node *f, Node *t)
...
@@ -692,10 +693,10 @@ gmove(Node *f, Node *t)
case
CASE
(
TUINT8
,
TINT32
):
case
CASE
(
TUINT8
,
TINT32
):
case
CASE
(
TUINT8
,
TUINT32
):
case
CASE
(
TUINT8
,
TUINT32
):
a
=
AMOVBLZX
;
a
=
AMOVBLZX
;
if
(
f
->
op
==
OCONST
)
{
//
if(f->op == OCONST) {
f
->
val
.
vval
&=
0xff
;
//
f->val.vval &= 0xff;
a
=
AMOVL
;
//
a = AMOVL;
}
//
}
break
;
break
;
case
CASE
(
TBOOL
,
TINT64
):
case
CASE
(
TBOOL
,
TINT64
):
...
@@ -705,10 +706,10 @@ gmove(Node *f, Node *t)
...
@@ -705,10 +706,10 @@ gmove(Node *f, Node *t)
case
CASE
(
TUINT8
,
TUINT64
):
case
CASE
(
TUINT8
,
TUINT64
):
case
CASE
(
TUINT8
,
TPTR64
):
case
CASE
(
TUINT8
,
TPTR64
):
a
=
AMOVBQZX
;
a
=
AMOVBQZX
;
if
(
f
->
op
==
OCONST
)
{
//
if(f->op == OCONST) {
f
->
val
.
vval
&=
0xff
;
//
f->val.vval &= 0xff;
a
=
AMOVL
;
/* zero-extends to 64-bits */
//
a = AMOVL; /* zero-extends to 64-bits */
}
//
}
break
;
break
;
/*
/*
...
@@ -961,7 +962,7 @@ samaddr(Node *f, Node *t)
...
@@ -961,7 +962,7 @@ samaddr(Node *f, Node *t)
switch
(
f
->
op
)
{
switch
(
f
->
op
)
{
case
OREGISTER
:
case
OREGISTER
:
if
(
f
->
val
.
vval
!=
t
->
val
.
vval
)
if
(
f
->
val
.
u
.
reg
!=
t
->
val
.
u
.
reg
)
break
;
break
;
return
1
;
return
1
;
}
}
...
@@ -1016,7 +1017,7 @@ naddr(Node *n, Addr *a)
...
@@ -1016,7 +1017,7 @@ naddr(Node *n, Addr *a)
break
;
break
;
case
OREGISTER
:
case
OREGISTER
:
a
->
type
=
n
->
val
.
vval
;
a
->
type
=
n
->
val
.
u
.
reg
;
a
->
sym
=
S
;
a
->
sym
=
S
;
break
;
break
;
...
@@ -1041,7 +1042,7 @@ naddr(Node *n, Addr *a)
...
@@ -1041,7 +1042,7 @@ naddr(Node *n, Addr *a)
// break;
// break;
case
OINDREG
:
case
OINDREG
:
a
->
type
=
n
->
val
.
vval
+
D_INDIR
;
a
->
type
=
n
->
val
.
u
.
reg
+
D_INDIR
;
a
->
sym
=
n
->
sym
;
a
->
sym
=
n
->
sym
;
a
->
offset
=
n
->
xoffset
;
a
->
offset
=
n
->
xoffset
;
break
;
break
;
...
@@ -1078,12 +1079,22 @@ naddr(Node *n, Addr *a)
...
@@ -1078,12 +1079,22 @@ naddr(Node *n, Addr *a)
break
;
break
;
case
OLITERAL
:
case
OLITERAL
:
if
(
isfloat
[
n
->
type
->
etype
])
{
switch
(
n
->
val
.
ctype
)
{
default:
fatal
(
"naddr: const %lT"
,
n
->
type
);
break
;
case
CTFLT
:
a
->
type
=
D_FCONST
;
a
->
type
=
D_FCONST
;
a
->
dval
=
n
->
val
.
dval
;
a
->
dval
=
mpgetflt
(
n
->
val
.
u
.
fval
)
;
break
;
break
;
}
case
CTINT
:
if
(
isptrto
(
n
->
type
,
TSTRING
))
{
case
CTSINT
:
case
CTUINT
:
a
->
sym
=
S
;
a
->
type
=
D_CONST
;
a
->
offset
=
mpgetfix
(
n
->
val
.
u
.
xval
);
break
;
case
CTSTR
:
a
->
etype
=
n
->
etype
;
a
->
etype
=
n
->
etype
;
a
->
sym
=
symstringo
;
a
->
sym
=
symstringo
;
a
->
type
=
D_ADDR
;
a
->
type
=
D_ADDR
;
...
@@ -1091,16 +1102,17 @@ naddr(Node *n, Addr *a)
...
@@ -1091,16 +1102,17 @@ naddr(Node *n, Addr *a)
a
->
offset
=
symstringo
->
offset
;
a
->
offset
=
symstringo
->
offset
;
stringpool
(
n
);
stringpool
(
n
);
break
;
break
;
}
case
CTBOOL
:
if
(
isint
[
n
->
type
->
etype
]
||
a
->
sym
=
S
;
isptr
[
n
->
type
->
etype
]
||
a
->
type
=
D_CONST
;
n
->
type
->
etype
==
TBOOL
)
{
a
->
offset
=
n
->
val
.
u
.
bval
;
break
;
case
CTNIL
:
a
->
sym
=
S
;
a
->
sym
=
S
;
a
->
type
=
D_CONST
;
a
->
type
=
D_CONST
;
a
->
offset
=
n
->
val
.
vval
;
a
->
offset
=
0
;
break
;
break
;
}
}
fatal
(
"naddr: const %lT"
,
n
->
type
);
break
;
break
;
case
OADDR
:
case
OADDR
:
...
@@ -1699,7 +1711,7 @@ stringpool(Node *n)
...
@@ -1699,7 +1711,7 @@ stringpool(Node *n)
p
=
mal
(
sizeof
(
*
p
));
p
=
mal
(
sizeof
(
*
p
));
p
->
sval
=
n
->
val
.
sval
;
p
->
sval
=
n
->
val
.
u
.
sval
;
p
->
link
=
nil
;
p
->
link
=
nil
;
if
(
poolist
==
nil
)
if
(
poolist
==
nil
)
...
...
src/cmd/6g/obj.c
View file @
9c2ade35
...
@@ -74,7 +74,7 @@ dumpobj(void)
...
@@ -74,7 +74,7 @@ dumpobj(void)
continue
;
continue
;
dowidth
(
n
->
type
);
dowidth
(
n
->
type
);
n1
.
val
.
vval
=
n
->
type
->
width
;
mpmovecfix
(
n1
.
val
.
u
.
xval
,
n
->
type
->
width
)
;
p
=
pc
;
p
=
pc
;
gins
(
AGLOBL
,
s
->
oname
,
&
n1
);
gins
(
AGLOBL
,
s
->
oname
,
&
n1
);
...
...
src/cmd/gc/Makefile
View file @
9c2ade35
...
@@ -22,7 +22,7 @@ OFILES=\
...
@@ -22,7 +22,7 @@ OFILES=\
export.
$O
\
export.
$O
\
walk.
$O
\
walk.
$O
\
const.
$O
\
const.
$O
\
mpa
tof
.
$O
\
mpa
rith
.
$O
\
sysimport.
$O
\
sysimport.
$O
\
compat.
$O
\
compat.
$O
\
...
...
src/cmd/gc/const.c
View file @
9c2ade35
...
@@ -23,7 +23,7 @@ convlit(Node *n, Type *t)
...
@@ -23,7 +23,7 @@ convlit(Node *n, Type *t)
if
(
!
isptr
[
et
]
&&
et
!=
TINTER
)
if
(
!
isptr
[
et
]
&&
et
!=
TINTER
)
goto
bad1
;
goto
bad1
;
if
(
isptrto
(
t
,
TSTRING
))
{
if
(
isptrto
(
t
,
TSTRING
))
{
n
->
val
.
sval
=
mal
(
8
);
n
->
val
.
u
.
sval
=
mal
(
8
);
n
->
val
.
ctype
=
CTSTR
;
n
->
val
.
ctype
=
CTSTR
;
}
}
break
;
break
;
...
@@ -44,29 +44,31 @@ convlit(Node *n, Type *t)
...
@@ -44,29 +44,31 @@ convlit(Node *n, Type *t)
int
l
;
int
l
;
String
*
s
;
String
*
s
;
rune
=
n
->
val
.
vval
;
rune
=
mpgetfix
(
n
->
val
.
u
.
xval
)
;
l
=
runelen
(
rune
);
l
=
runelen
(
rune
);
s
=
mal
(
sizeof
(
*
s
)
+
l
);
s
=
mal
(
sizeof
(
*
s
)
+
l
);
s
->
len
=
l
;
s
->
len
=
l
;
runetochar
((
char
*
)(
s
->
s
),
&
rune
);
runetochar
((
char
*
)(
s
->
s
),
&
rune
);
n
->
val
.
sval
=
s
;
n
->
val
.
u
.
sval
=
s
;
n
->
val
.
ctype
=
CTSTR
;
n
->
val
.
ctype
=
CTSTR
;
break
;
break
;
}
}
if
(
isint
[
et
])
{
if
(
isint
[
et
])
{
if
(
n
->
val
.
vval
<
minintval
[
et
])
// int to int
if
(
mpcmpfixfix
(
n
->
val
.
u
.
xval
,
minintval
[
et
])
<
0
)
goto
bad2
;
goto
bad2
;
if
(
n
->
val
.
vval
>
maxintval
[
et
]
)
if
(
mpcmpfixfix
(
n
->
val
.
u
.
xval
,
maxintval
[
et
])
>
0
)
goto
bad2
;
goto
bad2
;
break
;
break
;
}
}
if
(
isfloat
[
et
])
{
if
(
isfloat
[
et
])
{
if
(
n
->
val
.
vval
<
minfloatval
[
et
])
// int to float
if
(
mpcmpfltflt
(
n
->
val
.
u
.
fval
,
minfltval
[
et
])
<
0
)
goto
bad2
;
goto
bad2
;
if
(
n
->
val
.
vval
>
maxfloatval
[
et
]
)
if
(
mpcmpfltflt
(
n
->
val
.
u
.
fval
,
maxfltval
[
et
])
>
0
)
goto
bad2
;
goto
bad2
;
n
->
val
.
dval
=
n
->
val
.
vval
;
mpmovefixflt
(
n
->
val
.
u
.
fval
,
n
->
val
.
u
.
xval
)
;
n
->
val
.
ctype
=
CTFLT
;
n
->
val
.
ctype
=
CTFLT
;
break
;
break
;
}
}
...
@@ -74,18 +76,20 @@ convlit(Node *n, Type *t)
...
@@ -74,18 +76,20 @@ convlit(Node *n, Type *t)
case
Wlitfloat
:
case
Wlitfloat
:
if
(
isint
[
et
])
{
if
(
isint
[
et
])
{
if
(
n
->
val
.
dval
<
minintval
[
et
])
// float to int
if
(
mpcmpfixfix
(
n
->
val
.
u
.
xval
,
minintval
[
et
])
<
0
)
goto
bad2
;
goto
bad2
;
if
(
n
->
val
.
dval
>
maxintval
[
et
]
)
if
(
mpcmpfixfix
(
n
->
val
.
u
.
xval
,
maxintval
[
et
])
>
0
)
goto
bad2
;
goto
bad2
;
n
->
val
.
vval
=
n
->
val
.
dval
;
mpmovefltfix
(
n
->
val
.
u
.
xval
,
n
->
val
.
u
.
fval
)
;
n
->
val
.
ctype
=
CTINT
;
n
->
val
.
ctype
=
CTINT
;
break
;
break
;
}
}
if
(
isfloat
[
et
])
{
if
(
isfloat
[
et
])
{
if
(
n
->
val
.
dval
<
minfloatval
[
et
])
// float to float
if
(
mpcmpfltflt
(
n
->
val
.
u
.
fval
,
minfltval
[
et
])
<
0
)
goto
bad2
;
goto
bad2
;
if
(
n
->
val
.
dval
>
maxfloatval
[
et
]
)
if
(
mpcmpfltflt
(
n
->
val
.
u
.
fval
,
maxfltval
[
et
])
>
0
)
goto
bad2
;
goto
bad2
;
break
;
break
;
}
}
...
@@ -110,6 +114,8 @@ evconst(Node *n)
...
@@ -110,6 +114,8 @@ evconst(Node *n)
int32
len
;
int32
len
;
String
*
str
;
String
*
str
;
int
wl
,
wr
;
int
wl
,
wr
;
Mpint
*
xval
;
Mpflt
*
fval
;
nl
=
n
->
left
;
nl
=
n
->
left
;
if
(
nl
==
N
)
if
(
nl
==
N
)
...
@@ -145,120 +151,135 @@ evconst(Node *n)
...
@@ -145,120 +151,135 @@ evconst(Node *n)
if
(
wl
!=
wr
)
{
if
(
wl
!=
wr
)
{
if
(
wl
==
Wlitfloat
&&
wr
==
Wlitint
)
{
if
(
wl
==
Wlitfloat
&&
wr
==
Wlitint
)
{
nr
->
val
.
dval
=
nr
->
val
.
vval
;
xval
=
nr
->
val
.
u
.
xval
;
nr
->
val
.
u
.
fval
=
mal
(
sizeof
(
*
nr
->
val
.
u
.
fval
));
mpmovefixflt
(
nr
->
val
.
u
.
fval
,
xval
);
nr
->
val
.
ctype
=
CTFLT
;
nr
->
val
.
ctype
=
CTFLT
;
wr
=
whatis
(
nr
);
wr
=
whatis
(
nr
);
}
else
}
else
if
(
wl
==
Wlitint
&&
wr
==
Wlitfloat
)
{
if
(
wl
==
Wlitint
&&
wr
==
Wlitfloat
)
{
nl
->
val
.
dval
=
nl
->
val
.
vval
;
xval
=
nl
->
val
.
u
.
xval
;
nl
->
val
.
u
.
fval
=
mal
(
sizeof
(
*
nl
->
val
.
u
.
fval
));
mpmovefixflt
(
nl
->
val
.
u
.
fval
,
xval
);
nl
->
val
.
ctype
=
CTFLT
;
nl
->
val
.
ctype
=
CTFLT
;
wl
=
whatis
(
nl
);
wl
=
whatis
(
nl
);
}
else
{
}
else
{
yyerror
(
"illegal combination of literals %
d %d
"
,
nl
->
etype
,
nr
->
etype
);
yyerror
(
"illegal combination of literals %
E %E
"
,
nl
->
etype
,
nr
->
etype
);
return
;
return
;
}
}
}
}
// dance to not modify left side
// this is because iota will reuse it
if
(
wl
==
Wlitint
)
{
xval
=
mal
(
sizeof
(
*
xval
));
mpmovefixfix
(
xval
,
nl
->
val
.
u
.
xval
);
}
else
if
(
wl
==
Wlitfloat
)
{
fval
=
mal
(
sizeof
(
*
fval
));
mpmovefltflt
(
fval
,
nl
->
val
.
u
.
fval
);
}
switch
(
TUP
(
n
->
op
,
wl
))
{
switch
(
TUP
(
n
->
op
,
wl
))
{
default:
default:
yyerror
(
"illegal combination of literals %O %
d"
,
n
->
op
,
wl
);
yyerror
(
"illegal combination of literals %O %
E"
,
n
->
op
,
nl
->
etype
);
return
;
return
;
case
TUP
(
OADD
,
Wlitint
):
case
TUP
(
OADD
,
Wlitint
):
nl
->
val
.
vval
+=
nr
->
val
.
vval
;
mpaddfixfix
(
xval
,
nr
->
val
.
u
.
xval
)
;
break
;
break
;
case
TUP
(
OSUB
,
Wlitint
):
case
TUP
(
OSUB
,
Wlitint
):
nl
->
val
.
vval
-=
nr
->
val
.
vval
;
mpsubfixfix
(
xval
,
nr
->
val
.
u
.
xval
)
;
break
;
break
;
case
TUP
(
OMUL
,
Wlitint
):
case
TUP
(
OMUL
,
Wlitint
):
nl
->
val
.
vval
*=
nr
->
val
.
vval
;
mpmulfixfix
(
xval
,
nr
->
val
.
u
.
xval
)
;
break
;
break
;
case
TUP
(
ODIV
,
Wlitint
):
case
TUP
(
ODIV
,
Wlitint
):
nl
->
val
.
vval
/=
nr
->
val
.
vval
;
mpdivfixfix
(
xval
,
nr
->
val
.
u
.
xval
)
;
break
;
break
;
case
TUP
(
OMOD
,
Wlitint
):
case
TUP
(
OMOD
,
Wlitint
):
nl
->
val
.
vval
%=
nr
->
val
.
vval
;
mpmodfixfix
(
xval
,
nr
->
val
.
u
.
xval
)
;
break
;
break
;
case
TUP
(
OLSH
,
Wlitint
):
case
TUP
(
OLSH
,
Wlitint
):
nl
->
val
.
vval
<<=
nr
->
val
.
vval
;
mplshfixfix
(
xval
,
nr
->
val
.
u
.
xval
)
;
break
;
break
;
case
TUP
(
ORSH
,
Wlitint
):
case
TUP
(
ORSH
,
Wlitint
):
nl
->
val
.
vval
>>=
nr
->
val
.
vval
;
mprshfixfix
(
xval
,
nr
->
val
.
u
.
xval
)
;
break
;
break
;
case
TUP
(
OOR
,
Wlitint
):
case
TUP
(
OOR
,
Wlitint
):
nl
->
val
.
vval
|=
nr
->
val
.
vval
;
mporfixfix
(
xval
,
nr
->
val
.
u
.
xval
)
;
break
;
break
;
case
TUP
(
OAND
,
Wlitint
):
case
TUP
(
OAND
,
Wlitint
):
nl
->
val
.
vval
&=
nr
->
val
.
vval
;
mpandfixfix
(
xval
,
nr
->
val
.
u
.
xval
)
;
break
;
break
;
case
TUP
(
OXOR
,
Wlitint
):
case
TUP
(
OXOR
,
Wlitint
):
nl
->
val
.
vval
^=
nr
->
val
.
vval
;
mpxorfixfix
(
xval
,
nr
->
val
.
u
.
xval
)
;
break
;
break
;
case
TUP
(
OADD
,
Wlitfloat
):
case
TUP
(
OADD
,
Wlitfloat
):
nl
->
val
.
dval
+=
nr
->
val
.
dval
;
mpaddfltflt
(
fval
,
nr
->
val
.
u
.
fval
)
;
break
;
break
;
case
TUP
(
OSUB
,
Wlitfloat
):
case
TUP
(
OSUB
,
Wlitfloat
):
nl
->
val
.
dval
-=
nr
->
val
.
dval
;
mpsubfltflt
(
fval
,
nr
->
val
.
u
.
fval
)
;
break
;
break
;
case
TUP
(
OMUL
,
Wlitfloat
):
case
TUP
(
OMUL
,
Wlitfloat
):
nl
->
val
.
dval
*=
nr
->
val
.
dval
;
mpmulfltflt
(
fval
,
nr
->
val
.
u
.
fval
)
;
break
;
break
;
case
TUP
(
ODIV
,
Wlitfloat
):
case
TUP
(
ODIV
,
Wlitfloat
):
nl
->
val
.
dval
/=
nr
->
val
.
dval
;
mpdivfltflt
(
fval
,
nr
->
val
.
u
.
fval
)
;
break
;
break
;
case
TUP
(
OEQ
,
Wlitint
):
case
TUP
(
OEQ
,
Wlitint
):
if
(
nl
->
val
.
vval
==
nr
->
val
.
vval
)
if
(
mpcmpfixfix
(
xval
,
nr
->
val
.
u
.
xval
)
==
0
)
goto
settrue
;
goto
settrue
;
goto
setfalse
;
goto
setfalse
;
case
TUP
(
ONE
,
Wlitint
):
case
TUP
(
ONE
,
Wlitint
):
if
(
nl
->
val
.
vval
!=
nr
->
val
.
vval
)
if
(
mpcmpfixfix
(
xval
,
nr
->
val
.
u
.
xval
)
!=
0
)
goto
settrue
;
goto
settrue
;
goto
setfalse
;
goto
setfalse
;
case
TUP
(
OLT
,
Wlitint
):
case
TUP
(
OLT
,
Wlitint
):
if
(
nl
->
val
.
vval
<
nr
->
val
.
vval
)
if
(
mpcmpfixfix
(
xval
,
nr
->
val
.
u
.
xval
)
<
0
)
goto
settrue
;
goto
settrue
;
goto
setfalse
;
goto
setfalse
;
case
TUP
(
OLE
,
Wlitint
):
case
TUP
(
OLE
,
Wlitint
):
if
(
nl
->
val
.
vval
<=
nr
->
val
.
vval
)
if
(
mpcmpfixfix
(
xval
,
nr
->
val
.
u
.
xval
)
<=
0
)
goto
settrue
;
goto
settrue
;
goto
setfalse
;
goto
setfalse
;
case
TUP
(
OGE
,
Wlitint
):
case
TUP
(
OGE
,
Wlitint
):
if
(
nl
->
val
.
vval
>=
nr
->
val
.
vval
)
if
(
mpcmpfixfix
(
xval
,
nr
->
val
.
u
.
xval
)
>=
0
)
goto
settrue
;
goto
settrue
;
goto
setfalse
;
goto
setfalse
;
case
TUP
(
OGT
,
Wlitint
):
case
TUP
(
OGT
,
Wlitint
):
if
(
nl
->
val
.
vval
>
nr
->
val
.
vval
)
if
(
mpcmpfixfix
(
xval
,
nr
->
val
.
u
.
xval
)
>
0
)
goto
settrue
;
goto
settrue
;
goto
setfalse
;
goto
setfalse
;
case
TUP
(
OEQ
,
Wlitfloat
):
case
TUP
(
OEQ
,
Wlitfloat
):
if
(
nl
->
val
.
dval
==
nr
->
val
.
dval
)
if
(
mpcmpfltflt
(
fval
,
nr
->
val
.
u
.
fval
)
==
0
)
goto
settrue
;
goto
settrue
;
goto
setfalse
;
goto
setfalse
;
case
TUP
(
ONE
,
Wlitfloat
):
case
TUP
(
ONE
,
Wlitfloat
):
if
(
nl
->
val
.
dval
!=
nr
->
val
.
dval
)
if
(
mpcmpfltflt
(
fval
,
nr
->
val
.
u
.
fval
)
!=
0
)
goto
settrue
;
goto
settrue
;
goto
setfalse
;
goto
setfalse
;
case
TUP
(
OLT
,
Wlitfloat
):
case
TUP
(
OLT
,
Wlitfloat
):
if
(
nl
->
val
.
dval
<
nr
->
val
.
dval
)
if
(
mpcmpfltflt
(
fval
,
nr
->
val
.
u
.
fval
)
<
0
)
goto
settrue
;
goto
settrue
;
goto
setfalse
;
goto
setfalse
;
case
TUP
(
OLE
,
Wlitfloat
):
case
TUP
(
OLE
,
Wlitfloat
):
if
(
nl
->
val
.
dval
<=
nr
->
val
.
dval
)
if
(
mpcmpfltflt
(
fval
,
nr
->
val
.
u
.
fval
)
<=
0
)
goto
settrue
;
goto
settrue
;
goto
setfalse
;
goto
setfalse
;
case
TUP
(
OGE
,
Wlitfloat
):
case
TUP
(
OGE
,
Wlitfloat
):
if
(
nl
->
val
.
dval
>=
nr
->
val
.
dval
)
if
(
mpcmpfltflt
(
fval
,
nr
->
val
.
u
.
fval
)
>=
0
)
goto
settrue
;
goto
settrue
;
goto
setfalse
;
goto
setfalse
;
case
TUP
(
OGT
,
Wlitfloat
):
case
TUP
(
OGT
,
Wlitfloat
):
if
(
nl
->
val
.
dval
>
nr
->
val
.
dval
)
if
(
mpcmpfltflt
(
fval
,
nr
->
val
.
u
.
fval
)
>
0
)
goto
settrue
;
goto
settrue
;
goto
setfalse
;
goto
setfalse
;
case
TUP
(
OEQ
,
Wlitstr
):
case
TUP
(
OEQ
,
Wlitstr
):
if
(
cmpslit
(
nl
,
nr
)
==
0
)
if
(
cmpslit
(
nl
,
nr
)
==
0
)
goto
settrue
;
goto
settrue
;
...
@@ -284,25 +305,33 @@ evconst(Node *n)
...
@@ -284,25 +305,33 @@ evconst(Node *n)
goto
settrue
;
goto
settrue
;
goto
setfalse
;
goto
setfalse
;
case
TUP
(
OADD
,
Wlitstr
):
case
TUP
(
OADD
,
Wlitstr
):
len
=
nl
->
val
.
sval
->
len
+
nr
->
val
.
sval
->
len
;
len
=
nl
->
val
.
u
.
sval
->
len
+
nr
->
val
.
u
.
sval
->
len
;
str
=
mal
(
sizeof
(
*
str
)
+
len
);
str
=
mal
(
sizeof
(
*
str
)
+
len
);
str
->
len
=
len
;
str
->
len
=
len
;
memcpy
(
str
->
s
,
nl
->
val
.
sval
->
s
,
nl
->
val
.
sval
->
len
);
memcpy
(
str
->
s
,
nl
->
val
.
u
.
sval
->
s
,
nl
->
val
.
u
.
sval
->
len
);
memcpy
(
str
->
s
+
nl
->
val
.
sval
->
len
,
nr
->
val
.
sval
->
s
,
nr
->
val
.
sval
->
len
);
memcpy
(
str
->
s
+
nl
->
val
.
u
.
sval
->
len
,
nr
->
val
.
u
.
sval
->
s
,
nr
->
val
.
u
.
sval
->
len
);
str
->
len
=
len
;
str
->
len
=
len
;
nl
->
val
.
sval
=
str
;
nl
->
val
.
u
.
sval
=
str
;
break
;
break
;
case
TUP
(
OOROR
,
Wlitbool
):
case
TUP
(
OOROR
,
Wlitbool
):
if
(
nl
->
val
.
vval
||
nr
->
val
.
v
val
)
if
(
nl
->
val
.
u
.
bval
||
nr
->
val
.
u
.
b
val
)
goto
settrue
;
goto
settrue
;
goto
setfalse
;
goto
setfalse
;
case
TUP
(
OANDAND
,
Wlitbool
):
case
TUP
(
OANDAND
,
Wlitbool
):
if
(
nl
->
val
.
vval
&&
nr
->
val
.
v
val
)
if
(
nl
->
val
.
u
.
bval
&&
nr
->
val
.
u
.
b
val
)
goto
settrue
;
goto
settrue
;
goto
setfalse
;
goto
setfalse
;
}
}
*
n
=
*
nl
;
*
n
=
*
nl
;
// second half of dance
if
(
wl
==
Wlitint
)
{
n
->
val
.
u
.
xval
=
xval
;
}
else
if
(
wl
==
Wlitfloat
)
{
n
->
val
.
u
.
fval
=
fval
;
}
return
;
return
;
settrue:
settrue:
...
@@ -320,24 +349,22 @@ unary:
...
@@ -320,24 +349,22 @@ unary:
return
;
return
;
case
TUP
(
OPLUS
,
Wlitint
):
case
TUP
(
OPLUS
,
Wlitint
):
nl
->
val
.
vval
=
+
nl
->
val
.
vval
;
break
;
break
;
case
TUP
(
OMINUS
,
Wlitint
):
case
TUP
(
OMINUS
,
Wlitint
):
nl
->
val
.
vval
=
-
nl
->
val
.
vval
;
mpnegfix
(
nl
->
val
.
u
.
xval
)
;
break
;
break
;
case
TUP
(
OCOM
,
Wlitint
):
case
TUP
(
OCOM
,
Wlitint
):
nl
->
val
.
vval
=
~
nl
->
val
.
vval
;
mpcomfix
(
nl
->
val
.
u
.
xval
)
;
break
;
break
;
case
TUP
(
OPLUS
,
Wlitfloat
):
case
TUP
(
OPLUS
,
Wlitfloat
):
nl
->
val
.
dval
=
+
nl
->
val
.
dval
;
break
;
break
;
case
TUP
(
OMINUS
,
Wlitfloat
):
case
TUP
(
OMINUS
,
Wlitfloat
):
nl
->
val
.
dval
=
-
nl
->
val
.
dval
;
mpnegflt
(
nl
->
val
.
u
.
fval
)
;
break
;
break
;
case
TUP
(
ONOT
,
Wlitbool
):
case
TUP
(
ONOT
,
Wlitbool
):
if
(
nl
->
val
.
v
val
)
if
(
nl
->
val
.
u
.
b
val
)
goto
settrue
;
goto
settrue
;
goto
setfalse
;
goto
setfalse
;
}
}
...
@@ -381,10 +408,10 @@ cmpslit(Node *l, Node *r)
...
@@ -381,10 +408,10 @@ cmpslit(Node *l, Node *r)
int32
l1
,
l2
,
i
,
m
;
int32
l1
,
l2
,
i
,
m
;
char
*
s1
,
*
s2
;
char
*
s1
,
*
s2
;
l1
=
l
->
val
.
sval
->
len
;
l1
=
l
->
val
.
u
.
sval
->
len
;
l2
=
r
->
val
.
sval
->
len
;
l2
=
r
->
val
.
u
.
sval
->
len
;
s1
=
l
->
val
.
sval
->
s
;
s1
=
l
->
val
.
u
.
sval
->
s
;
s2
=
r
->
val
.
sval
->
s
;
s2
=
r
->
val
.
u
.
sval
->
s
;
m
=
l1
;
m
=
l1
;
if
(
l2
<
m
)
if
(
l2
<
m
)
...
...
src/cmd/gc/export.c
View file @
9c2ade35
...
@@ -78,14 +78,16 @@ dumpexportconst(Sym *s)
...
@@ -78,14 +78,16 @@ dumpexportconst(Sym *s)
case
CTINT
:
case
CTINT
:
case
CTSINT
:
case
CTSINT
:
case
CTUINT
:
case
CTUINT
:
Bprint
(
bout
,
"0x%llux
\n
"
,
mpgetfix
(
n
->
val
.
u
.
xval
));
break
;
case
CTBOOL
:
case
CTBOOL
:
Bprint
(
bout
,
"0x%llux
\n
"
,
n
->
val
.
v
val
);
Bprint
(
bout
,
"0x%llux
\n
"
,
n
->
val
.
u
.
b
val
);
break
;
break
;
case
CTFLT
:
case
CTFLT
:
Bprint
(
bout
,
"%.17e
\n
"
,
n
->
val
.
dval
);
Bprint
(
bout
,
"%.17e
\n
"
,
mpgetflt
(
n
->
val
.
u
.
fval
)
);
break
;
break
;
case
CTSTR
:
case
CTSTR
:
Bprint
(
bout
,
"
\"
%Z
\"\n
"
,
n
->
val
.
sval
);
Bprint
(
bout
,
"
\"
%Z
\"\n
"
,
n
->
val
.
u
.
sval
);
break
;
break
;
}
}
}
}
...
@@ -516,7 +518,7 @@ doimport2(Node *ss, Val *b, Node *st)
...
@@ -516,7 +518,7 @@ doimport2(Node *ss, Val *b, Node *st)
Sym
*
s
;
Sym
*
s
;
t
=
typ
(
TARRAY
);
t
=
typ
(
TARRAY
);
t
->
bound
=
b
->
vval
;
t
->
bound
=
mpgetfix
(
b
->
u
.
xval
)
;
s
=
pkglookup
(
st
->
sym
->
name
,
st
->
psym
->
name
);
s
=
pkglookup
(
st
->
sym
->
name
,
st
->
psym
->
name
);
t
->
type
=
s
->
otype
;
t
->
type
=
s
->
otype
;
...
@@ -542,6 +544,7 @@ doimport3(Node *ss, Node *n)
...
@@ -542,6 +544,7 @@ doimport3(Node *ss, Node *n)
t
->
outtuple
=
importcount
(
t
->
type
->
down
);
t
->
outtuple
=
importcount
(
t
->
type
->
down
);
t
->
intuple
=
importcount
(
t
->
type
->
down
->
down
);
t
->
intuple
=
importcount
(
t
->
type
->
down
->
down
);
dowidth
(
t
);
importfuncnam
(
t
);
importfuncnam
(
t
);
importaddtyp
(
ss
,
t
);
importaddtyp
(
ss
,
t
);
...
@@ -573,7 +576,7 @@ doimport5(Node *ss, Val *v)
...
@@ -573,7 +576,7 @@ doimport5(Node *ss, Val *v)
int
et
;
int
et
;
Type
*
t
;
Type
*
t
;
et
=
v
->
vval
;
et
=
mpgetfix
(
v
->
u
.
xval
)
;
if
(
et
<=
0
||
et
>=
nelem
(
types
)
||
types
[
et
]
==
T
)
if
(
et
<=
0
||
et
>=
nelem
(
types
)
||
types
[
et
]
==
T
)
fatal
(
"doimport5: bad type index: %E"
,
et
);
fatal
(
"doimport5: bad type index: %E"
,
et
);
...
@@ -631,7 +634,7 @@ doimport8(Node *ss, Val *v, Node *st)
...
@@ -631,7 +634,7 @@ doimport8(Node *ss, Val *v, Node *st)
int
dir
;
int
dir
;
s
=
pkglookup
(
st
->
sym
->
name
,
st
->
psym
->
name
);
s
=
pkglookup
(
st
->
sym
->
name
,
st
->
psym
->
name
);
dir
=
v
->
vval
;
dir
=
mpgetfix
(
v
->
u
.
xval
)
;
t
=
typ
(
TCHAN
);
t
=
typ
(
TCHAN
);
s
=
pkglookup
(
st
->
sym
->
name
,
st
->
psym
->
name
);
s
=
pkglookup
(
st
->
sym
->
name
,
st
->
psym
->
name
);
...
...
src/cmd/gc/go.h
View file @
9c2ade35
...
@@ -6,7 +6,6 @@
...
@@ -6,7 +6,6 @@
todo:
todo:
1. dyn arrays
1. dyn arrays
2. multi
2. multi
3. block 0
tothinkabout:
tothinkabout:
2. argument in import
2. argument in import
*/
*/
...
@@ -56,13 +55,46 @@ struct String
...
@@ -56,13 +55,46 @@ struct String
char
s
[
3
];
// variable
char
s
[
3
];
// variable
};
};
enum
{
Mpscale
=
29
,
/* safely smaller than bits in a long */
Mpprec
=
10
,
/* Mpscale*Mpprec is max number of bits */
Mpbase
=
1L
<<
Mpscale
,
Mpsign
=
Mpbase
>>
1
,
Mpmask
=
Mpbase
-
1
,
Debug
=
1
,
};
typedef
struct
Mpint
Mpint
;
struct
Mpint
{
vlong
val
;
long
a
[
Mpprec
];
uchar
neg
;
uchar
ovf
;
};
typedef
struct
Mpflt
Mpflt
;
struct
Mpflt
{
double
val
;
long
a
[
Mpprec
];
uchar
neg
;
uchar
ovf
;
};
typedef
struct
Val
Val
;
typedef
struct
Val
Val
;
struct
Val
struct
Val
{
{
int
ctype
;
short
ctype
;
double
dval
;
union
vlong
vval
;
{
String
*
sval
;
short
reg
;
// OREGISTER
short
bval
;
// bool value CTBOOL
Mpint
*
xval
;
// int CTINT
Mpflt
*
fval
;
// float CTFLT
String
*
sval
;
// string CTSTR
}
u
;
};
};
typedef
struct
Sym
Sym
;
typedef
struct
Sym
Sym
;
...
@@ -135,7 +167,7 @@ struct Node
...
@@ -135,7 +167,7 @@ struct Node
// func
// func
Node
*
nname
;
Node
*
nname
;
// OLITERAL
// OLITERAL
/OREGISTER
Val
val
;
Val
val
;
Sym
*
osym
;
// import
Sym
*
osym
;
// import
...
@@ -380,10 +412,11 @@ EXTERN uchar issimple[NTYPE];
...
@@ -380,10 +412,11 @@ EXTERN uchar issimple[NTYPE];
EXTERN
uchar
okforeq
[
NTYPE
];
EXTERN
uchar
okforeq
[
NTYPE
];
EXTERN
uchar
okforadd
[
NTYPE
];
EXTERN
uchar
okforadd
[
NTYPE
];
EXTERN
uchar
okforand
[
NTYPE
];
EXTERN
uchar
okforand
[
NTYPE
];
EXTERN
double
minfloatval
[
NTYPE
];
EXTERN
double
maxfloatval
[
NTYPE
];
EXTERN
Mpint
*
minintval
[
NTYPE
];
EXTERN
vlong
minintval
[
NTYPE
];
EXTERN
Mpint
*
maxintval
[
NTYPE
];
EXTERN
vlong
maxintval
[
NTYPE
];
EXTERN
Mpflt
*
minfltval
[
NTYPE
];
EXTERN
Mpflt
*
maxfltval
[
NTYPE
];
EXTERN
Dcl
*
autodcl
;
EXTERN
Dcl
*
autodcl
;
EXTERN
Dcl
*
paramdcl
;
EXTERN
Dcl
*
paramdcl
;
...
@@ -438,10 +471,46 @@ void ungetc(int);
...
@@ -438,10 +471,46 @@ void ungetc(int);
void
mkpackage
(
char
*
);
void
mkpackage
(
char
*
);
/*
/*
* mpa
tof
.c
* mpa
rith
.c
*/
*/
int
mpatof
(
char
*
,
double
*
);
void
mpmovefixfix
(
Mpint
*
a
,
Mpint
*
b
);
int
mpatov
(
char
*
,
vlong
*
);
void
mpmovefixflt
(
Mpflt
*
a
,
Mpint
*
b
);
void
mpmovefltfix
(
Mpint
*
a
,
Mpflt
*
b
);
void
mpmovefltflt
(
Mpflt
*
a
,
Mpflt
*
b
);
void
mpmovecfix
(
Mpint
*
a
,
vlong
v
);
void
mpmovecflt
(
Mpflt
*
a
,
double
f
);
int
mpcmpfixfix
(
Mpint
*
a
,
Mpint
*
b
);
int
mpcmpfltflt
(
Mpflt
*
a
,
Mpflt
*
b
);
int
mpcmpfixc
(
Mpint
*
b
,
vlong
c
);
int
mpcmpfltc
(
Mpint
*
b
,
double
c
);
int
mptestfixfix
(
Mpint
*
a
);
int
mptestfltflt
(
Mpflt
*
a
);
void
mpaddfixfix
(
Mpint
*
a
,
Mpint
*
b
);
void
mpaddfltflt
(
Mpflt
*
a
,
Mpflt
*
b
);
void
mpsubfixfix
(
Mpint
*
a
,
Mpint
*
b
);
void
mpsubfltflt
(
Mpflt
*
a
,
Mpflt
*
b
);
void
mpmulfixfix
(
Mpint
*
a
,
Mpint
*
b
);
void
mpmulfltflt
(
Mpflt
*
a
,
Mpflt
*
b
);
void
mpdivfixfix
(
Mpint
*
a
,
Mpint
*
b
);
void
mpdivfltflt
(
Mpflt
*
a
,
Mpflt
*
b
);
void
mpnegfix
(
Mpint
*
a
);
void
mpnegflt
(
Mpflt
*
a
);
void
mpandfixfix
(
Mpint
*
a
,
Mpint
*
b
);
void
mplshfixfix
(
Mpint
*
a
,
Mpint
*
b
);
void
mpmodfixfix
(
Mpint
*
a
,
Mpint
*
b
);
void
mporfixfix
(
Mpint
*
a
,
Mpint
*
b
);
void
mprshfixfix
(
Mpint
*
a
,
Mpint
*
b
);
void
mpxorfixfix
(
Mpint
*
a
,
Mpint
*
b
);
void
mpcomfix
(
Mpint
*
a
);
double
mpgetflt
(
Mpflt
*
a
);
vlong
mpgetfix
(
Mpint
*
a
);
void
mpatofix
(
Mpint
*
a
,
char
*
s
);
void
mpatoflt
(
Mpflt
*
a
,
char
*
s
);
/*
/*
* subr.c
* subr.c
...
...
src/cmd/gc/go.y
View file @
9c2ade35
...
@@ -13,7 +13,8 @@
...
@@ -13,7 +13,8 @@
int
lint
;
int
lint
;
}
}
%
token
<
sym
>
LNAME
LBASETYPE
LATYPE
LPACK
LACONST
%
token
<
sym
>
LNAME
LBASETYPE
LATYPE
LPACK
LACONST
%
token
<
val
>
LLITERAL
LASOP
%
token
<
val
>
LLITERAL
%
token
<
lint
>
LASOP
%
token
LPACKAGE
LIMPORT
LEXPORT
%
token
LPACKAGE
LIMPORT
LEXPORT
%
token
LMAP
LCHAN
LINTERFACE
LFUNC
LSTRUCT
%
token
LMAP
LCHAN
LINTERFACE
LFUNC
LSTRUCT
%
token
LCOLAS
LFALL
LRETURN
%
token
LCOLAS
LFALL
LRETURN
...
@@ -269,8 +270,8 @@ conexpr:
...
@@ -269,8 +270,8 @@ conexpr:
}
}
|
'='
expr
|
'='
expr
{
{
$$
=
$
2
;
lastconst
=
$
2
;
lastconst
=
treecopy
($$
);
$$
=
treecopy
(
lastconst
);
iota
+=
1
;
iota
+=
1
;
}
}
...
@@ -314,7 +315,7 @@ noninc_stmt:
...
@@ -314,7 +315,7 @@ noninc_stmt:
|
expr
LASOP
expr
|
expr
LASOP
expr
{
{
$$
=
nod
(
OASOP
,
$
1
,
$
3
);
$$
=
nod
(
OASOP
,
$
1
,
$
3
);
$$->
etype
=
$
2
.
vval
;
//
rathole
to
pass
opcode
$$->
etype
=
$
2
;
//
rathole
to
pass
opcode
}
}
|
expr_list
'='
expr_list
|
expr_list
'='
expr_list
{
{
...
@@ -687,7 +688,6 @@ pexpr:
...
@@ -687,7 +688,6 @@ pexpr:
{
{
$$
=
nod
(
OLITERAL
,
N
,
N
);
$$
=
nod
(
OLITERAL
,
N
,
N
);
$$->
val
.
ctype
=
CTNIL
;
$$->
val
.
ctype
=
CTNIL
;
$$->
val
.
vval
=
0
;
}
}
|
LTRUE
|
LTRUE
{
{
...
...
src/cmd/gc/lex.c
View file @
9c2ade35
...
@@ -207,11 +207,11 @@ importfile(Val *f)
...
@@ -207,11 +207,11 @@ importfile(Val *f)
return
;
return
;
}
}
if
(
!
findpkg
(
f
->
sval
))
if
(
!
findpkg
(
f
->
u
.
sval
))
fatal
(
"can't find import: %Z"
,
f
->
sval
);
fatal
(
"can't find import: %Z"
,
f
->
u
.
sval
);
imp
=
Bopen
(
namebuf
,
OREAD
);
imp
=
Bopen
(
namebuf
,
OREAD
);
if
(
imp
==
nil
)
if
(
imp
==
nil
)
fatal
(
"can't open import: %Z"
,
f
->
sval
);
fatal
(
"can't open import: %Z"
,
f
->
u
.
sval
);
file
=
strdup
(
namebuf
);
file
=
strdup
(
namebuf
);
len
=
strlen
(
namebuf
);
len
=
strlen
(
namebuf
);
...
@@ -245,7 +245,7 @@ importfile(Val *f)
...
@@ -245,7 +245,7 @@ importfile(Val *f)
continue
;
continue
;
return
;
return
;
}
}
yyerror
(
"no import in: %Z"
,
f
->
sval
);
yyerror
(
"no import in: %Z"
,
f
->
u
.
sval
);
unimportfile
();
unimportfile
();
}
}
...
@@ -390,7 +390,7 @@ l0:
...
@@ -390,7 +390,7 @@ l0:
cp
=
remal
(
cp
,
c1
,
1
);
cp
=
remal
(
cp
,
c1
,
1
);
cp
[
c1
++
]
=
0
;
cp
[
c1
++
]
=
0
;
}
while
(
c1
&
MAXALIGN
);
}
while
(
c1
&
MAXALIGN
);
yylval
.
val
.
sval
=
(
String
*
)
cp
;
yylval
.
val
.
u
.
sval
=
(
String
*
)
cp
;
yylval
.
val
.
ctype
=
CTSTR
;
yylval
.
val
.
ctype
=
CTSTR
;
DBG
(
"lex: string literal
\n
"
);
DBG
(
"lex: string literal
\n
"
);
return
LLITERAL
;
return
LLITERAL
;
...
@@ -403,7 +403,8 @@ l0:
...
@@ -403,7 +403,8 @@ l0:
yyerror
(
"missing '"
);
yyerror
(
"missing '"
);
ungetc
(
v
);
ungetc
(
v
);
}
}
yylval
.
val
.
vval
=
v
;
yylval
.
val
.
u
.
xval
=
mal
(
sizeof
(
*
yylval
.
val
.
u
.
xval
));
mpmovecfix
(
yylval
.
val
.
u
.
xval
,
v
);
yylval
.
val
.
ctype
=
CTINT
;
yylval
.
val
.
ctype
=
CTINT
;
DBG
(
"lex: codepoint literal
\n
"
);
DBG
(
"lex: codepoint literal
\n
"
);
return
LLITERAL
;
return
LLITERAL
;
...
@@ -594,7 +595,7 @@ lx:
...
@@ -594,7 +595,7 @@ lx:
return
c
;
return
c
;
asop:
asop:
yylval
.
val
.
vval
=
c
;
// rathole to hold which asop
yylval
.
lint
=
c
;
// rathole to hold which asop
DBG
(
"lex: TOKEN ASOP %c
\n
"
,
c
);
DBG
(
"lex: TOKEN ASOP %c
\n
"
,
c
);
return
LASOP
;
return
LASOP
;
...
@@ -695,9 +696,12 @@ dc:
...
@@ -695,9 +696,12 @@ dc:
ncu:
ncu:
*
cp
=
0
;
*
cp
=
0
;
ungetc
(
c
);
ungetc
(
c
);
if
(
mpatov
(
namebuf
,
&
yylval
.
val
.
vval
))
{
yylval
.
val
.
u
.
xval
=
mal
(
sizeof
(
*
yylval
.
val
.
u
.
xval
));
mpatofix
(
yylval
.
val
.
u
.
xval
,
namebuf
);
if
(
yylval
.
val
.
u
.
xval
->
ovf
)
{
yyerror
(
"overflow in constant"
);
yyerror
(
"overflow in constant"
);
yylval
.
val
.
vval
=
0
;
mpmovecfix
(
yylval
.
val
.
u
.
xval
,
0
)
;
}
}
yylval
.
val
.
ctype
=
CTINT
;
yylval
.
val
.
ctype
=
CTINT
;
DBG
(
"lex: integer literal
\n
"
);
DBG
(
"lex: integer literal
\n
"
);
...
@@ -730,9 +734,12 @@ casee:
...
@@ -730,9 +734,12 @@ casee:
caseout:
caseout:
*
cp
=
0
;
*
cp
=
0
;
ungetc
(
c
);
ungetc
(
c
);
if
(
mpatof
(
namebuf
,
&
yylval
.
val
.
dval
))
{
yylval
.
val
.
u
.
fval
=
mal
(
sizeof
(
*
yylval
.
val
.
u
.
fval
));
mpatoflt
(
yylval
.
val
.
u
.
fval
,
namebuf
);
if
(
yylval
.
val
.
u
.
fval
->
ovf
)
{
yyerror
(
"overflow in float constant"
);
yyerror
(
"overflow in float constant"
);
yylval
.
val
.
dval
=
0
;
mpmovecflt
(
yylval
.
val
.
u
.
fval
,
0
.
0
)
;
}
}
yylval
.
val
.
ctype
=
CTFLT
;
yylval
.
val
.
ctype
=
CTFLT
;
DBG
(
"lex: floating literal
\n
"
);
DBG
(
"lex: floating literal
\n
"
);
...
@@ -1040,11 +1047,15 @@ lexinit(void)
...
@@ -1040,11 +1047,15 @@ lexinit(void)
okforadd
[
i
]
=
1
;
okforadd
[
i
]
=
1
;
okforand
[
i
]
=
1
;
okforand
[
i
]
=
1
;
issimple
[
i
]
=
1
;
issimple
[
i
]
=
1
;
minintval
[
i
]
=
mal
(
sizeof
(
*
minintval
[
i
]));
maxintval
[
i
]
=
mal
(
sizeof
(
*
maxintval
[
i
]));
}
}
if
(
isfloat
[
i
])
{
if
(
isfloat
[
i
])
{
okforeq
[
i
]
=
1
;
okforeq
[
i
]
=
1
;
okforadd
[
i
]
=
1
;
okforadd
[
i
]
=
1
;
issimple
[
i
]
=
1
;
issimple
[
i
]
=
1
;
minfltval
[
i
]
=
mal
(
sizeof
(
*
minfltval
[
i
]));
maxfltval
[
i
]
=
mal
(
sizeof
(
*
maxfltval
[
i
]));
}
}
switch
(
i
)
{
switch
(
i
)
{
case
TBOOL
:
case
TBOOL
:
...
@@ -1055,35 +1066,27 @@ lexinit(void)
...
@@ -1055,35 +1066,27 @@ lexinit(void)
okforeq
[
i
]
=
1
;
okforeq
[
i
]
=
1
;
break
;
break
;
}
}
minfloatval
[
i
]
=
0
.
0
;
maxfloatval
[
i
]
=
0
.
0
;
minintval
[
i
]
=
0
;
maxintval
[
i
]
=
0
;
}
}
// this stuff smells - really need to do constants
mpatofix
(
maxintval
[
TINT8
],
"0x7f"
);
// in multi precision arithmetic
mpatofix
(
minintval
[
TINT8
],
"-0x80"
);
mpatofix
(
maxintval
[
TINT16
],
"0x7fff"
);
maxintval
[
TINT8
]
=
0x7f
;
mpatofix
(
minintval
[
TINT16
],
"-0x8000"
);
minintval
[
TINT8
]
=
-
maxintval
[
TINT8
]
-
1
;
mpatofix
(
maxintval
[
TINT32
],
"0x7fffffff"
);
maxintval
[
TINT16
]
=
0x7fff
;
mpatofix
(
minintval
[
TINT32
],
"-0x80000000"
);
minintval
[
TINT16
]
=
-
maxintval
[
TINT16
]
-
1
;
mpatofix
(
maxintval
[
TINT64
],
"0x7fffffffffffffff"
);
maxintval
[
TINT32
]
=
0x7fffffffL
;
mpatofix
(
minintval
[
TINT64
],
"-0x8000000000000000"
);
minintval
[
TINT32
]
=
-
maxintval
[
TINT32
]
-
1
;
mpatofix
(
maxintval
[
TUINT8
],
"0xff"
);
maxintval
[
TINT64
]
=
0x7fffffffffffffffLL
;
mpatofix
(
maxintval
[
TUINT16
],
"0xffff"
);
minintval
[
TINT64
]
=
-
maxintval
[
TINT64
]
-
1
;
mpatofix
(
maxintval
[
TUINT32
],
"0xffffffff"
);
maxintval
[
TUINT8
]
=
0xff
;
mpatofix
(
maxintval
[
TUINT64
],
"0x7fffffffffffffff"
);
maxintval
[
TUINT16
]
=
0xffff
;
mpatofix
(
minintval
[
TUINT64
],
"-0x8000000000000000"
);
maxintval
[
TUINT32
]
=
0xffffffffL
;
mpatoflt
(
maxfltval
[
TFLOAT32
],
"3.40282347e+38"
);
/* special case until we got to multiple precision */
mpatoflt
(
minfltval
[
TFLOAT32
],
"-3.40282347e+38"
);
maxintval
[
TUINT64
]
=
0x7fffffffffffffffLL
;
mpatoflt
(
maxfltval
[
TFLOAT64
],
"1.7976931348623157e+308"
);
minintval
[
TUINT64
]
=
-
maxintval
[
TUINT64
]
-
1
;
mpatoflt
(
minfltval
[
TFLOAT64
],
"-1.7976931348623157e+308"
);
maxfloatval
[
TFLOAT32
]
=
3.40282347e+38
;
minfloatval
[
TFLOAT32
]
=
-
maxfloatval
[
TFLOAT32
];
maxfloatval
[
TFLOAT64
]
=
1.7976931348623157e+308
;
minfloatval
[
TFLOAT64
]
=
-
maxfloatval
[
TFLOAT64
]
-
1
;
/*
/*
* initialize basic types array
* initialize basic types array
...
@@ -1126,14 +1129,14 @@ lexinit(void)
...
@@ -1126,14 +1129,14 @@ lexinit(void)
belexinit
(
LBASETYPE
);
belexinit
(
LBASETYPE
);
booltrue
=
nod
(
OLITERAL
,
N
,
N
);
booltrue
=
nod
(
OLITERAL
,
N
,
N
);
booltrue
->
val
.
u
.
bval
=
1
;
booltrue
->
val
.
ctype
=
CTBOOL
;
booltrue
->
val
.
ctype
=
CTBOOL
;
booltrue
->
val
.
vval
=
1
;
booltrue
->
type
=
types
[
TBOOL
];
booltrue
->
type
=
types
[
TBOOL
];
booltrue
->
addable
=
1
;
booltrue
->
addable
=
1
;
boolfalse
=
nod
(
OLITERAL
,
N
,
N
);
boolfalse
=
nod
(
OLITERAL
,
N
,
N
);
boolfalse
->
val
.
u
.
bval
=
0
;
boolfalse
->
val
.
ctype
=
CTBOOL
;
boolfalse
->
val
.
ctype
=
CTBOOL
;
boolfalse
->
val
.
vval
=
0
;
boolfalse
->
type
=
types
[
TBOOL
];
boolfalse
->
type
=
types
[
TBOOL
];
boolfalse
->
addable
=
1
;
boolfalse
->
addable
=
1
;
}
}
...
...
src/cmd/gc/subr.c
View file @
9c2ade35
...
@@ -313,7 +313,8 @@ nodintconst(int32 v)
...
@@ -313,7 +313,8 @@ nodintconst(int32 v)
c
=
nod
(
OLITERAL
,
N
,
N
);
c
=
nod
(
OLITERAL
,
N
,
N
);
c
->
addable
=
1
;
c
->
addable
=
1
;
c
->
val
.
vval
=
v
;
c
->
val
.
u
.
xval
=
mal
(
sizeof
(
*
c
->
val
.
u
.
xval
));
mpmovecfix
(
c
->
val
.
u
.
xval
,
v
);
c
->
val
.
ctype
=
CTINT
;
c
->
val
.
ctype
=
CTINT
;
c
->
type
=
types
[
TINT32
];
c
->
type
=
types
[
TINT32
];
ullmancalc
(
c
);
ullmancalc
(
c
);
...
@@ -391,7 +392,7 @@ aindex(Node *b, Type *t)
...
@@ -391,7 +392,7 @@ aindex(Node *b, Type *t)
break
;
break
;
case
Wlitint
:
// fixed lb
case
Wlitint
:
// fixed lb
r
->
bound
=
b
->
val
.
vval
;
r
->
bound
=
mpgetfix
(
b
->
val
.
u
.
xval
)
;
break
;
break
;
}
}
return
r
;
return
r
;
...
@@ -1043,31 +1044,31 @@ Nconv(Fmt *fp)
...
@@ -1043,31 +1044,31 @@ Nconv(Fmt *fp)
goto
ptyp
;
goto
ptyp
;
case
OREGISTER
:
case
OREGISTER
:
snprint
(
buf
,
sizeof
(
buf
),
"%O-%R%J"
,
n
->
op
,
(
int
)
n
->
val
.
vval
,
n
);
snprint
(
buf
,
sizeof
(
buf
),
"%O-%R%J"
,
n
->
op
,
n
->
val
.
u
.
reg
,
n
);
break
;
break
;
case
OLITERAL
:
case
OLITERAL
:
switch
(
n
->
val
.
ctype
)
{
switch
(
n
->
val
.
ctype
)
{
default:
default:
snprint
(
buf1
,
sizeof
(
buf1
),
"LITERAL-ctype=%d
%lld"
,
n
->
val
.
ctype
,
n
->
val
.
vval
);
snprint
(
buf1
,
sizeof
(
buf1
),
"LITERAL-ctype=%d
"
,
n
->
val
.
ctype
);
break
;
break
;
case
CTINT
:
case
CTINT
:
snprint
(
buf1
,
sizeof
(
buf1
),
"I%lld"
,
n
->
val
.
vval
);
snprint
(
buf1
,
sizeof
(
buf1
),
"I%lld"
,
mpgetfix
(
n
->
val
.
u
.
xval
)
);
break
;
break
;
case
CTSINT
:
case
CTSINT
:
snprint
(
buf1
,
sizeof
(
buf1
),
"S%lld"
,
n
->
val
.
vval
);
snprint
(
buf1
,
sizeof
(
buf1
),
"S%lld"
,
mpgetfix
(
n
->
val
.
u
.
xval
)
);
break
;
break
;
case
CTUINT
:
case
CTUINT
:
snprint
(
buf1
,
sizeof
(
buf1
),
"U%lld"
,
n
->
val
.
vval
);
snprint
(
buf1
,
sizeof
(
buf1
),
"U%lld"
,
mpgetfix
(
n
->
val
.
u
.
xval
)
);
break
;
break
;
case
CTFLT
:
case
CTFLT
:
snprint
(
buf1
,
sizeof
(
buf1
),
"F%g"
,
n
->
val
.
dval
);
snprint
(
buf1
,
sizeof
(
buf1
),
"F%g"
,
mpgetflt
(
n
->
val
.
u
.
fval
)
);
break
;
break
;
case
CTSTR
:
case
CTSTR
:
snprint
(
buf1
,
sizeof
(
buf1
),
"S
\"
%Z
\"
"
,
n
->
val
.
sval
);
snprint
(
buf1
,
sizeof
(
buf1
),
"S
\"
%Z
\"
"
,
n
->
val
.
u
.
sval
);
break
;
break
;
case
CTBOOL
:
case
CTBOOL
:
snprint
(
buf1
,
sizeof
(
buf1
),
"B%lld"
,
n
->
val
.
v
val
);
snprint
(
buf1
,
sizeof
(
buf1
),
"B%lld"
,
n
->
val
.
u
.
b
val
);
break
;
break
;
case
CTNIL
:
case
CTNIL
:
snprint
(
buf1
,
sizeof
(
buf1
),
"N"
);
snprint
(
buf1
,
sizeof
(
buf1
),
"N"
);
...
@@ -1118,7 +1119,6 @@ treecopy(Node *n)
...
@@ -1118,7 +1119,6 @@ treecopy(Node *n)
case
OLITERAL
:
case
OLITERAL
:
if
(
n
->
iota
)
{
if
(
n
->
iota
)
{
m
=
literal
(
iota
);
m
=
literal
(
iota
);
m
->
iota
=
1
;
// flag to reevaluate on copy
break
;
break
;
}
}
m
=
nod
(
OXXX
,
N
,
N
);
m
=
nod
(
OXXX
,
N
,
N
);
...
@@ -1528,8 +1528,9 @@ literal(int32 v)
...
@@ -1528,8 +1528,9 @@ literal(int32 v)
Node
*
n
;
Node
*
n
;
n
=
nod
(
OLITERAL
,
N
,
N
);
n
=
nod
(
OLITERAL
,
N
,
N
);
n
->
val
.
u
.
xval
=
mal
(
sizeof
(
*
n
->
val
.
u
.
xval
));
n
->
val
.
ctype
=
CTINT
;
n
->
val
.
ctype
=
CTINT
;
n
->
val
.
vval
=
v
;
mpmovecfix
(
n
->
val
.
u
.
xval
,
v
)
;
return
n
;
return
n
;
}
}
...
...
src/cmd/gc/walk.c
View file @
9c2ade35
...
@@ -762,8 +762,9 @@ loop:
...
@@ -762,8 +762,9 @@ loop:
break
;
break
;
l
=
nod
(
OLITERAL
,
N
,
N
);
l
=
nod
(
OLITERAL
,
N
,
N
);
l
->
val
.
u
.
fval
=
mal
(
sizeof
(
*
l
->
val
.
u
.
fval
));
l
->
val
.
ctype
=
CTFLT
;
l
->
val
.
ctype
=
CTFLT
;
l
->
val
.
dval
=
0
;
mpmovecflt
(
l
->
val
.
u
.
fval
,
0
.
0
)
;
l
=
nod
(
OSUB
,
l
,
n
->
left
);
l
=
nod
(
OSUB
,
l
,
n
->
left
);
*
n
=
*
l
;
*
n
=
*
l
;
...
@@ -991,7 +992,6 @@ recv:
...
@@ -991,7 +992,6 @@ recv:
a
=
c
->
left
;
// nil elem
a
=
c
->
left
;
// nil elem
a
=
nod
(
OLITERAL
,
N
,
N
);
a
=
nod
(
OLITERAL
,
N
,
N
);
a
->
val
.
ctype
=
CTNIL
;
a
->
val
.
ctype
=
CTNIL
;
a
->
val
.
vval
=
0
;
r
=
a
;
r
=
a
;
a
=
c
->
left
;
// chan
a
=
c
->
left
;
// chan
...
@@ -1987,7 +1987,6 @@ chanop(Node *n, int top)
...
@@ -1987,7 +1987,6 @@ chanop(Node *n, int top)
if
(
a
==
N
)
{
if
(
a
==
N
)
{
a
=
nod
(
OLITERAL
,
N
,
N
);
a
=
nod
(
OLITERAL
,
N
,
N
);
a
->
val
.
ctype
=
CTNIL
;
a
->
val
.
ctype
=
CTNIL
;
a
->
val
.
vval
=
0
;
}
else
}
else
a
=
nod
(
OADDR
,
a
,
N
);
a
=
nod
(
OADDR
,
a
,
N
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment