PMDemoConnection.py 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. """
  2. Created on 29-03-2013
  3. @author: citan
  4. """
  5. from pimonitor.PM import PM
  6. from pimonitor.PMPacket import PMPacket
  7. import random
  8. import time
  9. class PMDemoConnection(object):
  10. def __init__(self):
  11. self._ser = None
  12. self._log_id = None
  13. random.seed()
  14. self._byteval = [0, 0, 0, 0]
  15. def open(self):
  16. message = 'Opening serial connection...'
  17. self._log_id = PM.log(message)
  18. time.sleep(0.2)
  19. PM.log(message + " [DONE]", self._log_id)
  20. return True
  21. def close(self):
  22. PM.log("Closing serial connection", self._log_id)
  23. pass
  24. def init(self, target):
  25. PM.log('Initializing CU for target: ' + str(target), self._log_id)
  26. response = []
  27. if target == 1 or target == 3:
  28. response = [0x80, 0xF0, 0x10, 0x69, 0xFF, 0xA2, 0x10, 0x02, 0x4D, 0x12, 0x04, 0x40, 0x06, 0xF3, 0xFA, 0xC9, 0x8E, 0x22, 0x04, 0x02, 0xAC, 0x00, 0x00, 0x00, 0x60, 0xCE, 0x54, 0xF8, 0xB9, 0x84, 0x00, 0x6C, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0xDC, 0x00, 0x00, 0x45, 0x1F, 0x30, 0x80, 0xF0, 0x20, 0x1F, 0x02, 0x43, 0xFB, 0x00, 0xF1, 0xC1, 0x84, 0x00, 0x00, 0x00, 0x00, 0x00, 0xF1, 0x80, 0x00, 0x00, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x26]
  29. if target == 2:
  30. response = [0x80, 0xF0, 0x18, 0x39, 0xFF, 0xA2, 0x10, 0x21, 0xD0, 0xF3, 0x70, 0x31, 0x00, 0x01, 0x00, 0x80, 0x04, 0x00, 0x00, 0x00, 0x00, 0xBD, 0xC3, 0xC0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x49, 0x3E, 0x00, 0x0B, 0x21, 0xC0, 0x00, 0x00, 0x01, 0x1F, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x51]
  31. return PMPacket.from_array(response)
  32. def read_parameter(self, parameter):
  33. time.sleep(0.05)
  34. address_len = parameter.get_address().get_length()
  35. data = [0x80, 0xF0] # [0x80, 0xF0, 0x18, 0x02, 0xE8, 0x60, 0xD2]
  36. if parameter.get_target() == 1 or parameter.get_target() == 3:
  37. data.append(0x10)
  38. if parameter.get_target() == 2:
  39. data.append(0x18)
  40. data.append(address_len+1)
  41. data.append(0xE8)
  42. for i in range(0, address_len):
  43. self._byteval[i] = (self._byteval[i] + 1) % 0xFF
  44. data.append(self._byteval[i])
  45. checksum = 0
  46. for b in data:
  47. checksum = (checksum + b) & 0xFF
  48. data.append(checksum)
  49. return PMPacket.from_array(data)
  50. def read_parameters(self, parameters):
  51. time.sleep(0.05)
  52. out_packets = []
  53. for parameter in parameters:
  54. out_packets.append(self.read_parameter(parameter))
  55. return out_packets