Driver library for SX1272/SX1276 transceivers

Fork of SX127x by wayne roberts

Revision:
4:d987ac2836bf
Parent:
2:fdae76e1215e
Child:
6:5d94ee847016
diff -r 3bf2515b1eed -r d987ac2836bf sx127x.cpp
--- a/sx127x.cpp	Fri May 02 01:18:59 2014 +0000
+++ b/sx127x.cpp	Fri May 02 23:35:30 2014 +0000
@@ -42,22 +42,20 @@
     RegDioMapping1.octet = read_reg(REG_DIOMAPPING1);
     RegDioMapping2.octet = read_reg(REG_DIOMAPPING2);
     
-    if (!RegOpMode.bits.LongRangeMode) {
+/*    if (!RegOpMode.bits.LongRangeMode) {
         if (RegOpMode.bits.Mode != RF_OPMODE_SLEEP)
             set_opmode(RF_OPMODE_SLEEP);
         RegOpMode.bits.LongRangeMode = 1;
         write_reg(REG_OPMODE, RegOpMode.octet);
-    }
-    
-
+    }*/
     
     get_type();
     
-    // turn on PA BOOST, eval boards are wired for this connection
-    RegPaConfig.bits.PaSelect = 1;
-    write_reg(REG_PACONFIG, RegPaConfig.octet);
-    
-
+    if (type == SX1272) {
+        // turn on PA BOOST, eval boards are wired for this connection
+        RegPaConfig.bits.PaSelect = 1;
+        write_reg(REG_PACONFIG, RegPaConfig.octet);
+    }
 }
 
 void SX127x::get_type()
@@ -148,7 +146,18 @@
     return ret;
 }
 
-void SX127x::write_reg_u24(uint8_t addr, uint32_t data)
+void SX127x::write_u16(uint8_t addr, uint16_t data)
+{
+    m_cs = 0;   // Select the device by seting chip select low
+
+    m_spi.write(addr | 0x80); // bit7 is high for writing to radio
+    m_spi.write((data >> 8) & 0xff);
+    m_spi.write(data & 0xff);
+ 
+    m_cs = 1;   // Deselect the device
+}
+
+void SX127x::write_u24(uint8_t addr, uint32_t data)
 {
     m_cs = 0;   // Select the device by seting chip select low
 
@@ -203,7 +212,7 @@
     uint32_t frf;
     
     frf = MHz / FREQ_STEP_MHZ;
-    write_reg_u24(REG_FRFMSB, frf);
+    write_u24(REG_FRFMSB, frf);
     
     if (MHz < 525)
         HF = false;