2018-05-03 13:47:57 +00:00
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
//
|
|
|
|
|
// SCSI Target Emulator RaSCSI (*^..^*)
|
|
|
|
|
// for Raspberry Pi
|
|
|
|
|
//
|
|
|
|
|
// Powered by XM6 TypeG Technology.
|
2020-07-04 14:57:44 +00:00
|
|
|
|
// Copyright (C) 2016-2020 GIMONS
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// [ GPIO-SCSI bus ]
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
#if !defined(gpiobus_h)
|
|
|
|
|
#define gpiobus_h
|
|
|
|
|
|
|
|
|
|
#include "scsi.h"
|
|
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Connection method definitions
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//
|
|
|
|
|
//---------------------------------------------------------------------------
|
2020-07-06 03:56:25 +00:00
|
|
|
|
//#define CONNECT_TYPE_STANDARD // Standard (SCSI logic, standard pin assignment)
|
|
|
|
|
//#define CONNECT_TYPE_FULLSPEC // Full spec (SCSI logic, standard pin assignment)
|
|
|
|
|
//#define CONNECT_TYPE_AIBOM // AIBOM version (positive logic, unique pin assignment)
|
|
|
|
|
//#define CONNECT_TYPE_GAMERNIUM // GAMERnium.com version (standard logic, unique pin assignment)
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Signal control logic and pin assignment customization
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// SIGNAL_CONTROL_MODE: Signal control mode selection
|
|
|
|
|
// You can customize the signal control logic from Version 1.22
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// 0:SCSI logical specification
|
|
|
|
|
// Conversion board using 74LS641-1 etc. directly connected or published on HP
|
|
|
|
|
// True : 0V
|
|
|
|
|
// False : Open collector output (disconnect from bus)
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// 1:Negative logic specification (when using conversion board for negative logic -> SCSI logic)
|
|
|
|
|
// There is no conversion board with this specification at this time
|
|
|
|
|
// True : 0V -> (CONVERT) -> 0V
|
|
|
|
|
// False : 3.3V -> (CONVERT) -> Open collector output
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// 2:Positive logic specification (when using the conversion board for positive logic -> SCSI logic)
|
|
|
|
|
// RaSCSI Adapter Rev.C @132sync etc.
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// True : 3.3V -> (CONVERT) -> 0V
|
|
|
|
|
// False : 0V -> (CONVERT) -> Open collector output
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Control signal pin assignment setting
|
|
|
|
|
// GPIO pin mapping table for control signals.
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Control signal:
|
2018-05-03 13:47:57 +00:00
|
|
|
|
// PIN_ACT
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Signal that indicates the status of processing SCSI command.
|
2018-05-03 13:47:57 +00:00
|
|
|
|
// PIN_ENB
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Signal that indicates the valid signal from start to finish.
|
2018-05-03 13:47:57 +00:00
|
|
|
|
// PIN_TAD
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Signal that indicates the input/output direction of the target signal (BSY,IO,CD,MSG,REG).
|
2018-05-03 13:47:57 +00:00
|
|
|
|
// PIN_IND
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Signal that indicates the input/output direction of the initiator signal (SEL, ATN, RST, ACK).
|
2018-05-03 13:47:57 +00:00
|
|
|
|
// PIN_DTD
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Signal that indicates the input/output direction of the data lines (DT0...DT7,DP).
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Control signal output logic
|
|
|
|
|
// 0V:FALSE 3.3V:TRUE
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//
|
|
|
|
|
// ACT_ON
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// PIN_ACT signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
// ENB_ON
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// PIN_ENB signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
// TAD_IN
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// PIN_TAD This is the logic when inputting.
|
2018-05-03 13:47:57 +00:00
|
|
|
|
// IND_IN
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// PIN_ENB This is the logic when inputting.
|
2018-05-03 13:47:57 +00:00
|
|
|
|
// DTD_IN
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// PIN_ENB This is the logic when inputting.
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// SCSI signal pin assignment setting
|
|
|
|
|
// GPIO pin mapping table for SCSI signals.
|
2018-05-03 13:47:57 +00:00
|
|
|
|
// PIN_DT0~PIN_SEL
|
|
|
|
|
//
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
#ifdef CONNECT_TYPE_STANDARD
|
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// RaSCSI standard (SCSI logic, standard pin assignment)
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
#define CONNECT_DESC "STANDARD" // Startup message
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Select signal control mode
|
|
|
|
|
#define SIGNAL_CONTROL_MODE 0 // SCSI logical specification
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Control signal pin assignment (-1 means no control)
|
2018-05-03 13:47:57 +00:00
|
|
|
|
#define PIN_ACT 4 // ACTIVE
|
|
|
|
|
#define PIN_ENB 5 // ENABLE
|
|
|
|
|
#define PIN_IND -1 // INITIATOR CTRL DIRECTION
|
|
|
|
|
#define PIN_TAD -1 // TARGET CTRL DIRECTION
|
|
|
|
|
#define PIN_DTD -1 // DATA DIRECTION
|
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Control signal output logic
|
2018-05-03 13:47:57 +00:00
|
|
|
|
#define ACT_ON TRUE // ACTIVE SIGNAL ON
|
|
|
|
|
#define ENB_ON TRUE // ENABLE SIGNAL ON
|
|
|
|
|
#define IND_IN FALSE // INITIATOR SIGNAL INPUT
|
|
|
|
|
#define TAD_IN FALSE // TARGET SIGNAL INPUT
|
|
|
|
|
#define DTD_IN TRUE // DATA SIGNAL INPUT
|
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// SCSI signal pin assignment
|
|
|
|
|
#define PIN_DT0 10 // Data 0
|
|
|
|
|
#define PIN_DT1 11 // Data 1
|
|
|
|
|
#define PIN_DT2 12 // Data 2
|
|
|
|
|
#define PIN_DT3 13 // Data 3
|
|
|
|
|
#define PIN_DT4 14 // Data 4
|
|
|
|
|
#define PIN_DT5 15 // Data 5
|
|
|
|
|
#define PIN_DT6 16 // Data 6
|
|
|
|
|
#define PIN_DT7 17 // Data 7
|
|
|
|
|
#define PIN_DP 18 // Data parity
|
2018-05-03 13:47:57 +00:00
|
|
|
|
#define PIN_ATN 19 // ATN
|
|
|
|
|
#define PIN_RST 20 // RST
|
|
|
|
|
#define PIN_ACK 21 // ACK
|
|
|
|
|
#define PIN_REQ 22 // REQ
|
|
|
|
|
#define PIN_MSG 23 // MSG
|
|
|
|
|
#define PIN_CD 24 // CD
|
|
|
|
|
#define PIN_IO 25 // IO
|
|
|
|
|
#define PIN_BSY 26 // BSY
|
|
|
|
|
#define PIN_SEL 27 // SEL
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifdef CONNECT_TYPE_FULLSPEC
|
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// RaSCSI standard (SCSI logic, standard pin assignment)
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
#define CONNECT_DESC "FULLSPEC" // Startup message
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Select signal control mode
|
|
|
|
|
#define SIGNAL_CONTROL_MODE 0 // SCSI logical specification
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Control signal pin assignment (-1 means no control)
|
2018-05-03 13:47:57 +00:00
|
|
|
|
#define PIN_ACT 4 // ACTIVE
|
|
|
|
|
#define PIN_ENB 5 // ENABLE
|
|
|
|
|
#define PIN_IND 6 // INITIATOR CTRL DIRECTION
|
|
|
|
|
#define PIN_TAD 7 // TARGET CTRL DIRECTION
|
|
|
|
|
#define PIN_DTD 8 // DATA DIRECTION
|
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Control signal output logic
|
2018-05-03 13:47:57 +00:00
|
|
|
|
#define ACT_ON TRUE // ACTIVE SIGNAL ON
|
|
|
|
|
#define ENB_ON TRUE // ENABLE SIGNAL ON
|
|
|
|
|
#define IND_IN FALSE // INITIATOR SIGNAL INPUT
|
|
|
|
|
#define TAD_IN FALSE // TARGET SIGNAL INPUT
|
|
|
|
|
#define DTD_IN TRUE // DATA SIGNAL INPUT
|
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// SCSI signal pin assignment
|
|
|
|
|
#define PIN_DT0 10 // Data 0
|
|
|
|
|
#define PIN_DT1 11 // Data 1
|
|
|
|
|
#define PIN_DT2 12 // Data 2
|
|
|
|
|
#define PIN_DT3 13 // Data 3
|
|
|
|
|
#define PIN_DT4 14 // Data 4
|
|
|
|
|
#define PIN_DT5 15 // Data 5
|
|
|
|
|
#define PIN_DT6 16 // Data 6
|
|
|
|
|
#define PIN_DT7 17 // Data 7
|
|
|
|
|
#define PIN_DP 18 // Data parity
|
2018-05-03 13:47:57 +00:00
|
|
|
|
#define PIN_ATN 19 // ATN
|
|
|
|
|
#define PIN_RST 20 // RST
|
|
|
|
|
#define PIN_ACK 21 // ACK
|
|
|
|
|
#define PIN_REQ 22 // REQ
|
|
|
|
|
#define PIN_MSG 23 // MSG
|
|
|
|
|
#define PIN_CD 24 // CD
|
|
|
|
|
#define PIN_IO 25 // IO
|
|
|
|
|
#define PIN_BSY 26 // BSY
|
|
|
|
|
#define PIN_SEL 27 // SEL
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifdef CONNECT_TYPE_AIBOM
|
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// RaSCSI Adapter Aibomu version
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//
|
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
#define CONNECT_DESC "AIBOM PRODUCTS version" // Startup message
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Select signal control mode
|
|
|
|
|
#define SIGNAL_CONTROL_MODE 2 // SCSI positive logic specification
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Control signal output logic
|
2018-05-03 13:47:57 +00:00
|
|
|
|
#define ACT_ON TRUE // ACTIVE SIGNAL ON
|
|
|
|
|
#define ENB_ON TRUE // ENABLE SIGNAL ON
|
|
|
|
|
#define IND_IN FALSE // INITIATOR SIGNAL INPUT
|
|
|
|
|
#define TAD_IN FALSE // TARGET SIGNAL INPUT
|
|
|
|
|
#define DTD_IN FALSE // DATA SIGNAL INPUT
|
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Control signal pin assignment (-1 means no control)
|
2018-05-03 13:47:57 +00:00
|
|
|
|
#define PIN_ACT 4 // ACTIVE
|
|
|
|
|
#define PIN_ENB 17 // ENABLE
|
|
|
|
|
#define PIN_IND 27 // INITIATOR CTRL DIRECTION
|
|
|
|
|
#define PIN_TAD -1 // TARGET CTRL DIRECTION
|
|
|
|
|
#define PIN_DTD 18 // DATA DIRECTION
|
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// SCSI signal pin assignment
|
|
|
|
|
#define PIN_DT0 6 // Data 0
|
|
|
|
|
#define PIN_DT1 12 // Data 1
|
|
|
|
|
#define PIN_DT2 13 // Data 2
|
|
|
|
|
#define PIN_DT3 16 // Data 3
|
|
|
|
|
#define PIN_DT4 19 // Data 4
|
|
|
|
|
#define PIN_DT5 20 // Data 5
|
|
|
|
|
#define PIN_DT6 26 // Data 6
|
|
|
|
|
#define PIN_DT7 21 // Data 7
|
|
|
|
|
#define PIN_DP 5 // Data parity
|
2018-05-03 13:47:57 +00:00
|
|
|
|
#define PIN_ATN 22 // ATN
|
|
|
|
|
#define PIN_RST 25 // RST
|
|
|
|
|
#define PIN_ACK 10 // ACK
|
|
|
|
|
#define PIN_REQ 7 // REQ
|
|
|
|
|
#define PIN_MSG 9 // MSG
|
|
|
|
|
#define PIN_CD 11 // CD
|
|
|
|
|
#define PIN_IO 23 // IO
|
|
|
|
|
#define PIN_BSY 24 // BSY
|
|
|
|
|
#define PIN_SEL 8 // SEL
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifdef CONNECT_TYPE_GAMERNIUM
|
|
|
|
|
//
|
|
|
|
|
// RaSCSI Adapter GAMERnium.com版
|
|
|
|
|
//
|
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
#define CONNECT_DESC "GAMERnium.com version"// Startup message
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Select signal control mode
|
|
|
|
|
#define SIGNAL_CONTROL_MODE 0 // SCSI logical specification
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Control signal output logic
|
2018-05-03 13:47:57 +00:00
|
|
|
|
#define ACT_ON TRUE // ACTIVE SIGNAL ON
|
|
|
|
|
#define ENB_ON TRUE // ENABLE SIGNAL ON
|
|
|
|
|
#define IND_IN FALSE // INITIATOR SIGNAL INPUT
|
|
|
|
|
#define TAD_IN FALSE // TARGET SIGNAL INPUT
|
|
|
|
|
#define DTD_IN TRUE // DATA SIGNAL INPUT
|
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Control signal pin assignment (-1 means no control)
|
2018-05-03 13:47:57 +00:00
|
|
|
|
#define PIN_ACT 14 // ACTIVE
|
|
|
|
|
#define PIN_ENB 6 // ENABLE
|
|
|
|
|
#define PIN_IND 7 // INITIATOR CTRL DIRECTION
|
|
|
|
|
#define PIN_TAD 8 // TARGET CTRL DIRECTION
|
|
|
|
|
#define PIN_DTD 5 // DATA DIRECTION
|
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// SCSI signal pin assignment
|
|
|
|
|
#define PIN_DT0 21 // Data 0
|
|
|
|
|
#define PIN_DT1 26 // Data 1
|
|
|
|
|
#define PIN_DT2 20 // Data 2
|
|
|
|
|
#define PIN_DT3 19 // Data 3
|
|
|
|
|
#define PIN_DT4 16 // Data 4
|
|
|
|
|
#define PIN_DT5 13 // Data 5
|
|
|
|
|
#define PIN_DT6 12 // Data 6
|
|
|
|
|
#define PIN_DT7 11 // Data 7
|
|
|
|
|
#define PIN_DP 25 // Data parity
|
2018-05-03 13:47:57 +00:00
|
|
|
|
#define PIN_ATN 10 // ATN
|
|
|
|
|
#define PIN_RST 22 // RST
|
|
|
|
|
#define PIN_ACK 24 // ACK
|
|
|
|
|
#define PIN_REQ 15 // REQ
|
|
|
|
|
#define PIN_MSG 17 // MSG
|
|
|
|
|
#define PIN_CD 18 // CD
|
|
|
|
|
#define PIN_IO 4 // IO
|
|
|
|
|
#define PIN_BSY 27 // BSY
|
|
|
|
|
#define PIN_SEL 23 // SEL
|
|
|
|
|
#endif
|
|
|
|
|
|
2020-10-19 12:31:06 +00:00
|
|
|
|
#define ALL_SCSI_PINS \
|
|
|
|
|
((1<<PIN_DT0)|\
|
|
|
|
|
(1<<PIN_DT1)|\
|
|
|
|
|
(1<<PIN_DT2)|\
|
|
|
|
|
(1<<PIN_DT3)|\
|
|
|
|
|
(1<<PIN_DT4)|\
|
|
|
|
|
(1<<PIN_DT5)|\
|
|
|
|
|
(1<<PIN_DT6)|\
|
|
|
|
|
(1<<PIN_DT7)|\
|
|
|
|
|
(1<<PIN_DP)|\
|
|
|
|
|
(1<<PIN_ATN)|\
|
|
|
|
|
(1<<PIN_RST)|\
|
|
|
|
|
(1<<PIN_ACK)|\
|
|
|
|
|
(1<<PIN_REQ)|\
|
|
|
|
|
(1<<PIN_MSG)|\
|
|
|
|
|
(1<<PIN_CD)|\
|
|
|
|
|
(1<<PIN_IO)|\
|
|
|
|
|
(1<<PIN_BSY)|\
|
|
|
|
|
(1<<PIN_SEL))
|
|
|
|
|
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Constant declarations(GPIO)
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//
|
|
|
|
|
//---------------------------------------------------------------------------
|
2020-07-04 14:57:44 +00:00
|
|
|
|
#define SYST_OFFSET 0x00003000
|
|
|
|
|
#define IRPT_OFFSET 0x0000B200
|
|
|
|
|
#define ARMT_OFFSET 0x0000B400
|
|
|
|
|
#define PADS_OFFSET 0x00100000
|
|
|
|
|
#define GPIO_OFFSET 0x00200000
|
|
|
|
|
#define QA7_OFFSET 0x01000000
|
2018-05-03 13:47:57 +00:00
|
|
|
|
#define GPIO_INPUT 0
|
|
|
|
|
#define GPIO_OUTPUT 1
|
|
|
|
|
#define GPIO_PULLNONE 0
|
|
|
|
|
#define GPIO_PULLDOWN 1
|
|
|
|
|
#define GPIO_PULLUP 2
|
|
|
|
|
#define GPIO_FSEL_0 0
|
|
|
|
|
#define GPIO_FSEL_1 1
|
|
|
|
|
#define GPIO_FSEL_2 2
|
|
|
|
|
#define GPIO_FSEL_3 3
|
|
|
|
|
#define GPIO_SET_0 7
|
|
|
|
|
#define GPIO_CLR_0 10
|
|
|
|
|
#define GPIO_LEV_0 13
|
|
|
|
|
#define GPIO_EDS_0 16
|
|
|
|
|
#define GPIO_REN_0 19
|
|
|
|
|
#define GPIO_FEN_0 22
|
|
|
|
|
#define GPIO_HEN_0 25
|
|
|
|
|
#define GPIO_LEN_0 28
|
|
|
|
|
#define GPIO_AREN_0 31
|
|
|
|
|
#define GPIO_AFEN_0 34
|
|
|
|
|
#define GPIO_PUD 37
|
|
|
|
|
#define GPIO_CLK_0 38
|
2020-07-04 14:57:44 +00:00
|
|
|
|
#define GPIO_GPPINMUXSD 52
|
|
|
|
|
#define GPIO_PUPPDN0 57
|
|
|
|
|
#define GPIO_PUPPDN1 58
|
|
|
|
|
#define GPIO_PUPPDN3 59
|
|
|
|
|
#define GPIO_PUPPDN4 60
|
2018-05-03 13:47:57 +00:00
|
|
|
|
#define PAD_0_27 11
|
2020-07-04 14:57:44 +00:00
|
|
|
|
#define SYST_CS 0
|
|
|
|
|
#define SYST_CLO 1
|
|
|
|
|
#define SYST_CHI 2
|
|
|
|
|
#define SYST_C0 3
|
|
|
|
|
#define SYST_C1 4
|
|
|
|
|
#define SYST_C2 5
|
|
|
|
|
#define SYST_C3 6
|
|
|
|
|
#define ARMT_LOAD 0
|
|
|
|
|
#define ARMT_VALUE 1
|
|
|
|
|
#define ARMT_CTRL 2
|
|
|
|
|
#define ARMT_CLRIRQ 3
|
|
|
|
|
#define ARMT_RAWIRQ 4
|
|
|
|
|
#define ARMT_MSKIRQ 5
|
|
|
|
|
#define ARMT_RELOAD 6
|
|
|
|
|
#define ARMT_PREDIV 7
|
|
|
|
|
#define ARMT_FREERUN 8
|
|
|
|
|
#define IRPT_PND_IRQ_B 0
|
|
|
|
|
#define IRPT_PND_IRQ_1 1
|
|
|
|
|
#define IRPT_PND_IRQ_2 2
|
|
|
|
|
#define IRPT_FIQ_CNTL 3
|
|
|
|
|
#define IRPT_ENB_IRQ_1 4
|
|
|
|
|
#define IRPT_ENB_IRQ_2 5
|
|
|
|
|
#define IRPT_ENB_IRQ_B 6
|
|
|
|
|
#define IRPT_DIS_IRQ_1 7
|
|
|
|
|
#define IRPT_DIS_IRQ_2 8
|
|
|
|
|
#define IRPT_DIS_IRQ_B 9
|
|
|
|
|
#define QA7_CORE0_TINTC 16
|
|
|
|
|
#define GPIO_IRQ (32 + 20) // GPIO3
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
|
|
|
|
#define GPIO_INEDGE ((1 << PIN_BSY) | \
|
|
|
|
|
(1 << PIN_SEL) | \
|
|
|
|
|
(1 << PIN_ATN) | \
|
|
|
|
|
(1 << PIN_ACK) | \
|
|
|
|
|
(1 << PIN_RST))
|
|
|
|
|
|
|
|
|
|
#define GPIO_MCI ((1 << PIN_MSG) | \
|
|
|
|
|
(1 << PIN_CD) | \
|
|
|
|
|
(1 << PIN_IO))
|
|
|
|
|
|
2020-07-04 14:57:44 +00:00
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Constant declarations(GIC)
|
2020-07-04 14:57:44 +00:00
|
|
|
|
//
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
#define ARM_GICD_BASE 0xFF841000
|
|
|
|
|
#define ARM_GICC_BASE 0xFF842000
|
|
|
|
|
#define ARM_GIC_END 0xFF847FFF
|
|
|
|
|
#define GICD_CTLR 0x000
|
|
|
|
|
#define GICD_IGROUPR0 0x020
|
|
|
|
|
#define GICD_ISENABLER0 0x040
|
|
|
|
|
#define GICD_ICENABLER0 0x060
|
|
|
|
|
#define GICD_ISPENDR0 0x080
|
|
|
|
|
#define GICD_ICPENDR0 0x0A0
|
|
|
|
|
#define GICD_ISACTIVER0 0x0C0
|
|
|
|
|
#define GICD_ICACTIVER0 0x0E0
|
|
|
|
|
#define GICD_IPRIORITYR0 0x100
|
|
|
|
|
#define GICD_ITARGETSR0 0x200
|
|
|
|
|
#define GICD_ICFGR0 0x300
|
|
|
|
|
#define GICD_SGIR 0x3C0
|
|
|
|
|
#define GICC_CTLR 0x000
|
|
|
|
|
#define GICC_PMR 0x001
|
|
|
|
|
#define GICC_IAR 0x003
|
|
|
|
|
#define GICC_EOIR 0x004
|
|
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Constant declarations(GIC IRQ)
|
2020-07-04 14:57:44 +00:00
|
|
|
|
//
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
#define GIC_IRQLOCAL0 (16 + 14)
|
|
|
|
|
#define GIC_GPIO_IRQ (32 + 116) // GPIO3
|
|
|
|
|
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Constant declarations (Control signals)
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
#define ACT_OFF !ACT_ON
|
|
|
|
|
#define ENB_OFF !ENB_ON
|
|
|
|
|
#define TAD_OUT !TAD_IN
|
|
|
|
|
#define IND_OUT !IND_IN
|
|
|
|
|
#define DTD_OUT !DTD_IN
|
|
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Constant declarations(SCSI)
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
#define IN GPIO_INPUT
|
|
|
|
|
#define OUT GPIO_OUTPUT
|
|
|
|
|
#define ON TRUE
|
|
|
|
|
#define OFF FALSE
|
|
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Constant declarations (bus control timing)
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//
|
|
|
|
|
//---------------------------------------------------------------------------
|
2020-07-06 03:56:25 +00:00
|
|
|
|
#define GPIO_DATA_SETTLING 100 // Data bus stabilization time (ns)
|
2021-01-27 21:16:52 +00:00
|
|
|
|
// SCSI Bus timings taken from:
|
|
|
|
|
// https://www.staff.uni-mainz.de/tacke/scsi/SCSI2-05.html
|
|
|
|
|
#define SCSI_DELAY_ARBITRATION_DELAY_NS 2400
|
|
|
|
|
#define SCSI_DELAY_ASSERTION_PERIOD_NS 90
|
|
|
|
|
#define SCSI_DELAY_BUS_CLEAR_DELAY_NS 800
|
|
|
|
|
#define SCSI_DELAY_BUS_FREE_DELAY_NS 800
|
|
|
|
|
#define SCSI_DELAY_BUS_SET_DELAY_NS 1800
|
|
|
|
|
#define SCSI_DELAY_BUS_SETTLE_DELAY_NS 400
|
|
|
|
|
#define SCSI_DELAY_CABLE_SKEW_DELAY_NS 10
|
|
|
|
|
#define SCSI_DELAY_DATA_RELEASE_DELAY_NS 400
|
|
|
|
|
#define SCSI_DELAY_DESKEW_DELAY_NS 45
|
|
|
|
|
#define SCSI_DELAY_DISCONNECTION_DELAY_US 200
|
|
|
|
|
#define SCSI_DELAY_HOLD_TIME_NS 45
|
|
|
|
|
#define SCSI_DELAY_NEGATION_PERIOD_NS 90
|
|
|
|
|
#define SCSI_DELAY_POWER_ON_TO_SELECTION_TIME_S 10 // (recommended)
|
|
|
|
|
#define SCSI_DELAY_RESET_TO_SELECTION_TIME_US (250*1000) // (recommended)
|
|
|
|
|
#define SCSI_DELAY_RESET_HOLD_TIME_US 25
|
|
|
|
|
#define SCSI_DELAY_SELECTION_ABORT_TIME_US 200
|
|
|
|
|
#define SCSI_DELAY_SELECTION_TIMEOUT_DELAY_NS (250*1000) // (recommended)
|
|
|
|
|
#define SCSI_DELAY_FAST_ASSERTION_PERIOD_NS 30
|
|
|
|
|
#define SCSI_DELAY_FAST_CABLE_SKEW_DELAY_NS 5
|
|
|
|
|
#define SCSI_DELAY_FAST_DESKEW_DELAY_NS 20
|
|
|
|
|
#define SCSI_DELAY_FAST_HOLD_TIME_NS 10
|
|
|
|
|
#define SCSI_DELAY_FAST_NEGATION_PERIOD_NS 30
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Class definition
|
2018-05-03 13:47:57 +00:00
|
|
|
|
//
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
class GPIOBUS : public BUS
|
|
|
|
|
{
|
|
|
|
|
public:
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Basic Functions
|
2018-05-03 13:47:57 +00:00
|
|
|
|
GPIOBUS();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Constructor
|
2018-05-03 13:47:57 +00:00
|
|
|
|
virtual ~GPIOBUS();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Destructor
|
2018-05-03 13:47:57 +00:00
|
|
|
|
BOOL FASTCALL Init(mode_e mode = TARGET);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Initialization
|
2018-05-03 13:47:57 +00:00
|
|
|
|
void FASTCALL Reset();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Reset
|
2018-05-03 13:47:57 +00:00
|
|
|
|
void FASTCALL Cleanup();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Cleanup
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-10-19 12:31:06 +00:00
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
//
|
|
|
|
|
// Bus signal acquisition
|
|
|
|
|
//
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
|
inline DWORD Aquire()
|
|
|
|
|
{
|
|
|
|
|
#if defined(__x86_64__) || defined(__X86__)
|
|
|
|
|
// Only used for development/debugging purposes. Isn't really applicable
|
|
|
|
|
// to any real-world RaSCSI application
|
|
|
|
|
return 0;
|
|
|
|
|
#else
|
|
|
|
|
signals = *level;
|
|
|
|
|
|
|
|
|
|
#if SIGNAL_CONTROL_MODE < 2
|
|
|
|
|
// Invert if negative logic (internal processing is unified to positive logic)
|
|
|
|
|
signals = ~signals;
|
|
|
|
|
#endif // SIGNAL_CONTROL_MODE
|
|
|
|
|
|
|
|
|
|
return signals;
|
|
|
|
|
#endif // ifdef __x86_64__ || __X86__
|
|
|
|
|
}
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-07-04 14:57:44 +00:00
|
|
|
|
void FASTCALL SetENB(BOOL ast);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Set ENB signal
|
2020-07-04 14:57:44 +00:00
|
|
|
|
|
2018-05-03 13:47:57 +00:00
|
|
|
|
BOOL FASTCALL GetBSY();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Get BSY signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
void FASTCALL SetBSY(BOOL ast);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Set BSY signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
|
|
|
|
BOOL FASTCALL GetSEL();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Get SEL signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
void FASTCALL SetSEL(BOOL ast);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Set SEL signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
|
|
|
|
BOOL FASTCALL GetATN();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Get ATN signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
void FASTCALL SetATN(BOOL ast);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Set ATN signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
|
|
|
|
BOOL FASTCALL GetACK();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Get ACK signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
void FASTCALL SetACK(BOOL ast);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Set ACK signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-10-19 12:31:06 +00:00
|
|
|
|
BOOL FASTCALL GetACT();
|
|
|
|
|
// Get ACT signal
|
|
|
|
|
void FASTCALL SetACT(BOOL ast);
|
|
|
|
|
// Set ACT signal
|
|
|
|
|
|
2018-05-03 13:47:57 +00:00
|
|
|
|
BOOL FASTCALL GetRST();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Get RST signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
void FASTCALL SetRST(BOOL ast);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Set RST signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
|
|
|
|
BOOL FASTCALL GetMSG();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Get MSG signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
void FASTCALL SetMSG(BOOL ast);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Set MSG signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
|
|
|
|
BOOL FASTCALL GetCD();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Get CD signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
void FASTCALL SetCD(BOOL ast);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Set CD signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
|
|
|
|
BOOL FASTCALL GetIO();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Get IO signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
void FASTCALL SetIO(BOOL ast);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Set IO signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
|
|
|
|
BOOL FASTCALL GetREQ();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Get REQ signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
void FASTCALL SetREQ(BOOL ast);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Set REQ signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
|
|
|
|
BYTE FASTCALL GetDAT();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Get DAT signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
void FASTCALL SetDAT(BYTE dat);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Set DAT signal
|
2020-07-04 14:57:44 +00:00
|
|
|
|
BOOL FASTCALL GetDP();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Get Data parity signal
|
2020-07-04 14:57:44 +00:00
|
|
|
|
int FASTCALL CommandHandShake(BYTE *buf);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Command receive handshake
|
2018-05-03 13:47:57 +00:00
|
|
|
|
int FASTCALL ReceiveHandShake(BYTE *buf, int count);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Data receive handshake
|
2018-05-03 13:47:57 +00:00
|
|
|
|
int FASTCALL SendHandShake(BYTE *buf, int count);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Data transmission handshake
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-10-19 12:31:06 +00:00
|
|
|
|
static BUS::phase_t FASTCALL GetPhaseRaw(DWORD raw_data);
|
2021-01-27 21:16:52 +00:00
|
|
|
|
// Get the phase based on raw data
|
2020-10-19 12:31:06 +00:00
|
|
|
|
|
2020-07-04 14:57:44 +00:00
|
|
|
|
#ifdef USE_SEL_EVENT_ENABLE
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// SEL signal interrupt
|
2020-07-04 14:57:44 +00:00
|
|
|
|
int FASTCALL PollSelectEvent();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// SEL signal event polling
|
2020-07-04 14:57:44 +00:00
|
|
|
|
void FASTCALL ClearSelectEvent();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Clear SEL signal event
|
2020-07-04 14:57:44 +00:00
|
|
|
|
#endif // USE_SEL_EVENT_ENABLE
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
|
|
|
|
private:
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// SCSI I/O signal control
|
2018-05-03 13:47:57 +00:00
|
|
|
|
void FASTCALL MakeTable();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Create work data
|
2018-05-03 13:47:57 +00:00
|
|
|
|
void FASTCALL SetControl(int pin, BOOL ast);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Set Control Signal
|
2018-05-03 13:47:57 +00:00
|
|
|
|
void FASTCALL SetMode(int pin, int mode);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Set SCSI I/O mode
|
2018-05-03 13:47:57 +00:00
|
|
|
|
BOOL FASTCALL GetSignal(int pin);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Get SCSI input signal value
|
2018-05-03 13:47:57 +00:00
|
|
|
|
void FASTCALL SetSignal(int pin, BOOL ast);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Set SCSI output signal value
|
2020-07-04 14:57:44 +00:00
|
|
|
|
BOOL FASTCALL WaitSignal(int pin, BOOL ast);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Wait for a signal to change
|
|
|
|
|
// Interrupt control
|
2020-07-04 14:57:44 +00:00
|
|
|
|
void FASTCALL DisableIRQ();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// IRQ Disabled
|
2020-07-04 14:57:44 +00:00
|
|
|
|
void FASTCALL EnableIRQ();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// IRQ Enabled
|
2020-07-04 14:57:44 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// GPIO pin functionality settings
|
2020-07-04 14:57:44 +00:00
|
|
|
|
void FASTCALL PinConfig(int pin, int mode);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// GPIO pin direction setting
|
2020-07-04 14:57:44 +00:00
|
|
|
|
void FASTCALL PullConfig(int pin, int mode);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// GPIO pin pull up/down resistor setting
|
2020-07-04 14:57:44 +00:00
|
|
|
|
void FASTCALL PinSetSignal(int pin, BOOL ast);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Set GPIO output signal
|
2020-07-04 14:57:44 +00:00
|
|
|
|
void FASTCALL DrvConfig(DWORD drive);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Set GPIO drive strength
|
2020-07-04 14:57:44 +00:00
|
|
|
|
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
mode_e actmode; // Operation mode
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
DWORD baseaddr; // Base address
|
2020-07-04 14:57:44 +00:00
|
|
|
|
|
|
|
|
|
int rpitype;
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Type of Raspberry Pi
|
2020-07-04 14:57:44 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
volatile DWORD *gpio; // GPIO register
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
volatile DWORD *pads; // PADS register
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
volatile DWORD *level; // GPIO input level
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
volatile DWORD *irpctl; // Interrupt control register
|
2020-07-04 14:57:44 +00:00
|
|
|
|
|
|
|
|
|
#ifndef BAREMETAL
|
2020-07-06 03:56:25 +00:00
|
|
|
|
volatile DWORD irptenb; // Interrupt enabled state
|
2020-07-04 14:57:44 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
volatile DWORD *qa7regs; // QA7 register
|
2020-07-04 14:57:44 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
volatile int tintcore; // Interupt control target CPU.
|
2020-07-04 14:57:44 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
volatile DWORD tintctl; // Interupt control
|
2020-07-04 14:57:44 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
volatile DWORD giccpmr; // GICC priority setting
|
2020-07-04 14:57:44 +00:00
|
|
|
|
#endif // BAREMETAL
|
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
volatile DWORD *gicd; // GIC Interrupt distributor register
|
2020-07-04 14:57:44 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
volatile DWORD *gicc; // GIC CPU interface register
|
2020-07-04 14:57:44 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
DWORD gpfsel[4]; // GPFSEL0-4 backup values
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
DWORD signals; // All bus signals
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-07-04 14:57:44 +00:00
|
|
|
|
#if defined(USE_SEL_EVENT_ENABLE) && !defined(BAREMETAL)
|
2020-07-06 03:56:25 +00:00
|
|
|
|
struct gpioevent_request selevreq; // SEL signal event request
|
2020-07-04 14:57:44 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
int epfd; // epoll file descriptor
|
2020-07-04 14:57:44 +00:00
|
|
|
|
#endif // USE_SEL_EVENT_ENABLE && !BAREMETAL
|
|
|
|
|
|
2018-05-03 13:47:57 +00:00
|
|
|
|
#if SIGNAL_CONTROL_MODE == 0
|
2020-07-06 03:56:25 +00:00
|
|
|
|
DWORD tblDatMsk[3][256]; // Data mask table
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
DWORD tblDatSet[3][256]; // Data setting table
|
2018-05-03 13:47:57 +00:00
|
|
|
|
#else
|
2020-07-06 03:56:25 +00:00
|
|
|
|
DWORD tblDatMsk[256]; // Data mask table
|
2018-05-03 13:47:57 +00:00
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
DWORD tblDatSet[256]; // Table setting table
|
2018-05-03 13:47:57 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
2020-07-06 03:56:25 +00:00
|
|
|
|
static const int SignalTable[19]; // signal table
|
2018-05-03 13:47:57 +00:00
|
|
|
|
};
|
|
|
|
|
|
2020-07-04 14:57:44 +00:00
|
|
|
|
//===========================================================================
|
|
|
|
|
//
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// System timer
|
2020-07-04 14:57:44 +00:00
|
|
|
|
//
|
|
|
|
|
//===========================================================================
|
|
|
|
|
class SysTimer
|
|
|
|
|
{
|
|
|
|
|
public:
|
|
|
|
|
static void FASTCALL Init(DWORD *syst, DWORD *armt);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Initialization
|
2020-07-04 14:57:44 +00:00
|
|
|
|
static DWORD FASTCALL GetTimerLow();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Get system timer low byte
|
2020-07-04 14:57:44 +00:00
|
|
|
|
static DWORD FASTCALL GetTimerHigh();
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Get system timer high byte
|
2020-07-04 14:57:44 +00:00
|
|
|
|
static void FASTCALL SleepNsec(DWORD nsec);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Sleep for N nanoseconds
|
2020-07-04 14:57:44 +00:00
|
|
|
|
static void FASTCALL SleepUsec(DWORD usec);
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Sleep for N microseconds
|
2020-07-04 14:57:44 +00:00
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
static volatile DWORD *systaddr;
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// System timer address
|
2020-07-04 14:57:44 +00:00
|
|
|
|
static volatile DWORD *armtaddr;
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// ARM timer address
|
2020-07-04 14:57:44 +00:00
|
|
|
|
static volatile DWORD corefreq;
|
2020-07-06 03:56:25 +00:00
|
|
|
|
// Core frequency
|
2020-07-04 14:57:44 +00:00
|
|
|
|
};
|
|
|
|
|
|
2018-05-03 13:47:57 +00:00
|
|
|
|
#endif // gpiobus_h
|