Re: [Bugme-new] [Bug 15376] New: regression (oops) with usb in 2.6.33-rc8

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi,

Le 25/02/2010 00:50, Sarah Sharp a écrit :

Random stuff, hmmm?  Maybe you asked it to change alternate settings to
one that the device doesn't provide?  Can you post your python script?


Yep, really random stuff ) The attached script puts the ipod in dfu mode and then uploads data from a file to it. The data I'm sending comes from /dev/urandom or a randomly chosen file in /bin. If I send the right amount of data, the ipod ends up in a state when I can run my script a second time, and this is when running it this second time that I get this oops. So it's truly happening when sending random stuff to an ipod in a weird state ;) If I send valid data with this script, or a small amount of data, I can do it again and again with no crash, so I don't think it's directly related to the script.

Hope that helps,

Christophe
#!/usr/bin/env python
#
#
#    Copyright 2010 TheSeven
#
#
#    This file is part of TheSeven's iPod tools.
#
#    TheSeven's iBugger is free software: you can redistribute it and/or
#    modify it under the terms of the GNU General Public License as
#    published by the Free Software Foundation, either version 2 of the
#    License, or (at your option) any later version.
#
#    TheSeven's iBugger is distributed in the hope that it will be useful,
#    but WITHOUT ANY WARRANTY; without even the implied warranty of
#    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
#    See the GNU General Public License for more details.
#
#    You should have received a copy of the GNU General Public License along
#    with TheSeven's iPod tools.  If not, see <http://www.gnu.org/licenses/>.
#
#


import sys
import struct
import usb


class ipoddfu:
  def __init__(self, generation = 0, type = 0):
    busses = usb.busses()
 
    for bus in busses:
      devices = bus.devices
      for dev in devices:
        if dev.idVendor == 0x05ac and dev.idProduct == 0x1220 \
           and generation in [0, 2] and type in [0, 1]:
          self.handle = dev.open()
          self.handle.setConfiguration(1)
          self.handle.claimInterface(0)
          self.generation = 2;
          self.type = 1;
          print("Connected to S5L8701 Bootrom DFU mode, USB version %s"  % dev.deviceVersion)
          return
        elif dev.idVendor == 0x05ac and dev.idProduct == 0x1240 \
           and generation in [0, 2] and type in [0, 2]:
          self.handle = dev.open()
          self.handle.setConfiguration(1)
          self.handle.claimInterface(0)
          self.generation = 2;
          self.type = 2;
          print("Connected to iPod Nano 2G NOR DFU mode, USB version %s"  % dev.deviceVersion)
          return
        elif dev.idVendor == 0x05ac and dev.idProduct == 0x1223 \
           and generation in [0, 3] and type in [0, 1]:
          self.handle = dev.open()
          self.handle.setConfiguration(1)
          self.handle.claimInterface(0)
          self.generation = 3;
          self.type = 1;
          print("Connected to S5L8702 Bootrom DFU mode, USB version %s"  % dev.deviceVersion)
          return
        elif dev.idVendor == 0x05ac and dev.idProduct == 0x1242 \
           and generation in [0, 3] and type in [0, 1]:
          self.handle = dev.open()
          self.handle.setConfiguration(1)
          self.handle.claimInterface(0)
          self.generation = 3;
          self.type = 2;
          print("Connected to iPod Nano 3G WTF mode, USB version %s"  % dev.deviceVersion)
          return
        elif dev.idVendor == 0x05ac and dev.idProduct == 0x1225 \
           and generation in [0, 4] and type in [0, 1]:
          self.handle = dev.open()
          self.handle.setConfiguration(1)
          self.handle.claimInterface(0)
          self.generation = 4;
          self.type = 1;
          print("Connected to S5L8720 Bootrom DFU mode, USB version %s"  % dev.deviceVersion)
          return
        elif dev.idVendor == 0x05ac and dev.idProduct == 0x1243 \
           and generation in [0, 4] and type in [0, 1]:
          self.handle = dev.open()
          self.handle.setConfiguration(1)
          self.handle.claimInterface(0)
          self.generation = 4;
          self.type = 2;
          print("Connected to iPod Nano 4G WTF mode, USB version %s"  % dev.deviceVersion)
          return

    raise Exception("Could not find specified DFU device (generation = %d, type = %d)" % (generation, type))


  @staticmethod
  def crc32(data):
    crc_table = []
    for i in range(256):
      t = i;
      for j in range(8):
        if t & 1:
          t = (t >> 1) ^ 0xedb88320
        else:
          t = t >> 1
      crc_table.append(t)

    crc = 0xffffffff
    for i in range(len(data)):
      crc = (crc >> 8) ^ crc_table[(crc ^ struct.unpack("B", data[i])[0]) & 0xff];

    return crc


  def getcpu(self):
    result = self.handle.controlMsg(0xa1, 0xff, 0x3f, 2, 0, 100)
    return struct.pack("%dB" % len(result), *result)


  def upload(self, data, exploit = 0):
    if exploit == 1 and self.generation == 2 and self.type == 1:
      data = f.read().ljust(0x200f0, "\0") \
           + "\xb8\x48\x02\x22\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0" \
           + "\0\0\0\x22\0\0\0\x22\0\0\0\x22\0\0\0\x22" \
           + "\0\0\0\x22\0\0\0\x22\0\0\0\x22\0\0\0\x22" \
           + "\0\0\0\x22\0\0\0\x22\0\0\0\x22\0\0\0\x22" \
           + "\0\0\0\x22\0\0\0\x22\0\0\0\x22\0\0\0\x22" \
           + "\0\0\0\x22\0\0\0\x22\0\0\0\x22\0\0\0\x22" \
           + "\0\0\0\x22\0\0\0\x22\0\0\0\x22\0\0\0\x22" \
           + "\0\0\0\x22\0\0\0\x22\0\0\0\x22\0\0\0\x22" \
           + "\0\0\0\x22\0\0\0\x22\0\0\0\x22\0\0\0\x22"

    data = data + struct.pack("<I", self.crc32(data))

    sys.stdout.write("Upload: .")
    sys.stdout.flush()
    for index in range((len(data) + 2047) // 2048):
      self.handle.controlMsg(0x21, 1, data[2048 * index : 2048 * (index + 1)], index, 0, 100)
      result = (0, 0, 0, 0, 0, 0)
      while result[4] != 0x05:
        result = self.handle.controlMsg(0xa1, 3, 6, 0, 0, 100)
      sys.stdout.write(".")
      sys.stdout.flush()

    self.handle.controlMsg(0x21, 1, "", index, 0, 100)
    result = (0, 0, 0, 0, 0, 0)
    index = 0
    try:
      while result[4] != 0x02 and index < 1000:
        result = self.handle.controlMsg(0xa1, 3, 6, 0, 0, 100)
        index = index + 1
    except:
      pass

    if (exploit == 0 and (index == 1000 or result[4] == 0x02)) or \
       (exploit == 1 and (index == 1000 or result[4] != 0x04)):
      print(" failed: %X / %X" % (result[4], result[0]))
      raise Exception("DFU upload failed! (%X / %X)" % (result[4], result[0]))
    else:
      print(" done")


  def uploadfile(self, file, exploit = 0):
    f = open(file, "rb")
    data = f.read()
    f.close()
    self.upload(data, exploit)

[Index of Archives]     [Linux Media]     [Linux Input]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Old Linux USB Devel Archive]

  Powered by Linux