2020-05-09 13:22:30 +02:00
|
|
|
-- SPDX-License-Identifier: GPL-2.0-only
|
2016-10-05 17:46:49 +02:00
|
|
|
|
|
|
|
with Interfaces.C;
|
2021-07-27 15:46:55 +02:00
|
|
|
with CB.Config;
|
2016-10-05 17:46:49 +02:00
|
|
|
|
2021-07-27 15:46:55 +02:00
|
|
|
use CB;
|
2016-10-05 17:46:49 +02:00
|
|
|
use type Interfaces.C.int;
|
|
|
|
|
|
|
|
package body HW.Debug_Sink is
|
|
|
|
|
2018-06-04 15:10:54 +02:00
|
|
|
function console_log_level
|
|
|
|
(msg_level : Interfaces.C.int)
|
|
|
|
return Interfaces.C.int;
|
|
|
|
pragma Import (C, console_log_level, "console_log_level");
|
|
|
|
|
|
|
|
Msg_Level_BIOS_DEBUG : constant := 7;
|
2016-10-05 17:46:49 +02:00
|
|
|
|
2021-07-27 15:46:55 +02:00
|
|
|
CONSOLE_LOG_FAST : constant := 1;
|
|
|
|
CONSOLE_LOG_ALL : constant := 2;
|
|
|
|
|
|
|
|
procedure cbmemc_tx_byte (chr : Interfaces.C.char);
|
|
|
|
pragma Import (C, cbmemc_tx_byte, "cbmemc_tx_byte");
|
|
|
|
|
2016-10-05 17:46:49 +02:00
|
|
|
procedure console_tx_byte (chr : Interfaces.C.char);
|
|
|
|
pragma Import (C, console_tx_byte, "console_tx_byte");
|
|
|
|
|
2021-07-27 15:46:55 +02:00
|
|
|
procedure Put (Item : String)
|
|
|
|
is
|
|
|
|
console_log : constant Interfaces.C.int :=
|
|
|
|
console_log_level (Msg_Level_BIOS_DEBUG);
|
2016-10-05 17:46:49 +02:00
|
|
|
begin
|
2021-07-27 15:46:55 +02:00
|
|
|
if console_log = CONSOLE_LOG_FAST then
|
|
|
|
if Config.CONSOLE_CBMEM then
|
|
|
|
for Idx in Item'Range loop
|
|
|
|
cbmemc_tx_byte (Interfaces.C.To_C (Item (Idx)));
|
|
|
|
end loop;
|
|
|
|
end if;
|
|
|
|
elsif console_log = CONSOLE_LOG_ALL then
|
2016-10-05 17:46:49 +02:00
|
|
|
for Idx in Item'Range loop
|
|
|
|
console_tx_byte (Interfaces.C.To_C (Item (Idx)));
|
|
|
|
end loop;
|
|
|
|
end if;
|
|
|
|
end Put;
|
|
|
|
|
2021-07-27 15:46:55 +02:00
|
|
|
procedure Put_Char (Item : Character)
|
|
|
|
is
|
|
|
|
console_log : constant Interfaces.C.int :=
|
|
|
|
console_log_level (Msg_Level_BIOS_DEBUG);
|
2016-10-05 17:46:49 +02:00
|
|
|
begin
|
2021-07-27 15:46:55 +02:00
|
|
|
if console_log = CONSOLE_LOG_FAST then
|
|
|
|
if Config.CONSOLE_CBMEM then
|
|
|
|
cbmemc_tx_byte (Interfaces.C.To_C (Item));
|
|
|
|
end if;
|
|
|
|
elsif console_log = CONSOLE_LOG_ALL then
|
2016-10-05 17:46:49 +02:00
|
|
|
console_tx_byte (Interfaces.C.To_C (Item));
|
|
|
|
end if;
|
|
|
|
end Put_Char;
|
|
|
|
|
|
|
|
procedure New_Line is
|
|
|
|
begin
|
|
|
|
Put_Char (Character'Val (16#0a#));
|
|
|
|
end New_Line;
|
|
|
|
|
|
|
|
end HW.Debug_Sink;
|