| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  | #!/usr/bin/env python | 
					
						
							|  |  |  | # -*- coding: UTF-8 -*- | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import datetime | 
					
						
							|  |  |  | import fileinput | 
					
						
							|  |  |  | import re | 
					
						
							|  |  |  | import sys | 
					
						
							|  |  |  | import serial | 
					
						
							|  |  |  | import time | 
					
						
							|  |  |  | import xmodem | 
					
						
							|  |  |  | import os | 
					
						
							|  |  |  | import binascii | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  | from log import myprint | 
					
						
							|  |  |  | from log import log_init | 
					
						
							|  |  |  | from bin_to_hex import bin_to_hex_file | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def init_send(s_port:serial.Serial, send_str): | 
					
						
							|  |  |  |     s_info = bytearray() | 
					
						
							|  |  |  |     while True: | 
					
						
							|  |  |  |         s_port.write(send_str) | 
					
						
							|  |  |  |         time.sleep(0.1) | 
					
						
							|  |  |  |         s_info += s_port.read(1) | 
					
						
							|  |  |  |         bytes2read = s_port.in_waiting | 
					
						
							|  |  |  |         tmp = s_port.read(bytes2read) | 
					
						
							|  |  |  |         s_info += tmp | 
					
						
							|  |  |  |         # m_ram = re.search("Recieving RAM-IMAGE in xmodem : C", s_info.decode("utf-8")) | 
					
						
							|  |  |  |         if(s_info.find(b"Recieving RAM-IMAGE in xmodem : C")>=0): | 
					
						
							|  |  |  |             m_ram=True | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             m_ram=False | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if m_ram: | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |             myprint ("Program enters transmission mode...") | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  |             break | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def burn_ram_bin(x_modem:xmodem.XMODEM, r_file): | 
					
						
							|  |  |  |     global trans_time_0 | 
					
						
							|  |  |  |     stime = datetime.datetime.now() | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |     myprint ("Transferring %s..." % r_file) | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  |     try: | 
					
						
							|  |  |  |         stream = open(r_file, 'rb') | 
					
						
							|  |  |  |     except Exception: | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |         myprint("Cannot load file, please check the file path and retry. Press <enter> to exit") | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  |         sys.exit() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     xmodem_send = x_modem.send(stream, callback=status_update_0) | 
					
						
							|  |  |  |     etime = datetime.datetime.now() | 
					
						
							|  |  |  |     trans_time_0 = (etime - stime).seconds | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |     myprint ("\nTransferring ram.bin result: %s, consuming time: %s s \n" % (xmodem_send, trans_time_0)) | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | def burn_flash_bin(s_port:serial.Serial, x_modem:xmodem.XMODEM, f_file): | 
					
						
							|  |  |  |     global trans_time_1 | 
					
						
							|  |  |  |     s_info = bytearray() | 
					
						
							|  |  |  |     while True: | 
					
						
							|  |  |  |         s_info += s_port.read(1) | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |         myprint(f"recv:{s_info.hex(' ')}") | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  |         bytes2read = s_port.in_waiting | 
					
						
							|  |  |  |         tmp = s_port.read(bytes2read) | 
					
						
							|  |  |  |         s_info += tmp | 
					
						
							|  |  |  |         if(s_info.find(b'C')>=0): | 
					
						
							|  |  |  |             m_flash=True | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             m_flash=False | 
					
						
							|  |  |  |         if(s_info.find(b"Updating done, PLS reboot the device...")>=0): | 
					
						
							|  |  |  |             m_done=True | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             m_done=False | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if m_flash: | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |             # myprint m_flash.group(0) | 
					
						
							|  |  |  |             myprint (r"Recieving FLASH-IMAGE in xmodem : C") | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  |             s_info = bytearray() | 
					
						
							|  |  |  |             stime = datetime.datetime.now() | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |             myprint ("Transferring %s..." % f_file) | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  |             try: | 
					
						
							|  |  |  |                 stream = open(f_file, 'rb') | 
					
						
							|  |  |  |             except Exception: | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |                 myprint("Cannot load file, please check the file path and retry. Press <enter> to exit") | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  |                 sys.exit() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             xmodem_send = x_modem.send(stream, quiet=True, callback=status_update_1) | 
					
						
							|  |  |  |             etime = datetime.datetime.now() | 
					
						
							|  |  |  |             trans_time_1 = (etime - stime).seconds | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |             myprint ("\nTransferring iot_flash.bin result: %s, consuming time: %d s \n" % (xmodem_send, trans_time_1)) | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  |         elif m_done: | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |             myprint (m_done.group(0)) | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  |             break | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             pass | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def upload_callback(total_packets, success_count, error_count, packet_size): | 
					
						
							|  |  |  |     # callback(total_packets, success_count, error_count, packet_size) | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |     myprint("upload:",total_packets, success_count, error_count, packet_size) | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | # 上传固件 | 
					
						
							|  |  |  | def upload_bin(x_modem:xmodem.XMODEM, w_file): | 
					
						
							|  |  |  |     global trans_time_0 | 
					
						
							|  |  |  |     stime = datetime.datetime.now() | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |     myprint ("Transferring %s..." % w_file) | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  |     try: | 
					
						
							|  |  |  |         stream = open(w_file, 'wb+') | 
					
						
							|  |  |  |     except Exception: | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |         myprint("Cannot load file, please check the file path and retry. Press <enter> to exit") | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  |         sys.exit() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     xmodem_send = x_modem.recv(stream, callback=upload_callback) | 
					
						
							|  |  |  |     etime = datetime.datetime.now() | 
					
						
							|  |  |  |     trans_time_0 = (etime - stime).seconds | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |     myprint ("\nTransferring ram.bin result: %s, consuming time: %s s \n" % (xmodem_send, trans_time_0)) | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def getc(size, timeout=1): | 
					
						
							|  |  |  |     data=ser.read(size) | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |     # myprint("getc:",data.hex(' ')) | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  |     return data or None | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def putc(data, timeout=1): | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |     # myprint("putc:",data.hex(' ')) | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  |     ser.write(data) | 
					
						
							|  |  |  |     time.sleep(0.03) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def status_update_0(total_packets, success_count, error_count): | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |     myprint ("total_packets: %s, success_count: %s, error_count: %d" % (total_packets, success_count, error_count)) | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  |     # if total_packets % 10 == 0: | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |     #     myprint ('.'), | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def status_update_1(total_packets, success_count, error_count): | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |     myprint ("total_packets: %s, success_count: %s, error_count: %d" % (total_packets, success_count, error_count)) | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  |     # if total_packets % 50 == 0: | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |     #     myprint ('.'), | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | '''
 | 
					
						
							|  |  |  | IMG_TYPE 0xfc00 sp.bin | 
					
						
							|  |  |  | IMG_TYPE 0xfc01 sbl.bin | 
					
						
							|  |  |  | IMG_TYPE 0xfc05 oem.bin | 
					
						
							|  |  |  | IMG_TYPE 0xfc03 pib.bin | 
					
						
							|  |  |  | IMG_TYPE 0xfc08 ht.bin | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | '''
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | _work_dir='work' | 
					
						
							|  |  |  | if not os.path.exists(_work_dir): | 
					
						
							|  |  |  |     os.mkdir(_work_dir) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def calc_log_file_name(): | 
					
						
							|  |  |  |     log_file=sys.argv[1].split('.')[0]+'.log' | 
					
						
							|  |  |  |     return os.path.join(_work_dir,log_file) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def calc_upload_name(): | 
					
						
							|  |  |  |     name=sys.argv[1] | 
					
						
							|  |  |  |     return os.path.join(_work_dir,name) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def calc_hex_name(): | 
					
						
							|  |  |  |     name=sys.argv[1]+'.txt' | 
					
						
							|  |  |  |     return os.path.join(_work_dir,name) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def calc_flash_info_name(): | 
					
						
							|  |  |  |     name=sys.argv[1].split('.')[0]+'.info' | 
					
						
							|  |  |  |     return os.path.join(_work_dir,name) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # kunlun.py [upload.bin] | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  | if __name__ == '__main__': | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |     if(len(sys.argv)<2): | 
					
						
							|  |  |  |         print("param too less") | 
					
						
							|  |  |  |         exit(-1) | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |     log_init(calc_log_file_name()) | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  |     exit_flag = 0 | 
					
						
							|  |  |  |     trans_time_0, trans_time_1 = 0, 0 | 
					
						
							|  |  |  |     config_file = r"xmodem_config.txt" | 
					
						
							|  |  |  |     init_str, sp_num, b_rate, nb_rate, ram_file, iot_flash_file, ser = None, None, None, None, None, None, None | 
					
						
							|  |  |  |     for eachline in fileinput.FileInput(config_file): | 
					
						
							|  |  |  |         m_info = re.match(r"(\w+)\s*=\s*(.+)", eachline) | 
					
						
							|  |  |  |         if m_info: | 
					
						
							|  |  |  |             if m_info.group(1) == "init_str": | 
					
						
							|  |  |  |                 init_str = m_info.group(2) | 
					
						
							|  |  |  |             elif m_info.group(1) == "serial_port_num": | 
					
						
							|  |  |  |                 sp_num = int(m_info.group(2)) | 
					
						
							|  |  |  |             elif m_info.group(1) == "baud_rate": | 
					
						
							|  |  |  |                 b_rate = int(m_info.group(2)) | 
					
						
							|  |  |  |             elif m_info.group(1) == "new_baud_rate": | 
					
						
							|  |  |  |                 nb_rate = int(m_info.group(2)) | 
					
						
							|  |  |  |             elif m_info.group(1) == "ram_file": | 
					
						
							|  |  |  |                 ram_file = m_info.group(2) | 
					
						
							|  |  |  |             elif m_info.group(1) == "iot_flash_file": | 
					
						
							|  |  |  |                 iot_flash_file = m_info.group(2) | 
					
						
							|  |  |  |             else: | 
					
						
							|  |  |  |                 pass | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         ser = serial.Serial(port='COM' + str(sp_num), baudrate=b_rate, timeout=0.3) | 
					
						
							|  |  |  |     except Exception: | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |         myprint("Serial Port COM%s Conflicts!!! Press <enter> to Close it and retry..." % str(sp_num)) | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  |         sys.exit() | 
					
						
							|  |  |  |     modem = xmodem.XMODEM(getc, putc, mode='xmodem1k') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # 发送启动字符让设备进入xmodem模式 | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |     init_send(ser, init_str.encode("utf-8")) | 
					
						
							|  |  |  |     burn_ram_bin(modem, ram_file) | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |     # # ser.baudrate=nb_rate | 
					
						
							|  |  |  |     # time.sleep(0.5) | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     # burn_flash_bin(ser, modem, iot_flash_file) | 
					
						
							|  |  |  |     # 显示flash信息 | 
					
						
							|  |  |  |     ser.write(b"f i\n") | 
					
						
							|  |  |  |     time.sleep(0.5) | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |     ser_read_data=ser.read(4096).decode('utf-8') | 
					
						
							|  |  |  |     myprint(ser_read_data) | 
					
						
							|  |  |  |     with open(calc_flash_info_name(),mode='w+',encoding='utf-8') as f: | 
					
						
							|  |  |  |         f.writelines(ser_read_data.split('\r\n')) | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  |     # 显示image信息 | 
					
						
							|  |  |  |     ser.write(b"f s\n") | 
					
						
							|  |  |  |     time.sleep(0.5) | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |     ser_read_data=ser.read(4096).decode('utf-8') | 
					
						
							|  |  |  |     myprint(ser_read_data) | 
					
						
							|  |  |  |     with open(calc_flash_info_name(),mode='a+',encoding='utf-8') as f: | 
					
						
							|  |  |  |         f.writelines(ser_read_data.split('\r\n')) | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  |     # 上传整个镜像 | 
					
						
							|  |  |  |     ser.write(b"fw u d all\n") | 
					
						
							|  |  |  |     time.sleep(0.5) | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |     myprint(ser.read(4096).decode('utf-8')) | 
					
						
							|  |  |  |     upload_bin(modem,calc_upload_name()) | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-12 19:16:00 +08:00
										 |  |  |     myprint ("Total transmission time: %s s" % str(trans_time_0+trans_time_1)) | 
					
						
							|  |  |  |     myprint("Start transform bin to hex.") | 
					
						
							|  |  |  |     bin_to_hex_file(calc_upload_name(), calc_hex_name(),calc_flash_info_name()) | 
					
						
							|  |  |  |     myprint("Transform to hex end.") | 
					
						
							| 
									
										
										
										
											2024-10-12 11:41:37 +08:00
										 |  |  | 
 |