-- { dg-do run }
with Init9; use Init9;
with Ada.Numerics; use Ada.Numerics;
with Text_IO; use Text_IO;
with Dump;
procedure Q9 is
  A1 : R1 := My_R1;
  B1 : R1 := My_R1;
  A2 : R2 := My_R2;
  B2 : R2 := My_R2;
begin
  Put ("A1 :");
  Dump (A1'Address, R1'Max_Size_In_Storage_Elements);
  New_Line;
  -- { dg-output "A1 : 18 2d 44 54 fb 21 09 40.*\n" }
  Put ("B1 :");
  Dump (B1'Address, R1'Max_Size_In_Storage_Elements);
  New_Line;
  -- { dg-output "B1 : 18 2d 44 54 fb 21 09 40.*\n" }
  Put ("A2 :");
  Dump (A2'Address, R2'Max_Size_In_Storage_Elements);
  New_Line;
  -- { dg-output "A2 : 40 09 21 fb 54 44 2d 18.*\n" }
  Put ("B2 :");
  Dump (B2'Address, R2'Max_Size_In_Storage_Elements);
  New_Line;
  -- { dg-output "B2 : 40 09 21 fb 54 44 2d 18.*\n" }
  if A1.F /= B1.F then
    raise Program_Error;
  end if;
  if A1.F /= Pi then
    raise Program_Error;
  end if;
  if A2.F /= B2.F then
    raise Program_Error;
  end if;
  if A2.F /= Pi then
    raise Program_Error;
  end if;
end;