Implement a secure ICS protocol targeting LoRa Node151 microcontroller for controlling irrigation.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

90 lines
2.9 KiB

  1. # Copyright 2021 John-Mark Gurney.
  2. #
  3. # Redistribution and use in source and binary forms, with or without
  4. # modification, are permitted provided that the following conditions
  5. # are met:
  6. # 1. Redistributions of source code must retain the above copyright
  7. # notice, this list of conditions and the following disclaimer.
  8. # 2. Redistributions in binary form must reproduce the above copyright
  9. # notice, this list of conditions and the following disclaimer in the
  10. # documentation and/or other materials provided with the distribution.
  11. #
  12. # THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
  13. # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  14. # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  15. # ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
  16. # FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  17. # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  18. # OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  19. # HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  20. # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  21. # OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  22. # SUCH DAMAGE.
  23. #
  24. from ctypes import Structure, POINTER, CFUNCTYPE, pointer
  25. from ctypes import c_uint8, c_uint16, c_ssize_t, c_size_t, c_uint64, c_int
  26. from ctypes import CDLL
  27. class PktBuf(Structure):
  28. _fields_ = [
  29. ('pkt', POINTER(c_uint8)),
  30. ('pktlen', c_uint16),
  31. ]
  32. def _from(self):
  33. return bytes(self.pkt[:self.pktlen])
  34. def __repr__(self): #pragma: no cover
  35. return 'PktBuf(pkt=%s, pktlen=%s)' % (repr(self._from()),
  36. self.pktlen)
  37. def make_pktbuf(s):
  38. pb = PktBuf()
  39. if isinstance(s, bytearray):
  40. obj = s
  41. pb.pkt = pointer(c_uint8.from_buffer(s))
  42. else:
  43. obj = (c_uint8 * len(s))(*s)
  44. pb.pkt = obj
  45. pb.pktlen = len(s)
  46. pb._make_pktbuf_ref = (obj, s)
  47. return pb
  48. process_msgfunc_t = CFUNCTYPE(None, PktBuf, POINTER(PktBuf))
  49. _lib = CDLL('liblora_test.dylib')
  50. _lib._strobe_state_size.restype = c_size_t
  51. _lib._strobe_state_size.argtypes = ()
  52. _strobe_state_u64_cnt = (_lib._strobe_state_size() + 7) // 8
  53. class CommsState(Structure):
  54. _fields_ = [
  55. # The alignment of these may be off
  56. ('cs_state', c_uint64 * _strobe_state_u64_cnt),
  57. ('cs_comm_state', c_int),
  58. ('cs_start', c_uint64 * _strobe_state_u64_cnt),
  59. ('cs_procmsg', process_msgfunc_t),
  60. ('cs_prevmsg', PktBuf),
  61. ('cs_prevmsgresp', PktBuf),
  62. ('cs_prevmsgbuf', c_uint8 * 64),
  63. ('cs_prevmsgrespbuf', c_uint8 * 64),
  64. ]
  65. for func, ret, args in [
  66. ('comms_init', None, (POINTER(CommsState), process_msgfunc_t, POINTER(PktBuf))),
  67. ('comms_process', None, (POINTER(CommsState), PktBuf, POINTER(PktBuf))),
  68. ('strobe_seed_prng', None, (POINTER(c_uint8), c_ssize_t)),
  69. ]:
  70. f = getattr(_lib, func)
  71. f.restype = ret
  72. f.argtypes = args
  73. locals()[func] = f