50 static KwargsList enumerate(
const std::string &args);
78 static Device *make(
const std::string &args);
88 static void unmake(
Device *device);
99 virtual std::string getDriverKey(
void)
const;
106 virtual std::string getHardwareKey(
void)
const;
115 virtual Kwargs getHardwareInfo(
void)
const;
127 virtual void setFrontendMapping(
const int direction,
const std::string &mapping);
134 virtual std::string getFrontendMapping(
const int direction)
const;
139 virtual size_t getNumChannels(
const int direction)
const;
147 virtual bool getFullDuplex(
const int direction,
const size_t channel)
const;
159 virtual std::vector<std::string> getStreamFormats(
const int direction,
const size_t channel)
const;
170 virtual std::string getNativeStreamFormat(
const int direction,
const size_t channel,
double &fullScale)
const;
178 virtual ArgInfoList getStreamArgsInfo(
const int direction,
const size_t channel)
const;
210 virtual Stream *setupStream(
212 const std::string &format,
213 const std::vector<size_t> &channels = std::vector<size_t>(),
221 virtual void closeStream(Stream *stream);
232 virtual size_t getStreamMTU(Stream *stream)
const;
251 virtual int activateStream(
254 const long long timeNs = 0,
255 const size_t numElems = 0);
271 virtual int deactivateStream(
274 const long long timeNs = 0);
294 virtual int readStream(
297 const size_t numElems,
300 const long timeoutUs = 100000);
315 virtual int writeStream(
317 const void *
const *buffs,
318 const size_t numElems,
320 const long long timeNs = 0,
321 const long timeoutUs = 100000);
335 virtual int readStreamStatus(
340 const long timeoutUs = 100000);
355 virtual size_t getNumDirectAccessBuffers(Stream *stream);
370 virtual int getDirectAccessBufferAddrs(Stream *stream,
const size_t handle,
void **buffs);
392 virtual int acquireReadBuffer(
398 const long timeoutUs = 100000);
407 virtual void releaseReadBuffer(
409 const size_t handle);
431 virtual int acquireWriteBuffer(
435 const long timeoutUs = 100000);
452 virtual void releaseWriteBuffer(
455 const size_t numElems,
457 const long long timeNs = 0);
469 virtual std::vector<std::string> listAntennas(
const int direction,
const size_t channel)
const;
477 virtual void setAntenna(
const int direction,
const size_t channel,
const std::string &name);
485 virtual std::string getAntenna(
const int direction,
const size_t channel)
const;
497 virtual bool hasDCOffsetMode(
const int direction,
const size_t channel)
const;
505 virtual void setDCOffsetMode(
const int direction,
const size_t channel,
const bool automatic);
513 virtual bool getDCOffsetMode(
const int direction,
const size_t channel)
const;
521 virtual bool hasDCOffset(
const int direction,
const size_t channel)
const;
529 virtual void setDCOffset(
const int direction,
const size_t channel,
const std::complex<double> &offset);
537 virtual std::complex<double> getDCOffset(
const int direction,
const size_t channel)
const;
545 virtual bool hasIQBalance(
const int direction,
const size_t channel)
const;
553 virtual void setIQBalance(
const int direction,
const size_t channel,
const std::complex<double> &balance);
561 virtual std::complex<double> getIQBalance(
const int direction,
const size_t channel)
const;
574 virtual std::vector<std::string> listGains(
const int direction,
const size_t channel)
const;
582 virtual bool hasGainMode(
const int direction,
const size_t channel)
const;
590 virtual void setGainMode(
const int direction,
const size_t channel,
const bool automatic);
598 virtual bool getGainMode(
const int direction,
const size_t channel)
const;
608 virtual void setGain(
const int direction,
const size_t channel,
const double value);
617 virtual void setGain(
const int direction,
const size_t channel,
const std::string &name,
const double value);
625 virtual double getGain(
const int direction,
const size_t channel)
const;
634 virtual double getGain(
const int direction,
const size_t channel,
const std::string &name)
const;
642 virtual Range getGainRange(
const int direction,
const size_t channel)
const;
651 virtual Range getGainRange(
const int direction,
const size_t channel,
const std::string &name)
const;
684 virtual void setFrequency(
const int direction,
const size_t channel,
const double frequency,
const Kwargs &args =
Kwargs());
702 virtual void setFrequency(
const int direction,
const size_t channel,
const std::string &name,
const double frequency,
const Kwargs &args =
Kwargs());
712 virtual double getFrequency(
const int direction,
const size_t channel)
const;
721 virtual double getFrequency(
const int direction,
const size_t channel,
const std::string &name)
const;
730 virtual std::vector<std::string> listFrequencies(
const int direction,
const size_t channel)
const;
738 virtual RangeList getFrequencyRange(
const int direction,
const size_t channel)
const;
747 virtual RangeList getFrequencyRange(
const int direction,
const size_t channel,
const std::string &name)
const;
755 virtual ArgInfoList getFrequencyArgsInfo(
const int direction,
const size_t channel)
const;
767 virtual void setSampleRate(
const int direction,
const size_t channel,
const double rate);
775 virtual double getSampleRate(
const int direction,
const size_t channel)
const;
783 virtual std::vector<double> listSampleRates(
const int direction,
const size_t channel)
const;
791 virtual void setBandwidth(
const int direction,
const size_t channel,
const double bw);
799 virtual double getBandwidth(
const int direction,
const size_t channel)
const;
807 virtual std::vector<double> listBandwidths(
const int direction,
const size_t channel)
const;
817 virtual void setMasterClockRate(
const double rate);
823 virtual double getMasterClockRate(
void)
const;
829 virtual RangeList getMasterClockRates(
void)
const;
835 virtual std::vector<std::string> listClockSources(
void)
const;
841 virtual void setClockSource(
const std::string &source);
847 virtual std::string getClockSource(
void)
const;
853 virtual std::vector<std::string> listTimeSources(
void)
const;
859 virtual void setTimeSource(
const std::string &source);
865 virtual std::string getTimeSource(
void)
const;
876 virtual bool hasHardwareTime(
const std::string &what =
"")
const;
884 virtual long long getHardwareTime(
const std::string &what =
"")
const;
892 virtual void setHardwareTime(
const long long timeNs,
const std::string &what =
"");
901 virtual void setCommandTime(
const long long timeNs,
const std::string &what =
"");
912 virtual std::vector<std::string> listSensors(
void)
const;
920 virtual ArgInfo getSensorInfo(
const std::string &name)
const;
929 virtual std::string readSensor(
const std::string &name)
const;
938 virtual std::vector<std::string> listSensors(
const int direction,
const size_t channel)
const;
948 virtual ArgInfo getSensorInfo(
const int direction,
const size_t channel,
const std::string &name)
const;
959 virtual std::string readSensor(
const int direction,
const size_t channel,
const std::string &name)
const;
972 virtual void writeRegister(
const unsigned addr,
const unsigned value);
979 virtual unsigned readRegister(
const unsigned addr)
const;
997 virtual void writeSetting(
const std::string &key,
const std::string &value);
1004 virtual std::string readSetting(
const std::string &key)
const;
1013 virtual std::vector<std::string> listGPIOBanks(
void)
const;
1020 virtual void writeGPIO(
const std::string &bank,
const unsigned value);
1028 virtual void writeGPIO(
const std::string &bank,
const unsigned value,
const unsigned mask);
1035 virtual unsigned readGPIO(
const std::string &bank)
const;
1043 virtual void writeGPIODir(
const std::string &bank,
const unsigned dir);
1052 virtual void writeGPIODir(
const std::string &bank,
const unsigned dir,
const unsigned mask);
1060 virtual unsigned readGPIODir(
const std::string &bank)
const;
1073 virtual void writeI2C(
const int addr,
const std::string &data);
1083 virtual std::string readI2C(
const int addr,
const size_t numBytes);
1103 virtual unsigned transactSPI(
const int addr,
const unsigned data,
const size_t numBits);
1113 virtual std::vector<std::string> listUARTs(
void)
const;
1122 virtual void writeUART(
const std::string &which,
const std::string &data);
1132 virtual std::string readUART(
const std::string &which,
const long timeoutUs = 100000)
const;
std::vector< Kwargs > KwargsList
Typedef for a list of key-word dictionaries.
Definition: Types.hpp:25
std::vector< ArgInfo > ArgInfoList
Definition: Types.hpp:112
std::map< std::string, std::string > Kwargs
Typedef for a dictionary of key-value string arguments.
Definition: Types.hpp:22
std::vector< Range > RangeList
Definition: Types.hpp:55
Definition: Device.hpp:21
Definition: Device.hpp:30
#define SOAPY_SDR_API
Definition: Config.h:41