summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Radio/HW/AirSpy/AirSpy.swift62
-rw-r--r--Radio/Utils/AirSpyIQ/main.swift58
2 files changed, 76 insertions, 44 deletions
diff --git a/Radio/HW/AirSpy/AirSpy.swift b/Radio/HW/AirSpy/AirSpy.swift
index 5b1b109..d7916b2 100644
--- a/Radio/HW/AirSpy/AirSpy.swift
+++ b/Radio/HW/AirSpy/AirSpy.swift
@@ -6,9 +6,67 @@
//
import libairspy
+enum AirspyHFError: Error {
+ case InvalidDevice
+}
+
/// Wrapper for libairspy library
class AirSpy {
- init() {
- airspy_init()
+
+ var dev:UnsafeMutablePointer<airspy_device_t>? = .allocate(capacity: 1)
+ var sample_rates:[UInt32] = []
+
+ init(serialno: UInt64) throws {
+ let ret = airspy_open_sn(&dev, serialno)
+ if (ret != AIRSPY_SUCCESS.rawValue) {
+ throw AirspyHFError.InvalidDevice
+ }
+ }
+
+ /// will open first device it can find
+ init() throws {
+ let ret = airspy_open(&dev)
+ if ret != AIRSPY_SUCCESS.rawValue {
+ print("Couldnt open airspy device")
+ throw AirspyHFError.InvalidDevice
+ }
+ }
+
+ func getSampleRates() -> [UInt32] {
+ if sample_rates.count == 0 {
+
+ let nscount: UnsafeMutablePointer<UInt32> = .allocate(capacity: 1)
+ ret = airspy_get_samplerates(dev, nscount, 0)
+
+ let samplerates_buf:UnsafeMutableBufferPointer<UInt32> = .allocate(capacity: Int(nscount.pointee))
+ let rawPointer = UnsafeMutablePointer<UInt32>?(samplerates_buf.baseAddress!)
+ ret = airspy_get_samplerates(dev, rawPointer, nscount.pointee)
+
+ sample_rates = []
+ for i in 0..<Int(nscount.pointee) {
+ sample_rates.append(samplerates_buf[i])
+ }
+ }
+ return sample_rates
+ }
+
+ func setSampleRate(_ samplerate: UInt32 ) -> Int32 {
+ return airspy_set_samplerate(dev, samplerate)
+ }
+
+ func startRx(_ callback: airspy_sample_block_cb_fn) -> Int32 {
+ return airspy_start_rx(dev, callback, nil)
+ }
+
+ func setFrequency(_ freq: UInt32) -> Int32 {
+ return airspy_set_freq(dev, freq)
+ }
+
+ func isStreaming() -> Int32 {
+ return airspy_is_streaming(dev)
+ }
+
+ func close() -> Int32 {
+ return airspy_close(dev)
}
}
diff --git a/Radio/Utils/AirSpyIQ/main.swift b/Radio/Utils/AirSpyIQ/main.swift
index 1fa6b04..7fea329 100644
--- a/Radio/Utils/AirSpyIQ/main.swift
+++ b/Radio/Utils/AirSpyIQ/main.swift
@@ -12,7 +12,7 @@ import libairspy
//set the command line arguments
struct CommandLineArgs: ParsableCommand {
@Argument var file:String = ""
- @Option(name:.shortAndLong) var device_idx: Int = 0
+ @Option(name:.shortAndLong) var serialno: UInt64 = 0
@Option(name:.shortAndLong) var samplerate: Int = 3000000
@Option(name:.shortAndLong) var gain: Int = 0
@Option(name:.shortAndLong) var frequency: Int = 100000000
@@ -33,11 +33,7 @@ var libersion:airspy_lib_version_t = airspy_lib_version_t()
airspy_lib_version(&libersion)
print("libairspy \(libersion.major_version).\(libersion.minor_version).\(libersion.revision)")
-
//detect number of devices
-//let AIRSPY_MAX_DEVICES=32
-//var device:airspy_device_t = airspy_device_t()
-//var device:UnsafeMutablePointer<OpaquePointer?>?
var dev:UnsafeMutablePointer<airspy_device_t>? = .allocate(capacity: 1)
var ret:Int32
@@ -47,59 +43,37 @@ if (ret != AIRSPY_SUCCESS.rawValue) {
exit(1)
}
-print("Here")
-
-ret = airspy_open(&dev)
-
-let sample_rate_count: UnsafeMutablePointer<UInt32> = .allocate(capacity: 1)
-print("Here 2 \(sample_rate_count)")
-ret = airspy_get_samplerates(dev, sample_rate_count, 0)
-print("ret = \(ret)")
-print("Here 3")
-print("Number of supported sample rates \(sample_rate_count.pointee)")
-
-var samplerates:UnsafeMutableBufferPointer<UInt32> = .allocate(capacity: Int(sample_rate_count.pointee))
-let rawPointer = UnsafeMutablePointer<UInt32>?(samplerates.baseAddress!)
-ret = airspy_get_samplerates(dev, rawPointer, sample_rate_count.pointee)
-print("ret=\(ret)")
-for i in 0..<sample_rate_count.pointee {
- print("sample rate \(i): \(samplerates[Int(i)])")
+var device:AirSpy?
+do {
+ device = try AirSpy()
+} catch {
+ print("Cant attach to device")
}
-print("Here 4")
-ret = airspy_set_samplerate(dev, 3000000) //3M
-if (ret != AIRSPY_SUCCESS.rawValue) {
- print("Couldnt set samplerate")
-}
+let sample_rates = device?.getSampleRates()
+
+let _ = device?.setSampleRate(sample_rates![0])
print("Here 5")
func rf_callback(_ transffer: UnsafeMutablePointer<airspy_transfer_t>?) -> Int32 {
- print("Got some samples")
+ let t = transffer!.pointee
+ print("Got \(t.sample_count) samples")
return 0
}
-print("Here 6")
-ret = airspy_start_rx(dev, rf_callback, nil)
-if (ret != AIRSPY_SUCCESS.rawValue) {
- print("Couldn't start rf thread")
-}
+let _ = device?.startRx(rf_callback)
-print("Here 7")
-ret = airspy_set_freq(dev, 100000000) //100M
-if (ret != AIRSPY_SUCCESS.rawValue) {
- print("Couldn't set frequency")
-}
+let _ = device?.setFrequency(UInt32(args.frequency))
-print("Here 8")
sleep(1)
var count = 10
-while((airspy_is_streaming(dev) != AIRSPY_TRUE.rawValue)
+while ((device?.isStreaming() != AIRSPY_TRUE.rawValue)
&& (count>0)) {
print("Streaming")
sleep(1)
count -= 1
}
-print("Here 9")
-airspy_close(dev)
+let _ = device?.close()
+
airspy_exit()