2
0

aoptutils.pas 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. {
  2. Copyright (c) 1998-2016 by Florian Klaempfl and Jonas Maebe
  3. This unit contains helper procedures for the assembler peephole optimizer
  4. This program is free software; you can redistribute it and/or modify
  5. it under the terms of the GNU General Public License as published by
  6. the Free Software Foundation; either version 2 of the License, or
  7. (at your option) any later version.
  8. This program is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. GNU General Public License for more details.
  12. You should have received a copy of the GNU General Public License
  13. along with this program; if not, write to the Free Software
  14. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  15. ****************************************************************************
  16. }
  17. unit aoptutils;
  18. {$i fpcdefs.inc}
  19. interface
  20. uses
  21. cpubase,aasmtai,aasmcpu;
  22. function MatchOpType(const p : taicpu;type0: toptype) : Boolean;
  23. function MatchOpType(const p : taicpu;type0,type1 : toptype) : Boolean;
  24. {$if max_operands>2}
  25. function MatchOpType(const p : taicpu; type0,type1,type2 : toptype) : Boolean;
  26. {$endif max_operands>2}
  27. { skips all labels and returns the next "real" instruction }
  28. function SkipLabels(hp: tai; out hp2: tai): boolean;
  29. { sets hp2 to hp and returns True if hp is not nil }
  30. function SetAndTest(const hp: tai; out hp2: tai): Boolean; inline;
  31. { Set Store and Result to Condition (useful as an inline assignment in a conditional block) }
  32. function SetAndTest(const Condition: Boolean; out Store: Boolean): Boolean; inline;
  33. implementation
  34. uses
  35. aasmbase;
  36. function MatchOpType(const p : taicpu; type0: toptype) : Boolean; inline;
  37. begin
  38. Result:=(p.ops=1) and (p.oper[0]^.typ=type0);
  39. end;
  40. function MatchOpType(const p : taicpu; type0,type1 : toptype) : Boolean; inline;
  41. begin
  42. Result:=(p.ops=2) and (p.oper[0]^.typ=type0) and (p.oper[1]^.typ=type1);
  43. end;
  44. {$if max_operands>2}
  45. function MatchOpType(const p : taicpu; type0,type1,type2 : toptype) : Boolean; inline;
  46. begin
  47. Result:=(p.ops=3) and (p.oper[0]^.typ=type0) and (p.oper[1]^.typ=type1) and (p.oper[2]^.typ=type2);
  48. end;
  49. {$endif max_operands>2}
  50. { skips all labels and returns the next "real" instruction }
  51. function SkipLabels(hp: tai; out hp2: tai): boolean;
  52. begin
  53. while assigned(hp.next) and
  54. (tai(hp.next).typ in SkipInstr + [ait_label]) Do
  55. hp := tai(hp.next);
  56. if assigned(hp.next) then
  57. begin
  58. SkipLabels := True;
  59. hp2 := tai(hp.next)
  60. end
  61. else
  62. begin
  63. hp2 := hp;
  64. SkipLabels := False
  65. end;
  66. end;
  67. { sets hp2 to hp and returns True if hp is not nil }
  68. function SetAndTest(const hp: tai; out hp2: tai): Boolean;
  69. begin
  70. hp2 := hp;
  71. Result := Assigned(hp);
  72. end;
  73. { Set Store and Result to Condition (useful as an inline assignment in a conditional block) }
  74. function SetAndTest(const Condition: Boolean; out Store: Boolean): Boolean;
  75. begin
  76. Store := Condition;
  77. Result := Store;
  78. end;
  79. end.