From 2e65679cc8502df42eb03e4b09c978313b6a6368 Mon Sep 17 00:00:00 2001 From: hopez13 <140780838+hopez13@users.noreply.github.com> Date: Sun, 15 Sep 2024 01:30:13 +0530 Subject: [PATCH] Fix preloader handshake --- mtkclient/Library/Port.py | 77 +++++++++++++----------------- mtkclient/Library/mtk_preloader.py | 3 -- 2 files changed, 32 insertions(+), 48 deletions(-) diff --git a/mtkclient/Library/Port.py b/mtkclient/Library/Port.py index 216ad8fd..7391e064 100755 --- a/mtkclient/Library/Port.py +++ b/mtkclient/Library/Port.py @@ -125,58 +125,45 @@ def serial_handshake(self, maxtries=None, loop=0): pass return False - def run_handshake(self): - ep_out = self.cdc.EP_OUT.write - ep_in = self.cdc.EP_IN.read - maxinsize = self.cdc.EP_IN.wMaxPacketSize - - i = 0 - startcmd = b"\xa0\x0a\x50\x05" - length = len(startcmd) - # On preloader, send 0xa0 first - if self.cdc.pid!=0x3: - ep_out(startcmd[0:1]) - try: - while i < length: - if ep_out(startcmd[i:i+1]): - if ep_in(maxinsize)[-1] == ~(startcmd[i]) & 0xFF: - i += 1 - else: - i = 0 - self.info("Device detected :)") - return True - except Exception as serr: - self.debug(str(serr)) - time.sleep(0.005) - return False + # def run_handshake(self): + + + def handshake(self, maxtries=None, loop=0): counter = 0 - while not self.cdc.connected: try: if maxtries is not None and counter == maxtries: break - counter += 1 - if self.cdc.connect() and self.run_handshake(): - return True - else: - if loop == 5: - sys.stdout.write('\n') - self.info("Hint:\n\nPower off the phone before connecting.\n" + - "For brom mode, press and hold vol up, vol dwn, or all hw buttons and " + - "connect usb.\n" + - "For preloader mode, don't press any hw button and connect usb.\n" - "If it is already connected and on, hold power for 10 seconds to reset.\n") - sys.stdout.write('\n') - if loop >= 10: - sys.stdout.write('.') - if loop >= 20: - sys.stdout.write('\n') - loop = 0 - loop += 1 - time.sleep(0.3) - sys.stdout.flush() + self.cdc.connect() + ep_out = self.cdc.EP_OUT.write + ep_in = self.cdc.EP_IN.read + maxinsize = self.cdc.EP_IN.wMaxPacketSize + + i = 0 + startcmd = b"\xa0\x0a\x50\x05" + length = len(startcmd) + # On preloader, send 0xa0 first + if self.cdc.pid!=0x3: + ep_out(startcmd[0:1]) + try: + while i < length: + if ep_out(startcmd[i:i+1]): + if ep_in(maxinsize)[-1] == ~(startcmd[i]) & 0xFF: + i += 1 + else: + i = 0 + + + self.info("Device detected :)") + return True + + except Exception as serr: + self.debug(str(serr)) + time.sleep(0.005) + return False + except Exception as serr: if "access denied" in str(serr): diff --git a/mtkclient/Library/mtk_preloader.py b/mtkclient/Library/mtk_preloader.py index 03c54727..1b234c32 100755 --- a/mtkclient/Library/mtk_preloader.py +++ b/mtkclient/Library/mtk_preloader.py @@ -160,9 +160,6 @@ def init(self, maxtries=None, display=True): else: res = self.mtk.port.handshake(maxtries=maxtries) if not res: - if display: - self.error("Status: Handshake failed, retrying...") - self.config.set_gui_status(self.config.tr("Status: Handshake failed, retrying...")) self.mtk.port.close() tries += 1 if tries == 1000: