mirror of
				https://github.com/fairwaves/openbts-2.8.git
				synced 2025-10-31 12:03:30 +00:00 
			
		
		
		
	Remove radio clock and vector interfaces into their own files. This clears up and simplifies the radio interface and, additionaly, prepares for a further split of the I/O portion for optional resampler use. Signed-off-by: Thomas Tsou <ttsou@vt.edu> git-svn-id: http://wush.net/svn/range/software/public/openbts/trunk@2669 19bc5d8c-e614-43d4-8b26-e1612bc8e597
		
			
				
	
	
		
			110 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			110 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Written by Thomas Tsou <ttsou@vt.edu>
 | |
|  * Based on code by Harvind S Samra <hssamra@kestrelsp.com>
 | |
|  *
 | |
|  * Copyright 2011 Free Software Foundation, Inc.
 | |
|  *
 | |
|  * This program is free software: you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU Affero General Public License as published by
 | |
|  * the Free Software Foundation, either version 3 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 Affero General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Affero General Public License
 | |
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | |
|  * See the COPYING file in the main directory for details.
 | |
|  */
 | |
| 
 | |
| #include "radioVector.h"
 | |
| 
 | |
| radioVector::radioVector(const signalVector& wVector, GSM::Time& wTime)
 | |
| 	: signalVector(wVector), mTime(wTime)
 | |
| {
 | |
| }
 | |
| 
 | |
| GSM::Time radioVector::time() const
 | |
| {
 | |
| 	return mTime;
 | |
| }
 | |
| 
 | |
| void radioVector::setTime(const GSM::Time& wTime)
 | |
| {
 | |
| 	mTime = wTime;
 | |
| }
 | |
| 
 | |
| bool radioVector::operator>(const radioVector& other) const
 | |
| {
 | |
| 	return mTime > other.mTime;
 | |
| }
 | |
| 
 | |
| unsigned VectorFIFO::size()
 | |
| {
 | |
| 	return mQ.size();
 | |
| }
 | |
| 
 | |
| void VectorFIFO::put(radioVector *ptr)
 | |
| {
 | |
| 	mQ.put((void*) ptr);
 | |
| }
 | |
| 
 | |
| radioVector *VectorFIFO::get()
 | |
| {
 | |
| 	return (radioVector*) mQ.get();
 | |
| }
 | |
| 
 | |
| GSM::Time VectorQueue::nextTime() const
 | |
| {
 | |
| 	GSM::Time retVal;
 | |
| 	mLock.lock();
 | |
| 
 | |
| 	while (mQ.size()==0)
 | |
| 		mWriteSignal.wait(mLock);
 | |
| 
 | |
| 	retVal = mQ.top()->time();
 | |
| 	mLock.unlock();
 | |
| 
 | |
| 	return retVal;
 | |
| }
 | |
| 
 | |
| radioVector* VectorQueue::getStaleBurst(const GSM::Time& targTime)
 | |
| {
 | |
| 	mLock.lock();
 | |
| 	if ((mQ.size()==0)) {
 | |
| 		mLock.unlock();
 | |
| 		return NULL;
 | |
| 	}
 | |
| 
 | |
| 	if (mQ.top()->time() < targTime) {
 | |
| 		radioVector* retVal = mQ.top();
 | |
| 		mQ.pop();
 | |
| 		mLock.unlock();
 | |
| 		return retVal;
 | |
| 	}
 | |
| 	mLock.unlock();
 | |
| 
 | |
| 	return NULL;
 | |
| }
 | |
| 
 | |
| radioVector* VectorQueue::getCurrentBurst(const GSM::Time& targTime)
 | |
| {
 | |
| 	mLock.lock();
 | |
| 	if ((mQ.size()==0)) {
 | |
| 		mLock.unlock();
 | |
| 		return NULL;
 | |
| 	}
 | |
| 
 | |
| 	if (mQ.top()->time() == targTime) {
 | |
| 		radioVector* retVal = mQ.top();
 | |
| 		mQ.pop();
 | |
| 		mLock.unlock();
 | |
| 		return retVal;
 | |
| 	}
 | |
| 	mLock.unlock();
 | |
| 
 | |
| 	return NULL;
 | |
| }
 |