* Improved -sr on PowerPC ATT asm writer

This commit is contained in:
daniel 2003-08-18 11:58:14 +00:00
parent 4c571efdda
commit 86fde70d18

View File

@ -143,6 +143,21 @@ unit agppcgas;
symaddr2str: array[trefsymaddr] of string[3] = ('','@ha','@l');
function regname(r:Tnewregister):string;
var s:Tsuperregister;
begin
s:=r shr 8;
if s in [RS_0..RS_31] then
s:='r'+tostr(s-RS_0)
else
begin
{Generate a systematic name.}
s:='reg'+tostr(s)+'d';
end;
end;
function getreferencestring(var ref : treference) : string;
var
s : string;
@ -186,13 +201,13 @@ unit agppcgas;
s:=s+'0';
end;
if base.enum=R_INTREGISTER then
s:=s+'(reg'+tostr(byte(base.number shr 8))+')'
s:=s+'(reg'+regname(base.number)+')'
else
s:=s+'('+gas_reg2str[base.enum]+')';
end
else if (not i) and (not b) and (offset=0) then
if base.enum=R_INTREGISTER then
s:=s+'r'+tostr(byte(base.number shr 8))+',r'+tostr(byte(index.number shr 8))
s:=s+'r'+regname(base.number)+',r'+regname(index.number))
else
s:=s+gas_reg2str[base.enum]+','+gas_reg2str[index.enum]
else if (not i) or (not b) then
@ -211,7 +226,10 @@ unit agppcgas;
begin
if (o.reg.enum < R_0) or (o.reg.enum > lastreg) then
internalerror(200303121);
getopstr_jmp:=gas_reg2str[o.reg.enum];
if o.reg=R_INTREGISTER then
getopstr_jmp:=regname(o.reg.number)
else
getopstr_jmp:=gas_reg2str[o.reg.enum];
end;
{ no top_ref jumping for powerpc }
top_const :
@ -371,7 +389,10 @@ begin
end.
{
$Log$
Revision 1.26 2003-08-17 21:11:00 daniel
Revision 1.27 2003-08-18 11:58:14 daniel
* Improved -sr on PowerPC ATT asm writer
Revision 1.26 2003/08/17 21:11:00 daniel
* Now -sr works...
Revision 1.25 2003/08/17 20:47:47 daniel