mirror of
https://github.com/RangeNetworks/openbts.git
synced 2025-11-18 04:03:45 +00:00
Transceiver52M: Separate main transmit and receive drive threads
This patch primarily addresses observed repeated overrun conditions in embedded environments - namely ARM. The heartbeat of the transceiver is derived from the receive sample stream, which drives the main GSM clock. Detach the transmit thread from the receive loop to avoid interfering with the receive I/O, which is sensitive to overrun conditions if pull process is interrupted. Signed-off-by: Thomas Tsou <tom@tsou.cc> git-svn-id: http://wush.net/svn/range/software/public/openbts/trunk@6745 19bc5d8c-e614-43d4-8b26-e1612bc8e597
This commit is contained in:
@@ -57,7 +57,8 @@ Transceiver::Transceiver(int wBasePort,
|
||||
{
|
||||
GSM::Time startTime(random() % gHyperframe,0);
|
||||
|
||||
mFIFOServiceLoopThread = new Thread(32768); ///< thread to push bursts into transmit FIFO
|
||||
mRxServiceLoopThread = new Thread(32768);
|
||||
mTxServiceLoopThread = new Thread(32768);
|
||||
mControlServiceLoopThread = new Thread(32768); ///< thread to process control messages from GSM core
|
||||
mTransmitPriorityQueueServiceLoopThread = new Thread(32768);///< thread to process transmit bursts from GSM core
|
||||
|
||||
@@ -527,7 +528,8 @@ void Transceiver::driveControl()
|
||||
mRadioInterface->start();
|
||||
|
||||
// Start radio interface threads.
|
||||
mFIFOServiceLoopThread->start((void * (*)(void*))FIFOServiceLoopAdapter,(void*) this);
|
||||
mTxServiceLoopThread->start((void * (*)(void*))TxServiceLoopAdapter,(void*) this);
|
||||
mRxServiceLoopThread->start((void * (*)(void*))RxServiceLoopAdapter,(void*) this);
|
||||
mTransmitPriorityQueueServiceLoopThread->start((void * (*)(void*))TransmitPriorityQueueServiceLoopAdapter,(void*) this);
|
||||
writeClockInterface();
|
||||
|
||||
@@ -836,11 +838,9 @@ void Transceiver::driveTransmitFIFO()
|
||||
pushRadioVector(mTransmitDeadlineClock);
|
||||
mTransmitDeadlineClock.incTN();
|
||||
}
|
||||
|
||||
}
|
||||
// FIXME -- This should not be a hard spin.
|
||||
// But any delay here causes us to throw omni_thread_fatal.
|
||||
//else radioClock->wait();
|
||||
|
||||
radioClock->wait();
|
||||
}
|
||||
|
||||
|
||||
@@ -857,17 +857,22 @@ void Transceiver::writeClockInterface()
|
||||
|
||||
mLastClockUpdateTime = mTransmitDeadlineClock;
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
void *FIFOServiceLoopAdapter(Transceiver *transceiver)
|
||||
void *RxServiceLoopAdapter(Transceiver *transceiver)
|
||||
{
|
||||
transceiver->setPriority();
|
||||
|
||||
while (1) {
|
||||
transceiver->driveReceiveFIFO();
|
||||
pthread_testcancel();
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
|
||||
void *TxServiceLoopAdapter(Transceiver *transceiver)
|
||||
{
|
||||
while (1) {
|
||||
transceiver->driveTransmitFIFO();
|
||||
pthread_testcancel();
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user