From fb92612f60ebf40bf34a61c921f9040825374b1b Mon Sep 17 00:00:00 2001 From: f4exb Date: Thu, 22 Nov 2018 00:41:28 +0100 Subject: [PATCH] SoapySDR support: input: documentation --- debian/changelog | 4 +- doc/img/SoapySDRInput_plugin1.png | Bin 0 -> 29135 bytes doc/img/SoapySDR_arg_bool1.png | Bin 0 -> 1456 bytes doc/img/SoapySDR_arg_bool1.xcf | Bin 0 -> 2921 bytes doc/img/SoapySDR_arg_bool2.png | Bin 0 -> 1837 bytes doc/img/SoapySDR_arg_bool2.xcf | Bin 0 -> 3677 bytes doc/img/SoapySDR_arg_str.png | Bin 0 -> 2993 bytes doc/img/SoapySDR_arg_str.xcf | Bin 0 -> 5461 bytes doc/img/SoapySDR_arg_strlist.png | Bin 0 -> 1907 bytes doc/img/SoapySDR_arg_strlist.xcf | Bin 0 -> 4616 bytes doc/img/SoapySDR_range_discrete.png | Bin 0 -> 2155 bytes doc/img/SoapySDR_range_discrete.xcf | Bin 0 -> 4304 bytes doc/img/SoapySDR_range_gain.png | Bin 0 -> 2116 bytes doc/img/SoapySDR_range_gain.xcf | Bin 0 -> 4107 bytes doc/img/SoapySDR_range_list1.png | Bin 0 -> 3071 bytes doc/img/SoapySDR_range_list1.xcf | Bin 0 -> 13834 bytes doc/img/SoapySDR_range_neg.png | Bin 0 -> 2892 bytes doc/img/SoapySDR_range_neg.xcf | Bin 0 -> 14201 bytes doc/img/SoapySDR_range_pos.png | Bin 0 -> 3334 bytes doc/img/SoapySDR_range_pos.xcf | Bin 0 -> 12708 bytes .../channelrx/chanalyzer/chanalyzerplugin.cpp | 2 +- plugins/channelrx/demodatv/atvdemodplugin.cpp | 2 +- plugins/samplesource/soapysdrinput/readme.md | 208 ++++++++++++++++++ 23 files changed, 213 insertions(+), 3 deletions(-) create mode 100644 doc/img/SoapySDRInput_plugin1.png create mode 100644 doc/img/SoapySDR_arg_bool1.png create mode 100644 doc/img/SoapySDR_arg_bool1.xcf create mode 100644 doc/img/SoapySDR_arg_bool2.png create mode 100644 doc/img/SoapySDR_arg_bool2.xcf create mode 100644 doc/img/SoapySDR_arg_str.png create mode 100644 doc/img/SoapySDR_arg_str.xcf create mode 100644 doc/img/SoapySDR_arg_strlist.png create mode 100644 doc/img/SoapySDR_arg_strlist.xcf create mode 100644 doc/img/SoapySDR_range_discrete.png create mode 100644 doc/img/SoapySDR_range_discrete.xcf create mode 100644 doc/img/SoapySDR_range_gain.png create mode 100644 doc/img/SoapySDR_range_gain.xcf create mode 100644 doc/img/SoapySDR_range_list1.png create mode 100644 doc/img/SoapySDR_range_list1.xcf create mode 100644 doc/img/SoapySDR_range_neg.png create mode 100644 doc/img/SoapySDR_range_neg.xcf create mode 100644 doc/img/SoapySDR_range_pos.png create mode 100644 doc/img/SoapySDR_range_pos.xcf create mode 100644 plugins/samplesource/soapysdrinput/readme.md diff --git a/debian/changelog b/debian/changelog index 91461fb1d..ef646f6cb 100644 --- a/debian/changelog +++ b/debian/changelog @@ -2,8 +2,10 @@ sdrangel (4.3.0-1) unstable; urgency=medium * SoapySDR support * BladeRF2 corrections + * Scope fixes possible seg fault and correct memory processing + * FCDPro/FCDProPlus critical fixes to make it work again - -- Edouard Griffiths, F4EXB Sun, 18 Nov 2018 21:14:18 +0100 + -- Edouard Griffiths, F4EXB Thu, 22 Nov 2018 21:14:18 +0100 sdrangel (4.2.4-1) unstable; urgency=medium diff --git a/doc/img/SoapySDRInput_plugin1.png b/doc/img/SoapySDRInput_plugin1.png new file mode 100644 index 0000000000000000000000000000000000000000..5abf4f7d35374cf99d1c3fd6bb8c28310fafc084 GIT binary patch literal 29135 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 z]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 literal 0 HcmV?d00001 diff --git a/doc/img/SoapySDR_arg_bool1.png b/doc/img/SoapySDR_arg_bool1.png new file mode 100644 index 0000000000000000000000000000000000000000..c9acf58168bb226ed2476ea6703da8f067fbc917 GIT binary patch literal 1456 zcmV;h1yA~kP)WFU8GbZ8()Nlj2>E@cM*00k6DL_t(o!|j++NYi^1 z$3OnPn``25{~ks(n!W}>sV@?9rG-!o@;{j*MUf!3r;U^-86owwMfH*p$dDL;sDBMg zXz3C{BwP^GL--O|6jPa-ORN9fb{{VOxy!n>%T>Fu1B0FO`+v_lJKw|k?SG1@s;aUp zD=UCX+#@)8z&J^5sjRf}24GKyh(# zp(4Kv8Ji(4mkX!UNmo}FGcz;4jB9RgW@uv4OZxiy zc>n&r`kc{dq@$w)tJR7qiYzTHF*P+sZ*MQLSZrI!5H{0!ad9!njveFHty?%8j$g)! zqDXst`@fER@7_IXYiqIDY;<;ZlFeob27_2E767zbEq#4`n9XL~ZZ~yxb#!!eU@#a6 z1Oj=F>;DBAhYlU$_3PI>eE5+4`}bos8r8FF*RJ7mxm4Y1wIa(h8jXfvFo@A;M3!at z?Ae3KWa8${o5-@v@bEC*-QDQ*`k%&6r_;Q7^M;dv%P6Xkv@*OyEfV+3^BFi#^gM*wp zbxOtEzki>zXU{S=Hb!G(BVMnU3l}ahFfc$@SJ&2&;cz$@85tp!N)ZZ$u-olF#iUXx zyk0NycpOQRn46p9>eZ{fd-o1Wk~n$tBxbXjwzjssa*<`3+S*zG4jw$n`1m-fR4V70 zwY4>dhK5KclN<1DZEaXA7LFf3PIGfJRaI3uoleTi%D8dk27y2TNs@56T%0*`MvbK? z3f0xsG&MEx=+PrmsTB3~^|;+`{C@w|kYP5Pu~;ljPfr6dIyy>IQxio+MS1xtD=VYA zx|(1xsQx%vma$r`dHG2ula!X0A_xKogMo#Gg}m_f_4SO7j-n_EtE;QDx3@DgGD1yF z4T(g8$;n9o78Vu=hr`s>)d7&rW(kMGeEs@W)nB}L!N-pux9$RWI2?$g$de~eRGVI} zr>3SRuZw)=&Yb`(EiI|GL?WTu^J$J)EJh}iAs&yjYuB#4@a5&@EH5vs`lnBy)cpRQ z8$diBr=p@FNB{PG%kB(~MuXjMr=_I@o6V+v{C+=@B&qX!edYo`+yJb1uqcW-|AZD7 z7xT*L#EBC;efkuDXV0F|*x0z?-Vp?W?(S~PX7dJoEEdbjK@>$yCKHQ`i#hi1<(JK7 zbI!ljHmL-8!8Ptyas*$_g_x zGqkq00#H&?g2Uk;91j09kD{U?cJJOzPfrh(m6hDNa|eLI!9kXnm+9^8W#7Ji=yWz44X`<060IRF3oI7`p^XJdw^ZC?H zo|u@x>-C~2$_AhP{r!ld$b$zDP!xs9$w>wV21uvVcsw3F9uID}n{+zO?c2ABL?U_D zt!RBw_)nwaM^acYZqggLAPB6JlFy>BAe%r&Vf(uMQfTepNd5#Qs0V^C9_{J?0000< KMNUMnLSTZ`%dX4- literal 0 HcmV?d00001 diff --git a/doc/img/SoapySDR_arg_bool1.xcf b/doc/img/SoapySDR_arg_bool1.xcf new file mode 100644 index 0000000000000000000000000000000000000000..0df4d94c59779550016e99aa16ee4cd4db68954d GIT binary patch literal 2921 zcmeHJ-A_|z7(cB{5hR)f^+XLCE$8 zf^JFld)-QPPDZv%c6!}jpO`&8i>pjBJWE191>%%9S zRq62afqv}>N8x%1t)@dQnKnqwMFD28UrF=d#ha*zjuDKl@%Gy|Xq3o+R= zCSx(C8jy)Mo!Z2BFB{_n0J9a`BFqK$SoqhQ;gV_RU2+|;oK z_Fl6LmjaiX0IzBp)YMA*bv1I%h6T__W5jsZRUGZN=ry-IIMbNaK#BsPGqB$NC8hDa zME9?l)uf@nV!({;57#CZVo^!_OJH9(CHf|A?m40tX{RS%7+#EMvQD)%ZUJhZrBnx^ zxYd$UEx@GZX(gS;$oGGt;}lS*@?yntI}q$m$wGhNSkyMVLwee}9(vl5vNs!>uEE@; z!tu(A?q(E*ekK*4-`dR`Q9EprdwNyqIAx!Nj@s|vxqd{&y52FT{clxmEu=8l=Izst zOK|_Vuy80=c6Kg zipkF#N~l2%S=*z7EoL|$sC_>IkB<)qFZ|ZqN-ci)WVhAU^FzsVAIhV<(RZT|Z3ACn z310Wr0qYC>kEjogx1UA$AaM3FvY|V z&i~$uu#fUB)Yv9=6>aVM$IAWkr@OYIJBQal_rgBvN-<(XvHoU$iHum=Mu*!9P<1~N bK7=HpUTDPpbADj;G;ZUsuYB_9FQtD0kIFw% literal 0 HcmV?d00001 diff --git a/doc/img/SoapySDR_arg_bool2.png b/doc/img/SoapySDR_arg_bool2.png new file mode 100644 index 0000000000000000000000000000000000000000..cefddca78fcab78179a6af62d0515d920910bab2 GIT binary patch literal 1837 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 literal 0 HcmV?d00001 diff --git a/doc/img/SoapySDR_arg_strlist.png b/doc/img/SoapySDR_arg_strlist.png new file mode 100644 index 0000000000000000000000000000000000000000..d71a604bb54a607f3f23377f00f299a812136964 GIT binary patch literal 1907 zcmV-(2aNcMP)WFU8GbZ8()Nlj2>E@cM*00!4dL_t(|+U=WdNKeaLZQHBv&pQQ29!!AAt52Wd-qOO zMt7BQ{`~ne5oZA1-Q5HP1W0QtCopb6cFlk1TF%J?#_4q8bUI}w&CpuPWR%G$lW{UP zU0q#GLqh`wg8_rVKz)5ZckkXME-p?o&dtrmY&K&unOs_4UfvHE-oJl8H*enjZ9hb( z(-9RFHR)%Cg@r%3q)V4Bv17*$m%arH7En=9!R5=BUHbHTJ*!u*cCjrkE+!)*!=*1i zKAzIj(!YwZwy}cb#6nXvnH5!cutJMmCzrQ~!l?s1v6|IH{?r^z`&hErA&w9i_g$o{t|t5)l#M7W)ed3IK?Wjph3F>!hTl zP*_;Vg9i^tNJ#jti(Xt@Oj1%3ix)5csa;%L9930S==FLRuh7uYfJUQ{&edu)&CSj9 z_xBSP7WVDVRw#&!jKpX({?)F%tE&sGR?C(xTYzuH^Yrv|bUGcCm6a407P4&FGRZ?; zyLOG-++51a%E-ydAvidg{QP`kV`HZlGb$7cwr}4~aBwiq&CS!A{P6HF8#Zj9sHlj7 zf&x~oSV4JtIhB=_3=9m+Xv{cS|NHmv(d+e`Jb9AL%*+YLtXZ>$p`jsKTU)W&Y?PFg zaO1`ehKGkS8jU0;C*$YmM{jR0YPFiCrY7mQrKN>ct5yMEwOap(GRDWpOLO=hR;!gK zPoB(J%qR!~BO@aKBqb#g5fQ=R!-p9h9OT4_6J%v&k(88#-EL>yx^eMMdeE2ZAGUnvuP+MC|ZEYDzlY!VU@uvjcEEhQ!8Unl?h^JiYY zdLCwX$v7HUK_-`b1}ECmT0z#KXe_ zwOWnYY{p`-NQ$Y^XfT;f(kA_GJbwI`uCA^Lm24s+x{D=CmXMg3$g^k90NA;6C-?5% zV{mW~fQpI=)~;PE#fAO-{SpzUoK25sZ)RpDzP`TH*VnrYxPANflw!v3A&R1O>~J`~ z-3jyDD|5ONGmbs}x^m?Tr%#`zv9Zx*%)*5W*}8Qrn>TMJIXPLn`~Cg>rA0Ryjc7C) z+S}Xt`t>Uv9Ub)a^lC*8`V7yR$51Y-#qD70O^RcAPX0s6z5;EoW zm{gj+eEC92NeLMl8F+bl{Z#>YetteNF)=J%y41x**VNRw*f|^yolpo5G^e&E(-A{k(ZY@Vae@(Rr)!2@Syav#gQXNuvjeg_4Q3? zKQb~hVOi*>ezLs09Du~c#960`-#38l>};y5tEE<4Tr7Py-qvQbQCeC`P*4y6>({SG zrBcz*(D1``YieqUiHSj>P++&)u~;mGhKADE*eKbU&1P1vTq&vITx-+Cty{Nv`}Qq& z?%YAA(-9mT%(-*tCbie=^%NBqarEd>*SLPJz3JW8*GFVzP&k zXA<(`!2fg1%Ey5+WXQ_s1{@BDtc)|bmNFULgr}z`qA2puKmSa*ekEgKD3wY?QI!7! z<1Pe2prfOMpr9ZE0|RA7O#`AR(%IRGAP6!U-GP^v7ehlsw70i2JUlEjYMNd~5QJG% tN1l^0<5+Rk$Hzxz)L#TSo0c(a@E<2F?t2&0C&K^$002ovPDHLkV1lR=i!cBH literal 0 HcmV?d00001 diff --git a/doc/img/SoapySDR_arg_strlist.xcf b/doc/img/SoapySDR_arg_strlist.xcf new file mode 100644 index 0000000000000000000000000000000000000000..2f707a3ef2ba112b991e4c9788d5ea2ec9a4c975 GIT binary patch literal 4616 zcmeHLdu&r>6mM_G!{J=T$3Lj_k0z{RBXHtlvh_Z`+ipypnS~YD22w^_3TrpFIvK+O zPQ^b68N>`@Oa>uHKv7Wss4(I*gcyVJieXFxj6lrTgI)GwYwxY+yS-)QmH3y5rYAYy z{oQlU@B6-czO#GJ>h<}nP3tQ>CXcVutwY(1I)eg~CsFl!9G*g*N}6>#swhvRrl2yY z&uW;)J%jNDcun)-wAmF^e!n{q#CsieP8Vz3uAqCh>0MuNjj5opsF-?;YN*fe^18FV zHNMrTmTFS5Tcxv6jyBnnJ2Td`{ zy;Pb9P4r*K5nkixLo=FI?5d>+ece^>uAwpXJg7`YrRNhxovL9nSy|>MuUfta<7kR)#*}k4{0Z;U6}<| zh!2?{XJwkx&3JEtaMoN$S@{#?>P;lm;ml9ZSFvm^wHxgkESrF(Hlt0mE)$L7?O8Ao z9vd6|qYB1=P3*`x~`gt>Ejs3$?x3hS%Xr^tm6T za119)>p25ABrWH-AHO`UKEEEuc3jK(XPia1Z^SvTT-)^sP6^Afii9T>?qH>IR?kM7 zqqGuaa|vr?wWD2ZHCi8pjyz+YYK>S57Urhs#&A}4fg|047z=B*C01Ay)i!~Wb(gHW zWZfm-ckx%`|L}dcX>xmXlWsGxW+k&cuUsy3ILAuSz*Z2h6jL-L2; zMpt)}Aowo|#l88$3Z+;$zWwlLLiMm+m?0?JLn$F;8-D9hKGhm&++`BkoyMz+MNZRAM-Ep;X|R&A$}4c-okxy zoYQlX(6^imcJDgOaTm78#oSCze{>3m-mVRJoP*yS{V(p-0g9+q$vtcI4 zj!Zh1n(0`kjxoGU#W+raJJ|A$_kPRMHnfh=es^iij9p>jZ%3*5isP70c!uKT3tOoSco_WEU{m|I} zV2hHvn_91l0ZuwYKen+$*Z0kbzO}S*Evf6gFMuwQ0wWz80qjx!Zm$~WYwngaufp!r zS}Pk~N!KrlZxGozUtGP~UKn#nz8h_(YoH$!wK!pPsJOsF?Q^nlRIWFU8GbZ8()Nlj2>E@cM*00+-WL_t(|+U=WpNL1Y$ z$3NqYTcNL&WteGcRzwSpZDu8EQ9`y@GAdb_h+tY_nA(QXf=dZa8bOvqi4qiP*`h(2 zjiu2>MHbnVie+h*&XUdK{r%;od0SrWji0YJUpRl9bDwk0eeV6<=X~#T&y~pKazU%r zGH~EP%rN73!@_(C%rFzoj6Mt5pXTuA&!6e)>f-a~&;80TD=RCcQYn^}mS%$WCb?uX z8Sd`x*xK46kx2T5UxFZ@*XvQM)pT}tVr^}0CRlHvtE&rlcXwnm8Smb`>sP)xI5;qR z^k`~pYt0d?HzSyhjZMEJ7eHHE8$*W<6@4^|{9ZzTSr+?>Z-1P~7X$%85c;ieW`das z_U97J(b17jn>I0R+BB@JtoZcl6IE4JWMyTc)9Fws6eK1lVlWuQJ{paN+qZ9%m6b(H zOG}@PgD9XrPL>(@n_xVSiUIvvN4AMd#a+p}j68jXhK%a`Nt@6YPht8sI4BPl6Kw5hGF z#oOCkEDD7JYinzE?AXz#BG}g@E-nr)FE7+;wMn~FDrMKMU6hxX6C51O-o1NSzkWTg zuC54zKyq?28jS{pLP1ni6l2DWAtWTkWDI9#XM%!)FdB{Do%?r}Uxi#QCm|t$-Me=a z5D>tE1q&!FEF?2C6IWMP(ay)m2bD_oYa-v%)04`|O7wa?04*&oBqk=JR4RWs!29>_ zIe-2<6DCaPv(c-ptc=~eccay6P1+|-nuH(-6c-mG2m()^K1HQc;pgWEKzVsNxw*L* z3UZh$Vj52 zqiJhvqpGTkxVSjd)6*#}E#<+32Ymeak^1_2ljv1dRfQl3goTBn(P&t@bSVI9*REyu z?Aer*l>C@r85tSezki>AfB@F4S%ameCD*Q9BTpSnBHPC@3fp=bJNU z4wo)n0^sf2w=7(^khyc`a_7z+^7Hfmd5P?PDz|Le!h!`0h>D8B&d!eP>}=8I>C>n9 z`ugJQ>q}Tz7y!k^#prapKC8k09$C8Udc7WNYiko58yg$+dc9b;x3_2i{{0vX22xW~ z`SRrp5{ZPQq$IMlvuST{7su|Yp32M1Gg-E^S}l2bdH-62?b)*ji9|wcYpY3nQ&SU% z4jm#QA_6}@KMD#8NKQ^>{`~pKWHP+Gyr{0O2H?z@Gvw#zvuf2U%F4<(aNq#LhY$ZT z!G;VO!lFfsOb*u7)p6v=5j;FRu(h@QrgK9>1E)@%A|)lIPbDyac5}Y2tJP}U+}ups z+}+)I@!|!7AYf-_M^;uAH*ek~BO^l;@~*C~xVX3wA0JOqQ4vK&MOa!|l9Q8zkB?7} zNTyUOF&d2+jYgD8)E_{^UovLwr$&3vt|tg1`GgT(4awthllg{@ncc= z{~bq<9>vAQg(XXt^t&bU;lqa*jYd|iSb>Fw1yiO>Vdl)4T)A=ufK8h=p;D97~Fc2FX%Z(d1dVC(4nVDo}X8tz6UcP)uMn(psMvWpgG*l$mzJ2@f z^z=j`kziqA!HgL*@bdEF_U+r>ygjC*q_A@3N&q@KI(YT!)pvu8sKHuWTZxX2CMG6^ zh=>TRtgPtl?4+Wif`o*GAD*mErz1N%n++Q_aP{g{+S}XvoXGDcj8rN`E|(J%6T^iI z7s$%WV*B>(BqSsd85v1yYb)vL=`=JnU}tBCzrQ~QgF(DW-7f*_)~)N6ByUf~*6a18 zq@-~4=uz(7yN6P#M5ED=mX?O2qazj;7O2%~($dmUsZ=B+B(QbsRY{}W*TRP_Ia zdCRmJ<_PvX(bd(}ZzEV&SC^S!y$MT8OSD=ofBp5>KYpR;YjALIK&#c7_vH5`q*5tO zO-(pEJAacQ@9WTNwY+})8mUxjCRlHwJM~guUvIMIsJ}#KsZ@%Um6e%by@~EWZocFlSe9*hg{4+BYBham zYpiccO-i9@nzqr_K5$b7R7~2^+Qfjw78{9$2wJ+p@{rk`-JUx;gKJ9vHSy2ha|QN*x3gBFdZL3>ug zBrXBtEm$vhV7IB|bu~5i+D2?sgnUY9u-h8#724OGja6F9>UDX9c|s0#*4P~OR7Zoe zg7`3+rV?F^P1Sa-tFGEvkrba;=_s$Ou4~XH%2jHEW3x@0wjxa~3jn=BC82cl0#cRN z{x=}ft*&}oxwF=x)vIHnvuPox;!Az4*4e0a)|OYjnImsl3lz221KN^M~ z3&V@U@Z*R{ziNp=pz6c-hQe!JRe(BqjMcn@xp$*oevs3&P*lt$MJA5@XEmcg9Cf z8(?2xj-K<6xy`T?RVv%_c@~(jd;|OXfd+q0SGUX-^E5A_)>DICkv9=q1CncOo}ESZ zv%3e1GcZ63iC6t_PNs`En)?gs^rrJ;lV7ibeUjHZGyADwo+LAjf~kV88>C;@Fk6fc zNmt0ytPhr%w&74>Q7|jiYwOi?Sy;%>4Bn1u`j7#HGkwa04P(2*Stz~u_te;Fb7;Q) z-5wU6$DRv}v{7A_aGak_XRH2jY&Fn^kpEtiB{wSzr$=&;YOz`oVuF?@$qAA(X8;l! zNn#|4ktdNn#i8f);XH}EVyNIQ>H_F>QgSN9L)s=^nN`0W;y`cq7h01MfJrLVh3Yc7 z&QaQeR6^Rc;NL%UoSdCi{S!lb1)<>5xaaH|K_mE&1&f6QIV>86R|i)D@LzUaJI3?o z(L;jMYvZr9TdV^ucy{_;yyYw66L_gu2hlJQigofm80#8A-s5iL_gZ=WlTMx&dUuNV zV?`4CCZ3>kJx4k2;7^F84=!;UZaU}p{Tz4VJSP@%v0UJQJK7!C&qZ-k5gCHW>W5WX zb2pJ4>A~xi>HBVhd+GLiqKo4Kt!|Aw(8@*M*V%7x#Df=yW7+q65P42sWZ4Z@zY|!# ze>=;H1#CR)JLPttVi&Pep)%O$2#a~1>p8+OwW9=ev@q-bXhtNxJUK#-_=9)0Gw}@l zZ45K7DL!)n`3a)oh7WVKQ)Ns?8-oF2K9it?-NF0F8Z?Tcz z-n>k(+)d}Z{~Wq(#`e86uzu=XJ%?~+&lxy*7U1w3un5N2wp{aF-vQ9M1>U+y4K)ZKzgMBb-vEFs$cN~+t0LjVDs*~&^Az%o>4VX^YIaYFWv?? z(MkMMB^k$WdZ+uE;ARPc^_P*MAJ^fTIDi(J|3h7W%}3zrJ*5oIY`UeD5 BR>lAT literal 0 HcmV?d00001 diff --git a/doc/img/SoapySDR_range_gain.png b/doc/img/SoapySDR_range_gain.png new file mode 100644 index 0000000000000000000000000000000000000000..d62ace47d7c27f60142c342e348c49c67550b97b GIT binary patch literal 2116 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 literal 0 HcmV?d00001 diff --git a/doc/img/SoapySDR_range_neg.png b/doc/img/SoapySDR_range_neg.png new file mode 100644 index 0000000000000000000000000000000000000000..d25f4e3835657216ad679cd386a4bab3dd14bb94 GIT binary patch literal 2892 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 RI^Zz=Tk3D&oc^cO{{fj(<0}9F literal 0 HcmV?d00001 diff --git a/doc/img/SoapySDR_range_pos.png b/doc/img/SoapySDR_range_pos.png new file mode 100644 index 0000000000000000000000000000000000000000..7b42b8ef40d98422354c8436ac408689da4ad8d5 GIT binary patch literal 3334 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 LW29ZK=^XvP2|0Rs literal 0 HcmV?d00001 diff --git a/doc/img/SoapySDR_range_pos.xcf b/doc/img/SoapySDR_range_pos.xcf new file mode 100644 index 0000000000000000000000000000000000000000..37c687b23a5be5cc9ff94f8bb1d69349c77ec6fa GIT binary patch literal 12708 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 literal 0 HcmV?d00001 diff --git a/plugins/channelrx/chanalyzer/chanalyzerplugin.cpp b/plugins/channelrx/chanalyzer/chanalyzerplugin.cpp index 8dcb43823..60aa4b978 100644 --- a/plugins/channelrx/chanalyzer/chanalyzerplugin.cpp +++ b/plugins/channelrx/chanalyzer/chanalyzerplugin.cpp @@ -23,7 +23,7 @@ const PluginDescriptor ChannelAnalyzerPlugin::m_pluginDescriptor = { QString("Channel Analyzer"), - QString("4.2.4"), + QString("4.3.0"), QString("(c) Edouard Griffiths, F4EXB"), QString("https://github.com/f4exb/sdrangel"), true, diff --git a/plugins/channelrx/demodatv/atvdemodplugin.cpp b/plugins/channelrx/demodatv/atvdemodplugin.cpp index f728462f5..bd1efedba 100644 --- a/plugins/channelrx/demodatv/atvdemodplugin.cpp +++ b/plugins/channelrx/demodatv/atvdemodplugin.cpp @@ -27,7 +27,7 @@ const PluginDescriptor ATVDemodPlugin::m_ptrPluginDescriptor = { QString("ATV Demodulator"), - QString("4.2.4"), + QString("4.3.0"), QString("(c) F4HKW for F4EXB / SDRAngel"), QString("https://github.com/f4exb/sdrangel"), true, diff --git a/plugins/samplesource/soapysdrinput/readme.md b/plugins/samplesource/soapysdrinput/readme.md new file mode 100644 index 000000000..55191f7d6 --- /dev/null +++ b/plugins/samplesource/soapysdrinput/readme.md @@ -0,0 +1,208 @@ +

SoapySDR input plugin

+ +

Introduction

+ +This input sample source plugin gets its samples from a device interfaced with [SoapySDR](https://github.com/pothosware/SoapySDR/wiki). + +SoapySDR is a [C/C++ API](https://github.com/pothosware/SoapySDR/blob/master/include/SoapySDR/Device.hpp) that interfaces SDR hardware on one side and application software on the other. Due to its very generic nature it was fairly difficult to implement and specific UI widgets were developped to handle specific types of parameters. The level of control depends on how the device API was implemented by the vendors. On application side some parts of the API have not been implemented and can be left as possible enhancements (see next). In any case it is recommended to use the native plugins if they are available. + +

Binary distributions

+ +The binary distributions provide only the SoapySDR base library. It is your responsibility to install SoapySDR in your system with the SoapySDR plugins suitable for your hardware. + +

SoapySDR API implementation

+ +Not all parts are implemented. Currently the following have been left out: + + - Frequency API tuning arguments. The tuning elements are of course supported. + - Clocking API + - Time API + - Sensor API + - Register API + - GPIO API + - I2C API + - SPI API + - UART API + +

Particular considerations concerning hardware

+ +In general as previously stated you should choose the native plugins if they are available. These are: + + - Airspy + - AirspyHF + - BladeRF + - HackRF + - LimeSDR + - PlutoSDR + - RTLSDR + - SDRplay RSP1 + +The following paragraphs list the known issues or oddities. + +

BladeRF

+ +It is very important NOT to use SoapySDR. The default parameters are set to flash the FPGA but as this does not suceeds it results in a FPGA image wipe out and the device returns in "Cypress" mode. It is not too difficult to recover but there is no point risking the hassle. + +

SDRplay RSP2

+ +Do not use sample rates lower than 2 MS/s + +

Red Pitaya

+ +When installed the Red Pitaya SoapySDR plugin lists a Red Pitaya device even if there is no Red Pitaya attached. Trying to select and start it when there is no Red Pitaya will result in program crash. + +

Interface

+ +![SoapySDR input plugin GUI](../../../doc/img/SoapySDRInput_plugin1.png) + +The top part described by number tags is common for all devices. The bottom part under the "A" tag depends on the SoapySDR device implementation. The corresponding widgets are stacked vertically inside a scrollable area as there may be many controls depending on how the device interface is implemented in SoapySDR. Move the slider on the right to see all parameters available. + +

1: Common stream parameters

+ +![SDR Daemon source input stream GUI](../../../doc/img/SDRdaemonSource_plugin_01.png) + +

1.1: Frequency

+ +This is the center frequency of reception in kHz. The center frequency is the same for all Rx channels. The GUI of the sibling channel if present is adjusted automatically. This control corresponds to the first SoapySDR tuning element usually labeled as "RF" and would generally control the main local oscillator (LO). + +Use the wheels to adjust the value. Left click on a digit sets the cursor position at this digit. Right click on a digit sets all digits on the right to zero. This effectively floors value at the digit position. Wheels are moved with the mousewheel while pointing at the wheel or by selecting the wheel with the left mouse click and using the keyboard arrows. Pressing shift simultaneously moves digit by 5 and pressing control moves it by 2. + +

1.2: Start/Stop

+ +Device start / stop button. + + - Blue triangle icon: device is ready and can be started + - Green square icon: device is running and can be stopped + - Magenta (or pink) square icon: an error occurred. In the case the device was accidentally disconnected you may click on the icon, plug back in and start again. Check the console log for possible errors. + +

1.3: Record

+ +Record baseband I/Q stream toggle button + +

1.4: Stream sample rate

+ +Baseband I/Q sample rate in kS/s. This is the device sample rate (the "SR" SoapySDR control) divided by the decimation factor (4). + +

2: Software auto correction options

+ +These buttons control the SDRangel internal DSP auto correction options: + + - **DC**: auto remove DC component + - **IQ**: auto make I/Q balance. The DC correction must be enabled for this to be effective. + +

3: Baseband center frequency position relative the LO center frequency

+ +Possible values are: + + - **Cen**: the decimation operation takes place around the LO frequency Fs + - **Inf**: the decimation operation takes place around Fs - Fc. + - **Sup**: the decimation operation takes place around Fs + Fc. + +With SR as the sample rate before decimation Fc is calculated as: + + - if decimation n is 4 or lower: Fc = SR/2^(log2(n)-1). The device center frequency is on the side of the baseband. You need a RF filter bandwidth at least twice the baseband. + - if decimation n is 8 or higher: Fc = SR/n. The device center frequency is half the baseband away from the side of the baseband. You need a RF filter bandwidth at least 3 times the baseband. + +

4: Decimation factor

+ +The I/Q stream from the SoapySDR I/Q stream is downsampled by a power of two before being sent to the passband. Possible values are increasing powers of two: 1 (no decimation), 2, 4, 8, 16, 32, 64. + +

5: Transverter mode open dialog

+ +This button opens a dialog to set the transverter mode frequency translation options: + +![Input stream transverter dialog](../../../doc/img/RTLSDR_plugin_xvrt.png) + +Note that if you mouse over the button a tooltip appears that displays the translating frequency and if translation is enabled or disabled. When the frequency translation is enabled the button is lit. + +

5.1: Translating frequency

+ +You can set the translating frequency in Hz with this dial. The manipulation of the dial is described in (1.1: Frequency). + +The frequency set in the device is the frequency on the main dial (1) minus this frequency. Thus it is positive for down converters and negative for up converters. + +For example a mixer at 120 MHz for HF operation you would set the value to -120,000,000 Hz so that if the main dial frequency is set at 7,130 kHz the PlutoSDR will be set to 127.130 MHz. + +If you use a down converter to receive the 6 cm band narrowband center frequency of 5670 MHz at 432 MHz you would set the translating frequency to 5760 - 432 = 5328 MHz thus dial +5,328,000,000 Hz. + +For bands even higher in the frequency spectrum the GHz digits are not really significant so you can have them set at 1 GHz. Thus to receive the 10368 MHz frequency at 432 MHz you would set the translating frequency to 1368 - 432 = 936 MHz. Note that in this case the frequency of the LO used in the mixer of the transverter is set at 9936 MHz. + +The Hz precision allows a fine tuning of the transverter LO offset + +

5.2: Translating frequency enable/disable

+ +Use this toggle button to activate or deactivate the frequency translation + +

5.3: Confirmation buttons

+ +Use these buttons to confirm ("OK") or dismiss ("Cancel") your changes. + +

6: Software LO ppm correction

+ +Use this slider to adjust SDRangel internal LO correction in ppm. It can be varied from -100.0 to 100.0 in 0.1 steps and is applied in software when calculating the frequency at which the LO should be set. + +

A: SoapySDR variable interface

+ +The form of widgets is closely related to the type of setting defined in the [SoapySDR interface](https://github.com/pothosware/SoapySDR/blob/master/include/SoapySDR/Types.hpp). These are: + + - Ranges + - Continuous range when maximum and minimum are different + - Discrete value when maximum and minimum are equal. Usually this appears in a range list to define a set of values + - List of ranges: more than one range applies to the same setting + - Arguments defined by + - type: boolean, integer, floating point, string + - nature: continuous or discrete + - String list + +

A.1: Continuous range

+ +If the range is all in the positive domain the unsigned variation is used: + +![SoapySDR input plugin GUI](../../../doc/img/SoapySDR_range_pos.png) + +Note that the same widget is used for single ranges and ranges list. In this case the range selection combo on the right is disabled. The manipulation of the dial is described in (1.1: Frequency) + +If the range is in both the positive and negative domains the signed variation is used: + +![SoapySDR input plugin GUI](../../../doc/img/SoapySDR_range_neg.png) + +If the range applies to a gain a slider is used: + +![SoapySDR input plugin GUI](../../../doc/img/SoapySDR_range_gain.png) + +

A.2: Discrete range

+ +Appears with a combo box to select a discrete value: + +![SoapySDR input plugin GUI](../../../doc/img/SoapySDR_range_discrete.png) + +

A.3: List of ranges

+ +In this case the range selection combo on the right is enabled: + +![SoapySDR input plugin GUI](../../../doc/img/SoapySDR_range_list1.png) + +

A.4: Boolean argument

+ +A checkbox is used to control boolean values: + +![SoapySDR input plugin GUI](../../../doc/img/SoapySDR_arg_bool2.png) + +For AGC, Auto DC and Auto IQ corrections a block with the text on the rihgt: + +![SoapySDR input plugin GUI](../../../doc/img/SoapySDR_arg_bool1.png) + +

A.5: Int, Float and String arguments

+ +For all these types of values a line editor is used. Numerical values are parsed from string: + +![SoapySDR input plugin GUI](../../../doc/img/SoapySDR_arg_str.png) + +

A.6 String lists

+ +Some parameters like the antenna ports are expressed as a list of possible string values. These are presented in a combo box: + +![SoapySDR input plugin GUI](../../../doc/img/SoapySDR_arg_strlist.png) + + +