auto detect twin module
This commit is contained in:
parent
f2c51b1549
commit
c580696dc1
4 changed files with 52 additions and 22 deletions
10
emoncms.py
10
emoncms.py
|
@ -1,6 +1,7 @@
|
||||||
#!/usr/bin/env python2.7
|
#!/usr/bin/env python2.7
|
||||||
|
|
||||||
import rfm69
|
import rfm69
|
||||||
|
from rfm69 import Rfm69
|
||||||
import sensors
|
import sensors
|
||||||
from sensors import rawsensor
|
from sensors import rawsensor
|
||||||
import time
|
import time
|
||||||
|
@ -66,7 +67,14 @@ def LogSensor(data):
|
||||||
return
|
return
|
||||||
print "No match for ID"
|
print "No match for ID"
|
||||||
|
|
||||||
rfm = rfm69.Rfm69()
|
|
||||||
|
if Rfm69.Test(1):
|
||||||
|
rfm = Rfm69(1, 24) #when using the RaspyRFM twin
|
||||||
|
elif Rfm69.Test(0):
|
||||||
|
rfm = Rfm69() #when using a single single 868 MHz RaspyRFM
|
||||||
|
else:
|
||||||
|
print "No RFM69 module found!"
|
||||||
|
exit()
|
||||||
|
|
||||||
rfm.SetParams(
|
rfm.SetParams(
|
||||||
Freq = 868.300, #MHz center frequency
|
Freq = 868.300, #MHz center frequency
|
||||||
|
|
10
fs20tx.py
10
fs20tx.py
|
@ -6,8 +6,14 @@ import sensors
|
||||||
import sys
|
import sys
|
||||||
import time
|
import time
|
||||||
|
|
||||||
rfm = Rfm69() #when using a single single 868 MHz RaspyRFM
|
if Rfm69.Test(1):
|
||||||
#rfm = Rfm69(1, 24) #when using the RaspyRFM twin
|
rfm = Rfm69(1, 24) #when using the RaspyRFM twin
|
||||||
|
elif Rfm69.Test(0):
|
||||||
|
rfm = Rfm69() #when using a single single 868 MHz RaspyRFM
|
||||||
|
else:
|
||||||
|
print "No RFM69 module found!"
|
||||||
|
exit()
|
||||||
|
|
||||||
rfm.SetParams(
|
rfm.SetParams(
|
||||||
Freq = 868.350,
|
Freq = 868.350,
|
||||||
Datarate = 5.0,
|
Datarate = 5.0,
|
||||||
|
|
|
@ -7,7 +7,13 @@ from sensors import rawsensor
|
||||||
import sys
|
import sys
|
||||||
import time
|
import time
|
||||||
|
|
||||||
rfm = Rfm69()
|
if Rfm69.Test(1):
|
||||||
|
rfm = Rfm69(1, 24) #when using the RaspyRFM twin
|
||||||
|
elif Rfm69.Test(0):
|
||||||
|
rfm = Rfm69() #when using a single single 868 MHz RaspyRFM
|
||||||
|
else:
|
||||||
|
print "No RFM69 module found!"
|
||||||
|
exit()
|
||||||
|
|
||||||
rfm.SetParams(
|
rfm.SetParams(
|
||||||
Freq = 868.312, #MHz center frequency
|
Freq = 868.312, #MHz center frequency
|
||||||
|
|
44
rfm69.py
44
rfm69.py
|
@ -99,29 +99,39 @@ MODE_TX = 3
|
||||||
MODE_RX = 4
|
MODE_RX = 4
|
||||||
|
|
||||||
class Rfm69:
|
class Rfm69:
|
||||||
|
@staticmethod
|
||||||
|
def Test(cs):
|
||||||
|
spi = spidev.SpiDev()
|
||||||
|
spi.open(0, cs)
|
||||||
|
#Testing presence of module
|
||||||
|
err = False
|
||||||
|
for i in range(0, 8):
|
||||||
|
spi.xfer2([(RegSyncValue1 + i) | 0x80, 0x55])
|
||||||
|
test = spi.xfer2([(RegSyncValue1 + i), 0x00])[1]
|
||||||
|
if test != 0x55:
|
||||||
|
err = True
|
||||||
|
break
|
||||||
|
temp = spi.xfer2([(RegSyncValue1 + i) | 0x80, 0xAA])
|
||||||
|
test = spi.xfer2([(RegSyncValue1 + i), 0x00])[1]
|
||||||
|
if test != 0xAA:
|
||||||
|
err = True
|
||||||
|
break
|
||||||
|
spi.close()
|
||||||
|
return not err
|
||||||
|
|
||||||
|
|
||||||
def __init__(self, cs = 0, gpio_int = 25):
|
def __init__(self, cs = 0, gpio_int = 25):
|
||||||
|
if not Rfm69.Test(cs):
|
||||||
|
print "ERROR! RFM69 not found"
|
||||||
|
return
|
||||||
|
|
||||||
self.__event = threading.Event()
|
self.__event = threading.Event()
|
||||||
self.__spi = spidev.SpiDev()
|
self.__spi = spidev.SpiDev()
|
||||||
self.__spi.open(0, cs)
|
self.__spi.open(0, cs)
|
||||||
self.__spi.max_speed_hz=int(5E6)
|
self.__spi.max_speed_hz=int(5E6)
|
||||||
self.__gpio_int = gpio_int
|
self.__gpio_int = gpio_int
|
||||||
|
|
||||||
#Testing presence of module
|
print "RFM69 found on CS", cs
|
||||||
err = False
|
|
||||||
for i in range(0, 8):
|
|
||||||
self.__WriteReg(RegSyncValue1 + i, 0x55)
|
|
||||||
if self.ReadReg(RegSyncValue1 + i) != 0x55:
|
|
||||||
err = True
|
|
||||||
break
|
|
||||||
self.__WriteReg(RegSyncValue1 + i, 0xAA)
|
|
||||||
if self.ReadReg(RegSyncValue1 + i) != 0xAA:
|
|
||||||
err = True
|
|
||||||
break
|
|
||||||
if err == True:
|
|
||||||
print "ERROR! RFM69 not found!"
|
|
||||||
return
|
|
||||||
|
|
||||||
print "RFM69 found!"
|
|
||||||
GPIO.setmode(GPIO.BCM)
|
GPIO.setmode(GPIO.BCM)
|
||||||
GPIO.setup(gpio_int, GPIO.IN)
|
GPIO.setup(gpio_int, GPIO.IN)
|
||||||
GPIO.add_event_detect(gpio_int, GPIO.RISING, callback=self.__RfmIrq)
|
GPIO.add_event_detect(gpio_int, GPIO.RISING, callback=self.__RfmIrq)
|
||||||
|
@ -196,7 +206,7 @@ class Rfm69:
|
||||||
print("INIT COMPLETE")
|
print("INIT COMPLETE")
|
||||||
|
|
||||||
def __RfmIrq(self, ch):
|
def __RfmIrq(self, ch):
|
||||||
self.__event.set();
|
self.__event.set()
|
||||||
|
|
||||||
def __WriteReg(self, reg, val):
|
def __WriteReg(self, reg, val):
|
||||||
temp = self.__spi.xfer2([(reg & 0x7F) | 0x80, val & 0xFF])
|
temp = self.__spi.xfer2([(reg & 0x7F) | 0x80, val & 0xFF])
|
||||||
|
|
Loading…
Reference in a new issue