blob: 2b29f999453bb9147f1097534bbf9e8726e488ad [file] [log] [blame]
Nico Huber83693c82016-10-08 22:17:55 +02001--
Nico Huber01b680f2017-06-09 16:24:22 +02002-- Copyright (C) 2015-2017 secunet Security Networks AG
Nico Huber83693c82016-10-08 22:17:55 +02003--
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
Nico Huber125a29e2016-10-18 00:23:54 +02006-- the Free Software Foundation; either version 2 of the License, or
7-- (at your option) any later version.
Nico Huber83693c82016-10-08 22:17:55 +02008--
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 HW.GFX.GMA.Config;
16with HW.GFX.GMA.Panel;
17with HW.GFX.GMA.Connectors.DDI;
18
19with HW.Debug;
20with GNAT.Source_Info;
21
22package body HW.GFX.GMA.Connectors is
23
Nico Huber3a0e2a02017-07-19 14:41:46 +020024 procedure Post_Reset_Off
25 is
26 begin
27 DDI.Post_Reset_Off;
28 end Post_Reset_Off;
29
Nico Huber0923b792017-06-09 15:28:41 +020030 procedure Initialize
31 is
32 begin
Nico Huber01b680f2017-06-09 16:24:22 +020033 DDI.Initialize;
Nico Huber0923b792017-06-09 15:28:41 +020034 end Initialize;
35
Nico Huber83693c82016-10-08 22:17:55 +020036 procedure Pre_On
Nico Huber6e327c92016-12-21 14:45:45 +010037 (Pipe : in Pipe_Index;
38 Port_Cfg : in Port_Config;
39 PLL_Hint : in Word32;
40 Success : out Boolean)
Nico Huber83693c82016-10-08 22:17:55 +020041 is
42 begin
43 pragma Debug (Debug.Put_Line (GNAT.Source_Info.Enclosing_Entity));
Arthur Heymans5d08a932018-03-28 17:00:18 +020044 if Port_Cfg.Port in Digital_Port then
45 DDI.Pre_On (Port_Cfg, PLL_Hint, Success);
46 else
47 Success := False; -- Should not happen
48 end if;
Nico Huber83693c82016-10-08 22:17:55 +020049 end Pre_On;
50
51 procedure Post_On
52 (Port_Cfg : in Port_Config;
53 PLL_Hint : in Word32;
54 Success : out Boolean)
55 is
56 begin
57 pragma Debug (Debug.Put_Line (GNAT.Source_Info.Enclosing_Entity));
58
Arthur Heymans5d08a932018-03-28 17:00:18 +020059 if Port_Cfg.Port in Digital_Port then
60 DDI.Post_On (Port_Cfg);
Nico Huber83693c82016-10-08 22:17:55 +020061
Arthur Heymans5d08a932018-03-28 17:00:18 +020062 if Port_Cfg.Port = DIGI_A then
63 Panel.Backlight_On;
64 end if;
65 Success := True;
66 else
67 Success := False; -- Should not happen
Nico Huber83693c82016-10-08 22:17:55 +020068 end if;
Nico Huber83693c82016-10-08 22:17:55 +020069 end Post_On;
70
71 ----------------------------------------------------------------------------
72
73 procedure Pre_Off (Port_Cfg : Port_Config)
74 is
75 begin
76 pragma Debug (Debug.Put_Line (GNAT.Source_Info.Enclosing_Entity));
77
78 if Port_Cfg.Port = DIGI_A then
79 Panel.Backlight_Off;
80 Panel.Off;
81 end if;
82 end Pre_Off;
83
84 procedure Post_Off (Port_Cfg : Port_Config)
85 is
86 begin
87 pragma Debug (Debug.Put_Line (GNAT.Source_Info.Enclosing_Entity));
Arthur Heymans5d08a932018-03-28 17:00:18 +020088 if Port_Cfg.Port in Digital_Port then
89 DDI.Off (Port_Cfg.Port);
90 end if;
Nico Huber83693c82016-10-08 22:17:55 +020091 end Post_Off;
92
93 ----------------------------------------------------------------------------
94
95 procedure Pre_All_Off
96 is
97 begin
98 Panel.Backlight_Off;
99 Panel.Off;
100 end Pre_All_Off;
101
102 procedure Post_All_Off
103 is
104 begin
Nico Huberac455ad2017-02-14 14:41:19 +0100105 for Port in Digital_Port range DIGI_A .. Config.Last_Digital_Port loop
Nico Huber83693c82016-10-08 22:17:55 +0200106 DDI.Off (Port);
107 end loop;
Nico Huber83693c82016-10-08 22:17:55 +0200108 end Post_All_Off;
109
110end HW.GFX.GMA.Connectors;