mirror of
https://github.com/bkerler/mtkclient.git
synced 2024-11-14 11:14:56 -05:00
Compare commits
11 commits
d5481d0370
...
2669bb91ba
Author | SHA1 | Date | |
---|---|---|---|
|
2669bb91ba | ||
|
127c353b39 | ||
|
7b30c5293c | ||
|
670cd5384c | ||
|
6cbe6786b3 | ||
|
77958d7ac8 | ||
|
cc0a502bc0 | ||
|
093769e72b | ||
|
e3cd58a837 | ||
|
35c5803ae0 | ||
|
2e65679cc8 |
6 changed files with 42 additions and 53 deletions
|
@ -309,7 +309,7 @@ class UsbClass(DeviceClass):
|
|||
break
|
||||
|
||||
if self.device is None:
|
||||
self.debug("Couldn't detect the device. Is it connected ?")
|
||||
# self.debug("Couldn't detect the device. Is it connected ?")
|
||||
return False
|
||||
|
||||
try:
|
||||
|
|
|
@ -967,7 +967,10 @@ class DAXML(metaclass=LogBase):
|
|||
self.ack_value(length)
|
||||
cmd, result = self.get_command_result()
|
||||
if type(result) is DwnFile:
|
||||
data = fh.read(length)
|
||||
if fh:
|
||||
data = fh.read(length)
|
||||
else:
|
||||
data = wdata
|
||||
if not self.upload(result, data, raw=True):
|
||||
self.error("Error on writing flash at 0x%08X" % addr)
|
||||
return False
|
||||
|
|
|
@ -125,63 +125,51 @@ class Port(metaclass=LogBase):
|
|||
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):
|
||||
self.warning(str(serr))
|
||||
self.debug(str(serr))
|
||||
# self.debug(str(serr))
|
||||
pass
|
||||
return False
|
||||
|
||||
|
|
|
@ -160,9 +160,6 @@ class Preloader(metaclass=LogBase):
|
|||
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:
|
||||
|
|
|
@ -101,7 +101,7 @@ class PLTools(metaclass=LogBase):
|
|||
return False
|
||||
else:
|
||||
self.error(f"Error on sending payload: {filename}")
|
||||
self.error(f"Error, payload answered instead: {hexlify(ack).decode('utf-8')}")
|
||||
self.error(f"Error, payload answered instead: {hexlify(response_ack).decode('utf-8')}")
|
||||
return False
|
||||
|
||||
def runbrute(self, args):
|
||||
|
|
|
@ -346,7 +346,7 @@ hwconfig = {
|
|||
dacode=0x0598,
|
||||
name="ELBRUS/MT0598"),
|
||||
0x992: Chipconfig( # var1
|
||||
# watchdog
|
||||
watchdog=0x10007000,
|
||||
# uart
|
||||
# brom_payload_addr
|
||||
# da_payload_addr
|
||||
|
@ -355,9 +355,10 @@ hwconfig = {
|
|||
# cqdma_base
|
||||
# ap_dma_mem
|
||||
# blacklist
|
||||
efuse_addr=0x11EC0000,
|
||||
damode=DAmodes.XFLASH,
|
||||
dacode=0x0992,
|
||||
name="MT0992"),
|
||||
name="MT6880/MT6890"),
|
||||
0x2601: Chipconfig(
|
||||
var1=0xA, # Smartwatch, confirmed
|
||||
watchdog=0x10007000,
|
||||
|
|
Loading…
Reference in a new issue