URL
https://opencores.org/ocsvn/openrisc/openrisc/trunk
Only display areas with differences |
Details |
Blame |
View Log
Rev 304 |
Rev 338 |
-- { dg-do run }
|
-- { dg-do run }
|
|
|
procedure Pack3 is
|
procedure Pack3 is
|
|
|
type U32 is mod 2 ** 32;
|
type U32 is mod 2 ** 32;
|
|
|
type Key is record
|
type Key is record
|
Value : U32;
|
Value : U32;
|
Valid : Boolean;
|
Valid : Boolean;
|
end record;
|
end record;
|
|
|
type Key_Buffer is record
|
type Key_Buffer is record
|
Current, Latch : Key;
|
Current, Latch : Key;
|
end record;
|
end record;
|
|
|
type Block is record
|
type Block is record
|
Keys : Key_Buffer;
|
Keys : Key_Buffer;
|
Stamp : U32;
|
Stamp : U32;
|
end record;
|
end record;
|
pragma Pack (Block);
|
pragma Pack (Block);
|
|
|
My_Block : Block;
|
My_Block : Block;
|
My_Stamp : constant := 16#01234567#;
|
My_Stamp : constant := 16#01234567#;
|
|
|
begin
|
begin
|
My_Block.Stamp := My_Stamp;
|
My_Block.Stamp := My_Stamp;
|
My_Block.Keys.Latch := My_Block.Keys.Current;
|
My_Block.Keys.Latch := My_Block.Keys.Current;
|
if My_Block.Stamp /= My_Stamp then
|
if My_Block.Stamp /= My_Stamp then
|
raise Program_Error;
|
raise Program_Error;
|
end if;
|
end if;
|
end;
|
end;
|
|
|
© copyright 1999-2024
OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.