mirror of https://github.com/g4klx/MMDVM.git
Merge branch 'master' into dstar_correlator
This commit is contained in:
commit
d30d768bdc
|
@ -194,6 +194,16 @@ int CSerialPort::availableInt(uint8_t n)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int CSerialPort::availableForWriteInt(uint8_t n)
|
||||||
|
{
|
||||||
|
switch (n) {
|
||||||
|
case 3U:
|
||||||
|
return Serial3.availableForWrite();
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
uint8_t CSerialPort::readInt(uint8_t n)
|
uint8_t CSerialPort::readInt(uint8_t n)
|
||||||
{
|
{
|
||||||
switch (n) {
|
switch (n) {
|
||||||
|
|
|
@ -433,6 +433,7 @@ DMR PC6 output
|
||||||
YSF PC7 output
|
YSF PC7 output
|
||||||
P25 PC8 output
|
P25 PC8 output
|
||||||
NXDN PC9 output
|
NXDN PC9 output
|
||||||
|
POCSAG PA8 output
|
||||||
|
|
||||||
RX PA0 analog input
|
RX PA0 analog input
|
||||||
RSSI PA7 analog input
|
RSSI PA7 analog input
|
||||||
|
@ -465,9 +466,9 @@ EXT_CLK PA15 input
|
||||||
#define PORT_NXDN GPIOC
|
#define PORT_NXDN GPIOC
|
||||||
#define RCC_Per_NXDN RCC_AHB1Periph_GPIOC
|
#define RCC_Per_NXDN RCC_AHB1Periph_GPIOC
|
||||||
|
|
||||||
#define PIN_POCSAG GPIO_Pin_12
|
#define PIN_POCSAG GPIO_Pin_8
|
||||||
#define PORT_POCSAG GPIOB
|
#define PORT_POCSAG GPIOA
|
||||||
#define RCC_Per_POCSAG RCC_AHB1Periph_GPIOB
|
#define RCC_Per_POCSAG RCC_AHB1Periph_GPIOA
|
||||||
|
|
||||||
#define PIN_DSTAR GPIO_Pin_15
|
#define PIN_DSTAR GPIO_Pin_15
|
||||||
#define PORT_DSTAR GPIOB
|
#define PORT_DSTAR GPIOB
|
||||||
|
|
|
@ -102,7 +102,7 @@ void loop()
|
||||||
if (m_nxdnEnable && m_modemState == STATE_NXDN)
|
if (m_nxdnEnable && m_modemState == STATE_NXDN)
|
||||||
nxdnTX.process();
|
nxdnTX.process();
|
||||||
|
|
||||||
if (m_pocsagEnable && m_modemState == STATE_POCSAG)
|
if (m_pocsagEnable && (m_modemState == STATE_POCSAG || pocsagTX.busy()))
|
||||||
pocsagTX.process();
|
pocsagTX.process();
|
||||||
|
|
||||||
if (m_modemState == STATE_DSTARCAL)
|
if (m_modemState == STATE_DSTARCAL)
|
||||||
|
|
|
@ -99,7 +99,7 @@ void loop()
|
||||||
if (m_nxdnEnable && m_modemState == STATE_NXDN)
|
if (m_nxdnEnable && m_modemState == STATE_NXDN)
|
||||||
nxdnTX.process();
|
nxdnTX.process();
|
||||||
|
|
||||||
if (m_pocsagEnable && m_modemState == STATE_POCSAG)
|
if (m_pocsagEnable && (m_modemState == STATE_POCSAG || pocsagTX.busy()))
|
||||||
pocsagTX.process();
|
pocsagTX.process();
|
||||||
|
|
||||||
if (m_modemState == STATE_DSTARCAL)
|
if (m_modemState == STATE_DSTARCAL)
|
||||||
|
|
|
@ -87,6 +87,14 @@ void CPOCSAGTX::process()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool CPOCSAGTX::busy()
|
||||||
|
{
|
||||||
|
if (m_poLen > 0U || m_buffer.getData() > 0U)
|
||||||
|
return true;
|
||||||
|
else
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
uint8_t CPOCSAGTX::writeData(const uint8_t* data, uint8_t length)
|
uint8_t CPOCSAGTX::writeData(const uint8_t* data, uint8_t length)
|
||||||
{
|
{
|
||||||
if (length != POCSAG_FRAME_LENGTH_BYTES)
|
if (length != POCSAG_FRAME_LENGTH_BYTES)
|
||||||
|
|
|
@ -35,6 +35,8 @@ public:
|
||||||
|
|
||||||
uint8_t getSpace() const;
|
uint8_t getSpace() const;
|
||||||
|
|
||||||
|
bool busy();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
CSerialRB m_buffer;
|
CSerialRB m_buffer;
|
||||||
arm_fir_instance_q15 m_modFilter;
|
arm_fir_instance_q15 m_modFilter;
|
||||||
|
|
|
@ -32,7 +32,7 @@ Boston, MA 02110-1301, USA.
|
||||||
#include <Arduino.h>
|
#include <Arduino.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
const uint16_t SERIAL_RINGBUFFER_SIZE = 2000U;
|
const uint16_t SERIAL_RINGBUFFER_SIZE = 1000U;
|
||||||
|
|
||||||
class CSerialRB {
|
class CSerialRB {
|
||||||
public:
|
public:
|
||||||
|
|
Loading…
Reference in New Issue