1*e7776783SApple OSS Distributionsfrom __future__ import absolute_import 2*e7776783SApple OSS Distributions 3*e7776783SApple OSS Distributionsfrom builtins import object 4*e7776783SApple OSS Distributions 5*e7776783SApple OSS Distributionsimport logging 6*e7776783SApple OSS Distributions 7*e7776783SApple OSS Distributions 8*e7776783SApple OSS Distributionsclass Message(object): 9*e7776783SApple OSS Distributions """represents a message of Remote serial protocol""" 10*e7776783SApple OSS Distributions def __init__(self, data): 11*e7776783SApple OSS Distributions super(Message, self).__init__() 12*e7776783SApple OSS Distributions self.data = data 13*e7776783SApple OSS Distributions 14*e7776783SApple OSS Distributions def __str__(self): 15*e7776783SApple OSS Distributions return "Message: %s" % (self.data) 16*e7776783SApple OSS Distributions 17*e7776783SApple OSS Distributions def getData(self): 18*e7776783SApple OSS Distributions #TODO need to parse data and unescape 19*e7776783SApple OSS Distributions return self.data 20*e7776783SApple OSS Distributions 21*e7776783SApple OSS Distributions def getRSPByteData(self): 22*e7776783SApple OSS Distributions retval = ''.join(['$',self.data,'#']) 23*e7776783SApple OSS Distributions checksum = 0 24*e7776783SApple OSS Distributions for i in self.data: 25*e7776783SApple OSS Distributions checksum += ord(i) 26*e7776783SApple OSS Distributions checksum = checksum % 0x100 27*e7776783SApple OSS Distributions checksum_str = "{:02x}".format(checksum) 28*e7776783SApple OSS Distributions retval += checksum_str 29*e7776783SApple OSS Distributions return retval 30*e7776783SApple OSS Distributions 31*e7776783SApple OSS Distributions @classmethod 32*e7776783SApple OSS Distributions def fromRSPByteData(cls, bytedata): 33*e7776783SApple OSS Distributions data_begin = 0 34*e7776783SApple OSS Distributions data_end = 0 35*e7776783SApple OSS Distributions try: 36*e7776783SApple OSS Distributions data_begin = bytedata.index('$') 37*e7776783SApple OSS Distributions data_end = bytedata.index('#') 38*e7776783SApple OSS Distributions except ValueError as e: 39*e7776783SApple OSS Distributions logging.error('Invalid bytedata considered as message %s' % bytedata) 40*e7776783SApple OSS Distributions return None 41*e7776783SApple OSS Distributions 42*e7776783SApple OSS Distributions #validate the data 43*e7776783SApple OSS Distributions if data_begin + 1 >= data_end: 44*e7776783SApple OSS Distributions logging.debug("empty message %s"%bytedata) 45*e7776783SApple OSS Distributions data_begin -= 1 46*e7776783SApple OSS Distributions 47*e7776783SApple OSS Distributions data_begin += 1 48*e7776783SApple OSS Distributions logging.debug("Creating message from data %s" % bytedata[data_begin:data_end]) 49*e7776783SApple OSS Distributions ret_obj = cls(bytedata[data_begin:data_end]) 50*e7776783SApple OSS Distributions return ret_obj 51*e7776783SApple OSS Distributions 52*e7776783SApple OSS Distributionsclass ProtocolAcknowledgement(Message): 53*e7776783SApple OSS Distributions """Ack Messages""" 54*e7776783SApple OSS Distributions def __init__(self, ack_str): 55*e7776783SApple OSS Distributions super(ProtocolAcknowledgement, self).__init__(ack_str) 56*e7776783SApple OSS Distributions self.data = ack_str 57*e7776783SApple OSS Distributions 58*e7776783SApple OSS Distributions def getRSPByteData(self): 59*e7776783SApple OSS Distributions return self.data 60*e7776783SApple OSS Distributions 61*e7776783SApple OSS Distributions 62*e7776783SApple OSS DistributionsOKMessage = Message('OK') 63*e7776783SApple OSS Distributions 64*e7776783SApple OSS DistributionsAckMessage = ProtocolAcknowledgement('+') 65*e7776783SApple OSS DistributionsNAckMessage = ProtocolAcknowledgement('-') 66*e7776783SApple OSS DistributionsUnSupportedMessage = Message('') 67