Browse Source

* Debug: Register read/write information is now clearer under "DEBUG_INSTRUCTIONREGISTERDEPENDENCIES"

J. Gareth "Curious Kit" Moreton 2 months ago
parent
commit
ed1893bd8f
1 changed files with 20 additions and 3 deletions
  1. 20 3
      compiler/aoptobj.pas

+ 20 - 3
compiler/aoptobj.pas

@@ -2845,12 +2845,14 @@ Unit AoptObj;
 {$ifdef x86}
 {$ifdef x86}
                 taicpu(p).SetOperandOrder(op_att);
                 taicpu(p).SetOperandOrder(op_att);
 {$endif x86}
 {$endif x86}
-                commentstr:='Instruction reads';
+                commentstr:='Instruction reads from';
                 registers_found:=false;
                 registers_found:=false;
                 for ri in tregisterindex do
                 for ri in tregisterindex do
                   begin
                   begin
                     reg:=regnumber_table[ri];
                     reg:=regnumber_table[ri];
-                    if (reg<>NR_NO) and InstructionLoadsFromReg(reg,p) then
+                    if (reg<>NR_NO) and InstructionLoadsFromReg(reg,p) and
+                      { Modified registers are handled below }
+                      not RegModifiedByInstruction(reg,p) then
                       begin
                       begin
                         commentstr:=commentstr+' '+std_regname(reg);
                         commentstr:=commentstr+' '+std_regname(reg);
                         registers_found:=true;
                         registers_found:=true;
@@ -2858,7 +2860,22 @@ Unit AoptObj;
                   end;
                   end;
                 if not registers_found then
                 if not registers_found then
                   commentstr:=commentstr+' no registers';
                   commentstr:=commentstr+' no registers';
-                commentstr:=commentstr+' and writes new values in';
+                commentstr:=commentstr+', modifies';
+                registers_found:=false;
+                for ri in tregisterindex do
+                  begin
+                    reg:=regnumber_table[ri];
+                    if (reg<>NR_NO) and RegModifiedByInstruction(reg,p) and
+                      { Pure writes are handled below }
+                      not RegLoadedWithNewValue(reg,p) then
+                      begin
+                        commentstr:=commentstr+' '+std_regname(reg);
+                        registers_found:=true;
+                      end;
+                  end;
+                if not registers_found then
+                  commentstr:=commentstr+' no registers';
+                commentstr:=commentstr+' and writes new values to';
                 registers_found:=false;
                 registers_found:=false;
                 for ri in tregisterindex do
                 for ri in tregisterindex do
                   begin
                   begin