blob: 03c9f44840c4234ab483a83ab50beebaa49db6a9 [file] [log] [blame]
Nico Huberef4545a2017-06-18 02:58:40 +02001--
2-- Copyright (C) 2017 Nico Huber <nico.h@gmx.de>
3--
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--
9-- This program is distributed in the hope that it will be useful,
10-- but WITHOUT ANY WARRANTY; without even the implied warranty of
11-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12-- GNU General Public License for more details.
13--
14
15with System;
16with HW.MMIO_Range;
17
18pragma Elaborate_All (HW.MMIO_Range);
19
20private generic
21 Dev : Address := (0, 0, 0);
22package HW.PCI.MMConf
23with
24 Abstract_State => (Address_State, (PCI_State with External)),
25 Initializes => Address_State
26is
27
28 procedure Read8 (Value : out Word8; Offset : Index);
29 procedure Read16 (Value : out Word16; Offset : Index)
30 with
31 Pre => Offset mod 2 = 0;
32 procedure Read32 (Value : out Word32; Offset : Index)
33 with
34 Pre => Offset mod 4 = 0;
35
36 procedure Write8 (Offset : Index; Value : Word8);
37 procedure Write16 (Offset : Index; Value : Word16)
38 with
39 Pre => Offset mod 2 = 0;
40 procedure Write32 (Offset : Index; Value : Word32)
41 with
42 Pre => Offset mod 4 = 0;
43
44 procedure Set_Base_Address (Base : Word64);
45
46end HW.PCI.MMConf;