2017-02-01 05:33:31 +01:00
|
|
|
/*
|
2017-12-27 18:49:58 +01:00
|
|
|
* Copyright (C) 2015,2016 by Jonathan Naylor G4KLX
|
2018-02-13 17:30:06 +01:00
|
|
|
* Copyright (C) 2016,2017,2018 by Andy Uribe CA6JAU
|
2017-07-23 00:12:13 +02:00
|
|
|
* Copyright (C) 2017 by Danilo DB4PLE
|
|
|
|
|
|
2017-02-01 05:33:31 +01:00
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
|
|
|
* (at your option) any later version.
|
|
|
|
|
*
|
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
|
*
|
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
|
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#if !defined(CIO_H)
|
|
|
|
|
#define CIO_H
|
|
|
|
|
|
2017-05-01 06:02:47 +02:00
|
|
|
#include "Config.h"
|
2017-02-01 05:33:31 +01:00
|
|
|
#include "Globals.h"
|
|
|
|
|
#include "BitRB.h"
|
|
|
|
|
|
|
|
|
|
#define LOW 0
|
|
|
|
|
#define HIGH 1
|
|
|
|
|
|
2017-02-10 21:58:51 +01:00
|
|
|
#define VHF1_MIN 144000000
|
|
|
|
|
#define VHF1_MAX 148000000
|
|
|
|
|
#define VHF2_MIN 219000000
|
|
|
|
|
#define VHF2_MAX 225000000
|
|
|
|
|
#define UHF1_MIN 420000000
|
2017-02-17 04:05:14 +01:00
|
|
|
#define UHF1_MAX 475000000
|
|
|
|
|
#define UHF2_MIN 842000000
|
|
|
|
|
#define UHF2_MAX 950000000
|
2017-02-01 05:33:31 +01:00
|
|
|
|
2017-03-29 01:14:24 +02:00
|
|
|
#define SCAN_TIME 1920
|
|
|
|
|
#define SCAN_PAUSE 20000
|
2017-03-25 16:52:37 +01:00
|
|
|
|
2017-02-01 05:33:31 +01:00
|
|
|
extern uint32_t m_frequency_rx;
|
|
|
|
|
extern uint32_t m_frequency_tx;
|
|
|
|
|
extern uint8_t m_power;
|
|
|
|
|
|
|
|
|
|
class CIO {
|
|
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
CIO();
|
|
|
|
|
|
|
|
|
|
// Platform API
|
2017-08-20 18:22:34 +02:00
|
|
|
void Init(void);
|
|
|
|
|
void SCLK_pin(bool on);
|
|
|
|
|
void SDATA_pin(bool on);
|
|
|
|
|
bool SREAD_pin(void);
|
|
|
|
|
void SLE_pin(bool on);
|
2017-05-01 06:02:47 +02:00
|
|
|
#if defined(DUPLEX)
|
2017-08-20 18:22:34 +02:00
|
|
|
void SLE2_pin(bool on);
|
|
|
|
|
bool RXD2_pin(void);
|
2017-05-01 06:02:47 +02:00
|
|
|
#endif
|
2017-08-20 18:22:34 +02:00
|
|
|
void CE_pin(bool on);
|
|
|
|
|
bool RXD_pin(void);
|
|
|
|
|
bool CLK_pin(void);
|
2017-02-10 20:14:02 +01:00
|
|
|
|
2017-02-09 02:36:33 +01:00
|
|
|
#if defined(BIDIR_DATA_PIN)
|
2017-08-20 18:22:34 +02:00
|
|
|
void RXD_pin_write(bool on);
|
2017-02-09 02:36:33 +01:00
|
|
|
#endif
|
2017-02-10 20:14:02 +01:00
|
|
|
|
2017-08-20 18:22:34 +02:00
|
|
|
void TXD_pin(bool on);
|
|
|
|
|
void PTT_pin(bool on);
|
|
|
|
|
void LED_pin(bool on);
|
|
|
|
|
void DEB_pin(bool on);
|
|
|
|
|
void DSTAR_pin(bool on);
|
|
|
|
|
void DMR_pin(bool on);
|
|
|
|
|
void YSF_pin(bool on);
|
|
|
|
|
void P25_pin(bool on);
|
2018-02-13 15:36:40 +01:00
|
|
|
void NXDN_pin(bool on);
|
2017-08-20 18:22:34 +02:00
|
|
|
void COS_pin(bool on);
|
|
|
|
|
void interrupt(void);
|
2017-05-01 06:02:47 +02:00
|
|
|
#if defined(DUPLEX)
|
2017-08-20 18:22:34 +02:00
|
|
|
void interrupt2(void);
|
2017-05-01 06:02:47 +02:00
|
|
|
#endif
|
2017-08-20 17:24:12 +02:00
|
|
|
|
2017-02-09 02:36:33 +01:00
|
|
|
#if defined(BIDIR_DATA_PIN)
|
2017-08-20 18:22:34 +02:00
|
|
|
void Data_dir_out(bool dir);
|
2017-02-09 02:36:33 +01:00
|
|
|
#endif
|
|
|
|
|
|
2017-02-01 05:33:31 +01:00
|
|
|
// IO API
|
2017-04-30 04:05:03 +02:00
|
|
|
void write(uint8_t* data, uint16_t length, const uint8_t* control = NULL);
|
2017-02-10 18:03:14 +01:00
|
|
|
uint16_t getSpace(void) const;
|
|
|
|
|
void process(void);
|
|
|
|
|
bool hasTXOverflow(void);
|
|
|
|
|
bool hasRXOverflow(void);
|
2017-12-30 04:34:06 +01:00
|
|
|
uint8_t setFreq(uint32_t frequency_rx, uint32_t frequency_tx, uint8_t rf_power);
|
2017-12-31 22:22:29 +01:00
|
|
|
void setPower(uint8_t power);
|
2017-03-25 16:52:37 +01:00
|
|
|
void setMode(MMDVM_STATE modemState);
|
2017-02-10 18:03:14 +01:00
|
|
|
void setDecode(bool dcd);
|
2017-03-24 02:06:04 +01:00
|
|
|
void setLoDevYSF(bool ysfLoDev);
|
2017-08-20 18:22:34 +02:00
|
|
|
void resetWatchdog(void);
|
|
|
|
|
uint32_t getWatchdog(void);
|
|
|
|
|
void selfTest(void);
|
2017-02-01 05:33:31 +01:00
|
|
|
|
|
|
|
|
// RF interface API
|
2017-02-10 18:03:14 +01:00
|
|
|
void setTX(void);
|
2017-04-02 03:09:30 +02:00
|
|
|
void setRX(bool doSle = true);
|
2017-03-24 05:11:50 +01:00
|
|
|
void ifConf(MMDVM_STATE modemState, bool reset);
|
2017-05-01 06:02:47 +02:00
|
|
|
#if defined(DUPLEX)
|
|
|
|
|
void ifConf2(MMDVM_STATE modemState);
|
|
|
|
|
#endif
|
2017-02-10 18:03:14 +01:00
|
|
|
void start(void);
|
|
|
|
|
void startInt(void);
|
2018-02-15 18:27:04 +01:00
|
|
|
void setDeviations(uint8_t dstarTXLevel, uint8_t dmrTXLevel, uint8_t ysfTXLevel, uint8_t p25TXLevel, uint8_t nxdnTXLevel, bool ysfLoDev);
|
|
|
|
|
void updateCal(void);
|
|
|
|
|
|
2017-02-10 18:03:14 +01:00
|
|
|
#if defined(SEND_RSSI_DATA)
|
|
|
|
|
uint16_t readRSSI(void);
|
|
|
|
|
#endif
|
2017-02-01 05:33:31 +01:00
|
|
|
|
2017-02-02 05:31:33 +01:00
|
|
|
// Misc functions
|
2017-02-10 18:03:14 +01:00
|
|
|
void dlybit(void);
|
2017-08-12 23:02:31 +02:00
|
|
|
void delay_IFcal(void);
|
2017-04-15 00:03:10 +02:00
|
|
|
void delay_reset(void);
|
2017-04-02 03:09:30 +02:00
|
|
|
void delay_us(uint32_t us);
|
2017-08-21 01:48:17 +02:00
|
|
|
uint32_t RXfreq(void);
|
|
|
|
|
uint32_t TXfreq(void);
|
|
|
|
|
uint16_t devDSTAR(void);
|
|
|
|
|
uint16_t devDMR(void);
|
2018-02-15 18:27:04 +01:00
|
|
|
uint16_t devYSF(void);
|
2017-08-21 01:48:17 +02:00
|
|
|
uint16_t devP25(void);
|
2018-02-13 17:30:06 +01:00
|
|
|
uint16_t devNXDN(void);
|
2017-08-26 23:55:37 +02:00
|
|
|
void printConf();
|
2017-08-21 01:48:17 +02:00
|
|
|
|
2017-02-01 05:33:31 +01:00
|
|
|
private:
|
2017-08-21 01:48:17 +02:00
|
|
|
uint8_t m_RX_N_divider;
|
|
|
|
|
uint16_t m_RX_F_divider;
|
|
|
|
|
uint8_t m_TX_N_divider;
|
|
|
|
|
uint16_t m_TX_F_divider;
|
2017-02-10 20:14:02 +01:00
|
|
|
|
2017-03-25 16:52:37 +01:00
|
|
|
bool m_started;
|
|
|
|
|
CBitRB m_rxBuffer;
|
|
|
|
|
CBitRB m_txBuffer;
|
|
|
|
|
bool m_LoDevYSF;
|
|
|
|
|
uint32_t m_ledCount;
|
|
|
|
|
bool m_scanEnable;
|
|
|
|
|
uint32_t m_scanPauseCnt;
|
|
|
|
|
uint8_t m_scanPos;
|
|
|
|
|
uint8_t m_TotalModes;
|
2018-02-13 17:30:06 +01:00
|
|
|
MMDVM_STATE m_Modes[5];
|
2017-03-25 16:52:37 +01:00
|
|
|
bool m_ledValue;
|
|
|
|
|
volatile uint32_t m_watchdog;
|
2017-02-01 05:33:31 +01:00
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
#endif
|