add MAX! receiving

add variable packet length
This commit is contained in:
S. Seegel 2020-02-06 20:23:11 +00:00
parent 160cf40b99
commit d61c88d4dc
2 changed files with 47 additions and 35 deletions

View file

@ -1,7 +1,6 @@
#!/usr/bin/env python2.7 #!/usr/bin/env python2.7
from rfm69 import Rfm69 from raspyrfm import *
import rfm69
import sys import sys
import time import time
import threading import threading
@ -16,23 +15,23 @@ devices = {
'0x1ac36b': 'HeatWohnL', '0x1ac36b': 'HeatWohnL',
} }
if Rfm69.Test(1): if raspyrfm_test(2, RFM69):
print("Found RaspyRFM twin") print("Found RaspyRFM twin")
rfm = Rfm69(1, 24) #when using the RaspyRFM twin rfm = RaspyRFM(2, RFM69) #when using the RaspyRFM twin
elif Rfm69.Test(0): elif raspyrfm_test(1, RFM69):
print("Found RaspyRFM single") print("Found RaspyRFM single")
rfm = Rfm69() #when using a single single 868 MHz RaspyRFM rfm = RaspyRFM(1, RFM69) #when using a single single 868 MHz RaspyRFM
else: else:
print("No RFM69 module found!") print("No RFM69 module found!")
exit() exit()
rfm.SetParams( rfm.set_params(
Freq = 868.300, #MHz center frequency Freq = 868.300, #MHz center frequency
ModulationType = rfm69.FSK, #modulation ModulationType = rfm69.FSK, #modulation
Datarate = 9.992, #kbit/s baudrate Datarate = 9.992, #kbit/s baudrate
Deviation = 19.042, #kHz frequency deviation Deviation = 19.042, #kHz frequency deviation
SyncPattern = [0xc6, 0x26, 0xc6, 0x26], #syncword SyncPattern = [0xc6, 0x26, 0xc6, 0x26], #syncword
Bandwidth = 100, #kHz bandwidth Bandwidth = 150, #kHz bandwidth
RssiThresh = -105, #dBm RSSI threshold RssiThresh = -105, #dBm RSSI threshold
) )
@ -45,10 +44,10 @@ class RxThread(threading.Thread):
self.__rfm = rfm self.__rfm = rfm
threading.Thread.__init__(self) threading.Thread.__init__(self)
def __callback(self): def __callback(self, rfm):
frame = rfm.ReadFifoWait(1) frame = rfm.read_fifo_wait(1)
len = frame[0] ^ 0xFF #invert due to whitening len = frame[0] ^ 0xFF #invert due to whitening
frame += rfm.ReadFifoWait(len) frame += rfm.read_fifo_wait(len)
rxMutex.acquire() rxMutex.acquire()
rxFifo.append(frame) rxFifo.append(frame)
@ -57,7 +56,7 @@ class RxThread(threading.Thread):
def run(self): def run(self):
while True: while True:
self.__rfm.StartRx(self.__callback) self.__rfm.start_receive(self.__callback)
rxThread = RxThread(rfm) rxThread = RxThread(rfm)
@ -122,7 +121,7 @@ while True:
left = len(rxFifo) > 0 left = len(rxFifo) > 0
rxMutex.release() rxMutex.release()
rfm.WhitenTI(frame) rfm.whiten_ti(frame)
Decode(frame) Decode(frame)
if not left: if not left:
break break

View file

@ -43,22 +43,22 @@ FSTEP = FXOSC / (1<<19)
# RaspyRFM twin module with 12-pin connector # RaspyRFM twin module with 12-pin connector
# Connect to pins 15-26 on raspberry pi # Connect to pins 15-26 on raspberry pi
#-------------------------------------------------# #---------------------------------#
# Raspi | Raspi | Raspi | RFM69 | RFM12 | PCB con # #Raspi|Raspi|Raspi|RFM69 |RaspyRFM#
# Name | GPIO | Pin | Name | Name | Pin # #Name |GPIO |Pin |Name |PCB Pin #
#-------------------------------------------------# #---------------------------------#
# - | 22 | 15 | DIO2_2| | 1 # # - | 22 | 15 |DIO2_2| 1 #
# - | 23 | 16 | DIO2_1| | 2 # # - | 23 | 16 |DIO2_1| 2 #
# 3V3 | - | 17 | 3.3V | VDD | 3 # #3V3 | - | 17 |3.3V | 3 #
# - | 24 | 18 | DIO0_2| FFIT | 4 # # - | 24 | 18 |DIO0_2| 4 #
# MOSI | 10 | 19 | MOSI | SDI | 5 # #MOSI | 10 | 19 |MOSI | 5 #
# GND | - | 20 | GND | GND | 6 # #GND | - | 20 |GND | 6 #
# MISO | 9 | 21 | MISO | SDO | 7 # #MISO | 9 | 21 |MISO | 7 #
# - | 25 | 22 | DIO0_1| nIRQ | 8 # # - | 25 | 22 |DIO0_1| 8 #
# SCKL | 11 | 23 | SCK | SCK | 9 # #SCKL | 11 | 23 |SCK | 9 #
# CE0 | 8 | 24 | NSS1 | nSEL | 10 # #CE0 | 8 | 24 |NSS1 | 10 #
# CE1 | 7 | 26 | NSS2 | nFFS | 12 # #CE1 | 7 | 26 |NSS2 | 12 #
#-------------------------------------------------# #---------------------------------#
#RFM69 registers #RFM69 registers
#common registers #common registers
@ -152,6 +152,10 @@ DIO0_PM_SENT = 0
DIO0_PM_TXDONE = 1 DIO0_PM_TXDONE = 1
DIO0_PM_PLLLOCK = 3 DIO0_PM_PLLLOCK = 3
#Packet format
PacketFormat_Fixed = 0
PacketFormat_Variable = 1
class Rfm69(threading.Thread): class Rfm69(threading.Thread):
@staticmethod @staticmethod
def test(cs, gpio_dio0): def test(cs, gpio_dio0):
@ -187,6 +191,7 @@ class Rfm69(threading.Thread):
self.__mutex = threading.Lock() self.__mutex = threading.Lock()
self.__syncsize = 4 self.__syncsize = 4
self.__fifothresh = 32 self.__fifothresh = 32
self.__packet_format = PacketFormat_Fixed
print("RFM69 found on CS " + str(cs)) print("RFM69 found on CS " + str(cs))
GPIO.setmode(GPIO.BCM) GPIO.setmode(GPIO.BCM)
@ -407,6 +412,10 @@ class Rfm69(threading.Thread):
elif key == "OokPeakThreshDec": elif key == "OokPeakThreshDec":
self.__set_reg(RegOokPeak, 7<<0, value) self.__set_reg(RegOokPeak, 7<<0, value)
elif key == "PacketFormat":
self.__set_reg(RegPacketConfig1, 1<<7, value<<7)
self.__packet_format = value
else: else:
print("Unrecognized option >>" + key + "<<") print("Unrecognized option >>" + key + "<<")
@ -451,7 +460,9 @@ class Rfm69(threading.Thread):
while (status & 0x40 == 0x40): while (status & 0x40 == 0x40):
self.read_reg(RegFifo) self.read_reg(RegFifo)
status = self.read_reg(RegIrqFlags2) status = self.read_reg(RegIrqFlags2)
if self.__packet_format == PacketFormat_Variable:
data.insert(0, len(data))
else:
self.__write_reg(RegPayloadLength, 0) #unlimited length self.__write_reg(RegPayloadLength, 0) #unlimited length
self.__write_reg(RegFifoThresh, 0x80 | self.__fifothresh) #start TX with 1st byte in FIFO self.__write_reg(RegFifoThresh, 0x80 | self.__fifothresh) #start TX with 1st byte in FIFO
self.__set_dio_mapping(0, DIO0_PM_SENT) #DIO0 -> PacketSent self.__set_dio_mapping(0, DIO0_PM_SENT) #DIO0 -> PacketSent
@ -518,10 +529,10 @@ class Rfm69(threading.Thread):
self.__mutex.release() self.__mutex.release()
return thresh return thresh
def __start_rx(self): def __start_rx(self, length):
self.__mutex.acquire() self.__mutex.acquire()
while True: while True:
self.__write_reg(RegPayloadLength, 0) #unlimited length self.__write_reg(RegPayloadLength, length)
self.__write_reg(RegFifoThresh, self.__fifothresh) self.__write_reg(RegFifoThresh, self.__fifothresh)
if self.__syncsize > 0: if self.__syncsize > 0:
self.__set_dio_mapping(0, DIO0_PM_SYNC) #DIO0 -> SyncAddress self.__set_dio_mapping(0, DIO0_PM_SYNC) #DIO0 -> SyncAddress
@ -535,13 +546,15 @@ class Rfm69(threading.Thread):
break; break;
def start_receive(self, cb): def start_receive(self, cb):
self.__start_rx() self.__start_rx(0)
cb(self) cb(self)
self.mode_standby() self.mode_standby()
self.__mutex.release() self.__mutex.release()
def receive(self, length): def receive(self, length):
self.__start_rx() self.__start_rx(length)
if self.__packet_format == PacketFormat_Variable:
length = self.read_fifo_wait(1)[0]
result = self.read_fifo_wait(length) result = self.read_fifo_wait(length)
rssi = -self.read_reg(RegRssiValue) / 2 rssi = -self.read_reg(RegRssiValue) / 2