41 static std::vector<Kwargs> enumerate(
const Kwargs &args =
Kwargs());
49 static std::vector<Kwargs> enumerate(
const std::string &args);
77 static Device *make(
const std::string &args);
87 static void unmake(
Device *device);
98 virtual std::string getDriverKey(
void)
const;
105 virtual std::string getHardwareKey(
void)
const;
114 virtual Kwargs getHardwareInfo(
void)
const;
126 virtual void setFrontendMapping(
const int direction,
const std::string &mapping);
133 virtual std::string getFrontendMapping(
const int direction)
const;
138 virtual size_t getNumChannels(
const int direction)
const;
146 virtual bool getFullDuplex(
const int direction,
const size_t channel)
const;
180 virtual Stream *setupStream(
182 const std::string &format,
183 const std::vector<size_t> &channels = std::vector<size_t>(),
191 virtual void closeStream(Stream *stream);
210 virtual int activateStream(
213 const long long timeNs = 0,
214 const size_t numElems = 0);
230 virtual int deactivateStream(
233 const long long timeNs = 0);
248 virtual int readStream(
251 const size_t numElems,
254 const long timeoutUs = 100000);
269 virtual int writeStream(
271 const void *
const *buffs,
272 const size_t numElems,
274 const long long timeNs = 0,
275 const long timeoutUs = 100000);
287 virtual std::vector<std::string> listAntennas(
const int direction,
const size_t channel)
const;
295 virtual void setAntenna(
const int direction,
const size_t channel,
const std::string &name);
303 virtual std::string getAntenna(
const int direction,
const size_t channel)
const;
315 virtual void setDCOffsetMode(
const int direction,
const size_t channel,
const bool automatic);
323 virtual bool getDCOffsetMode(
const int direction,
const size_t channel)
const;
331 virtual void setDCOffset(
const int direction,
const size_t channel,
const std::complex<double> &offset);
339 virtual std::complex<double> getDCOffset(
const int direction,
const size_t channel)
const;
347 virtual void setIQBalance(
const int direction,
const size_t channel,
const std::complex<double> &balance);
355 virtual std::complex<double> getIQBalance(
const int direction,
const size_t channel)
const;
367 virtual std::vector<std::string> listGains(
const int direction,
const size_t channel)
const;
375 virtual void setGainMode(
const int direction,
const size_t channel,
const bool automatic);
383 virtual bool getGainMode(
const int direction,
const size_t channel)
const;
393 virtual void setGain(
const int direction,
const size_t channel,
const double value);
402 virtual void setGain(
const int direction,
const size_t channel,
const std::string &name,
const double value);
410 virtual double getGain(
const int direction,
const size_t channel)
const;
419 virtual double getGain(
const int direction,
const size_t channel,
const std::string &name)
const;
427 virtual Range getGainRange(
const int direction,
const size_t channel)
const;
436 virtual Range getGainRange(
const int direction,
const size_t channel,
const std::string &name)
const;
454 virtual void setFrequency(
const int direction,
const size_t channel,
const double frequency,
const Kwargs &args =
Kwargs());
462 virtual double getFrequency(
const int direction,
const size_t channel)
const;
475 virtual double getFrequency(
const int direction,
const size_t channel,
const std::string &name)
const;
483 virtual std::vector<std::string> listFrequencies(
const int direction,
const size_t channel)
const;
491 virtual RangeList getFrequencyRange(
const int direction,
const size_t channel)
const;
503 virtual void setSampleRate(
const int direction,
const size_t channel,
const double rate);
511 virtual double getSampleRate(
const int direction,
const size_t channel)
const;
519 virtual std::vector<double> listSampleRates(
const int direction,
const size_t channel)
const;
527 virtual void setBandwidth(
const int direction,
const size_t channel,
const double bw);
535 virtual double getBandwidth(
const int direction,
const size_t channel)
const;
543 virtual std::vector<double> listBandwidths(
const int direction,
const size_t channel)
const;
553 virtual void setMasterClockRate(
const double rate);
559 virtual double getMasterClockRate(
void)
const;
565 virtual std::vector<std::string> listClockSources(
void)
const;
571 virtual void setClockSource(
const std::string &source);
577 virtual std::string getClockSource(
void)
const;
583 virtual std::vector<std::string> listTimeSources(
void)
const;
589 virtual void setTimeSource(
const std::string &source);
595 virtual std::string getTimeSource(
void)
const;
606 virtual bool hasHardwareTime(
const std::string &what =
"")
const;
614 virtual long long getHardwareTime(
const std::string &what =
"")
const;
622 virtual void setHardwareTime(
const long long timeNs,
const std::string &what =
"");
631 virtual void setCommandTime(
const long long timeNs,
const std::string &what =
"");
642 virtual std::vector<std::string> listSensors(
void)
const;
651 virtual std::string readSensor(
const std::string &name)
const;
664 virtual void writeRegister(
const unsigned addr,
const unsigned value);
671 virtual unsigned readRegister(
const unsigned addr)
const;
683 virtual void writeSetting(
const std::string &key,
const std::string &value);
690 virtual std::string readSetting(
const std::string &key)
const;
699 virtual std::vector<std::string> listGPIOBanks(
void)
const;
706 virtual void writeGPIO(
const std::string &bank,
const unsigned value);
713 virtual unsigned readGPIO(
const std::string &bank)
const;
726 virtual void writeI2C(
const int addr,
const std::string &data);
736 virtual std::string readI2C(
const int addr,
const size_t numBytes);
756 virtual unsigned transactSPI(
const int addr,
const unsigned data,
const size_t numBits);
766 virtual std::vector<std::string> listUARTs(
void)
const;
775 virtual void writeUART(
const std::string &which,
const std::string &data);
785 virtual std::string readUART(
const std::string &which,
const long timeoutUs = 100000)
const;
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:52
Definition: Device.hpp:29
#define SOAPY_SDR_API
Definition: Config.h:41