Test suite results for test file webtbs/tw3782.pp

Test run data :

Run ID:
Operating system: linux
Processor: i386
Version: 3.3.1
Fails/OK/Total: 46/9610/9656
Version: 3.3.1
Full version: 3.3.1-15584-g2f9ed0576e
Comment: -XR/home/muller/sys-root/i386-linux -Xd -Xr/home/muller/sys-root/i386-linux
Machine: gcc188
Category: 1
SVN revisions: 2f9ed0576e:8b7dbb81b1:3f8bbd3b00:2f9ed0576e
Submitter: muller
Date: 2024/04/19 11:34:00
Previous run: 934311
Next run: 935655

Hide skipped tests

Hide successful tests

Test file "webtbs/tw3782.pp" information:

t_id 1537
t_cpu i386
t_adddate 2005/03/25
t_result 0
t_knownrunerror 0
t_opts -Ogr

Detailed test run results:

tr_idruntr_oktr_skiptr_result
443849501934995TrueFalseSuccessfully run

Record count: 1

No log of 934995.

Source:

{ %cpu=i386 }
{ %opt=-Ogr }

{$mode delphi}

type
  my_rec = record
    my_field: string;
    end;

var
 my_fyl: my_rec;
 my_str: array[0..99] of char;

function my_func(var f: my_rec):PChar;
begin
  my_func:=@my_str[1];
end;

procedure my_proc(var f: my_rec; const s: String);
var i, len: Integer; wascur: PChar;
begin
  len := length(s);
  wascur := my_func(f);
  for i:=0 to len-1 do
   wascur[i]:=s[i+1];
end;

begin
my_proc(my_fyl,'xxx');
my_str[0]:='y';
writeln(my_str);
end.

{
It's a spilling bug:

# [23] wascur[i]:=s[i+1];
         movl    -8(%ebp),%ireg23d
         # Register %ireg24d allocated
         movl    %ireg16d,%ireg24d
         incl    %ireg24d
         # Register %ireg24d released
         # Register %ireg25d allocated
         movl    %ireg24d,%ireg25d
         # Register %ireg26d allocated
        movl    -12(%ebp),%ireg26d
         # Register %ireg26d released
         # Register %edi allocated
         leal    (%ireg26d,%ireg16d,1),%edi
         # Register %ireg23d,%ireg25d released

becomes

# [23] wascur[i]:=s[i+1];
         movl    -8(%ebp),%edx
         # Register %ecx allocated
         movl    -20(%ebp),%ecx
         incl    %ecx
         # Register %eax allocated
        movl    -12(%ebp),%eax
         # Register %eax released
         # Register %edi,%eax allocated
        movl    -20(%ebp),%eax
         # Register %eax released
         leal    (%eax,%eax,1),%edi
         # Register %edx,%ecx released


ireg16d is spilled to -20(%ebp), so before the leal it must be loaded
into a register. The spilling code picks eax, but that one is already
used at that moment (by ireg26d).
}

Link to SVN view of webtbs/tw3782.pp source.