-
-
Notifications
You must be signed in to change notification settings - Fork 656
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
TX power issues #33
Comments
One more thing: LMIC should really allow selecting between PA_BOOST or RFO outputs, since most hardware only has either of them connected. |
Hi Matthijs, Just wondering, have there been any updates/fixes to setting the Tx power correctly? We're currently conducting experiments at 915MHz on the SX1272, and want to be able to control the Tx power. Regards, |
@pprasan, no progress yet, but I think @tftelkamp was planning to have a look at this soon. |
Hello @matthijskooijman! Thank you for the project! |
AFAIK no progress has been made on this issue so far, the code still needs a thorough cleanup. Additionally jmarcelino reported on slack that the RegPaDac register number is defined as 0x5A but it should be 0x4D. However, since the only value written to that register is the same as the default value, and since 0x5A is an unused address, operation is unaffected. |
Hi @matthijskooijman! Any news about this? Is it still hardcoded or was someone able to change it? |
When i was checking different power settings on my test node today, and comparing the LMiC code with SX1276 data sheet, i came to the same findings as stated in the beginning of this thread. For me the actual code seems clearly wrong, since on SX1276 it always sets PA output to the PA_BOOST pin. This is forced by OR-ing the value that is to be written to RegPaConfig register with 0x80:
I guess this can't work on board hardware which does not wire the PA_BOOST Pin #27 of SX1276, only using RFO_LF / RFO_HF (Pin #28 / #22) instead? How do we take care of this issue? |
I opened issue in the IBM's repo on this. |
…e and txPower before performing the join. Setting the txPower via the parameter has currently no effect, as only the LMIC.adrTxPow is changed. [1] Modifications in lmic.h and lmic.c are labelled with an <!EDITED> comment. [1] matthijskooijman#33
Hello, I am still hoping to change the power on my RFM95W using LMIC and I appear to be experiencing the same issue. Is there any reason this has not yet been addressed? |
Currently, the library allows setting the TX power using
LMIC_setDrTxpow()
. This sets theLMIC.adrTxPow
field, but this field is never actually used anywhere.The actual tx power to use is kept in
LMIC.txpow
and is currently defined per-band for 868 and hardcoded for 900 (seeupdateTx()
for both).However, the actual writing of the registers in
configPower()
seems inconsistent. The comments say that PA_BOOST is used for SX1272 and RFO for SX1276, but then for both the PaSelect bit (0x80) is set in RegPaConfig to select PA_BOOST.However, the corresponding value in RegPaDac, which should be 0x7 for PA_BOOST is set to 0x4 (for RFO), or left at the default of 0x4.Correction: RegPaDac should be set to 0x7 only for +20dBm operation (which requires additional care), with RegPaDac PA_BOOST is limited to +17dBm.Then, the cropping of the txpow value for 1276 seems wrong, if txpow is 16, it effectively becomes 0 instead of 15 (due to the
& 0xf
masking). The lower limit is set to 2, but if PA_BOOST is indeed not used, this should be 0.Finally, the txpower -> register setting calculation is wrong, assuming no PA_BOOST is used. The datasheet says:
If MaxPower == 7, then Pmax = 15 and Pout = OutputPower (just like with SX1272, which does not have MaxPower). The calculation seems to assume this, but it sets MaxPower to 0.
However, since PaSelect is actually set (using PA_BOOST), the real calculation should be txpow-2 (as for 1272). Effectively, I believe this means that for the 0.1% and 1% bands, LMIC on a 17276 currently transmits at 16dBm instead of the intended 14dBm.
The text was updated successfully, but these errors were encountered: