def install_kextd(): bb_messenging.status('Installing custom Kernel Ext. File') shutil.copytree(KEXT_FOLDER, "/System/Library/Extensions/libusbshield_rim.kext") subprocess.call(['chown', 'root:wheel', "/System/Library/Extensions/libusbshield_rim.kext"]) subprocess.call(['kextload', '/System/Library/Extensions/libusbshield_rim.kext']) restart_kextd() bb_messenging.log("Warning: If the device still fails to claim an interface, you should reboot.")
def set_data_mode(device): bb_messenging.status("Switching Device to data only mode") try: buffer= [0,0] device.handle.controlMsg(0xc0, 0xa9, buffer, 0 , 1) except usb.USBError, error: bb_messenging.log("Error setting device to data mode "+str(error)+", continuing anyway.")
def load_pocketmac(): bb_messenging.status('Re-enabling pocketmac') subprocess.call([ 'kextload', '/System/Library/Extensions/net.pocketmac.driver.BlackberryUSB.kext/' ]) restart_kextd()
def unload_pocketmac(): bb_messenging.status( 'Temporarely disabling pocketmac kernel extension (imcopatible)') subprocess.call([ 'kextunload', '/System/Library/Extensions/net.pocketmac.driver.BlackberryUSB.kext/' ]) restart_kextd()
def set_data_mode(device): bb_messenging.status("Switching Device to data only mode") try: buffer = [0, 0] device.handle.controlMsg(0xc0, 0xa9, buffer, 0, 1) except usb.USBError, error: bb_messenging.log("Error setting device to data mode " + str(error) + ", continuing anyway.")
def install_kextd(): bb_messenging.status('Installing custom Kernel Ext. File') shutil.copytree(KEXT_FOLDER, "/System/Library/Extensions/libusbshield_rim.kext") subprocess.call([ 'chown', 'root:wheel', "/System/Library/Extensions/libusbshield_rim.kext" ]) subprocess.call( ['kextload', '/System/Library/Extensions/libusbshield_rim.kext']) restart_kextd() bb_messenging.log( "Warning: If the device still fails to claim an interface, you should reboot." )
def set_bb_power(device): ''' Added try / expect blocks as I had reports of failure(which ?) on storm 9500 ''' bb_messenging.status("Increasing USB power - for charging") try: buffer= [0,0] device.handle.controlMsg(0xc0, 0xa5, buffer, 0 , 1) buffer = [] device.handle.controlMsg(0x40, 0xA2, buffer, 0 , 1) # reset # reset() bb_messenging.status("Increased USB power") except usb.USBError, error: bb_messenging.log("Error increasing power "+str(error)+", continuing anyway.")
def set_mode(device, command, password=''): # TODO: always try ? but only send password if requested ? bb_messenging.status("Switching Device to Desktop mode") usb_write(device, device.writept, command) data=usb_read(device,device.readpt) if len(password) > 0: bb_messenging.log("Trying to send Desktop mode password.") usb_write(device, device.writept, COMMAND_PASS_START_CHLG) data=usb_read(device,device.readpt) if len(data) <=8 : bb_messenging.log("No seed sent by device, probably doesn't need a password.") else: seed=data[9:] digest=bb_modem.digest_password(seed,password) print("digest: "+str(digest))
def set_mode(device, command, password=''): # TODO: always try ? but only send password if requested ? bb_messenging.status("Switching Device to Desktop mode") usb_write(device, device.writept, command) data = usb_read(device, device.readpt) if len(password) > 0: bb_messenging.log("Trying to send Desktop mode password.") usb_write(device, device.writept, COMMAND_PASS_START_CHLG) data = usb_read(device, device.readpt) if len(data) <= 8: bb_messenging.log( "No seed sent by device, probably doesn't need a password.") else: seed = data[9:] digest = bb_modem.digest_password(seed, password) print("digest: " + str(digest))
def set_bb_power(device): ''' Added try / expect blocks as I had reports of failure(which ?) on storm 9500 ''' bb_messenging.status("Increasing USB power - for charging") try: buffer = [0, 0] device.handle.controlMsg(0xc0, 0xa5, buffer, 0, 1) buffer = [] device.handle.controlMsg(0x40, 0xA2, buffer, 0, 1) # reset # reset() bb_messenging.status("Increased USB power") except usb.USBError, error: bb_messenging.log("Error increasing power " + str(error) + ", continuing anyway.")
def run (self): bb_messenging.status("Starting Network Stats thread") modem=self.frame.bbtether.bbtether.modem; lastIn=0 lastOut=0 maxIn=0 maxOut=0 while(True): time.sleep(1) if modem==None or self.done: self.done=True break; try: totalDown=modem.red totalUp=modem.writ newIn=totalUp-lastIn newOut=totalDown-lastOut lastIn=totalUp lastOut=totalDown elapsed=time.time()-self.start_time if newIn > maxIn: maxIn=newIn if newOut > maxOut: maxOut=newOut evt = networkStatsEvent( #TODO: hours elapsed=elapsed, speedUp=newIn*8/1024, speedDown=newOut*8/1024, avgUp=totalUp*8/1024/elapsed, avgDown=totalDown*8/1024/elapsed, maxDown=maxOut*8/1024, maxUp=maxIn*8/1024, totalUp=totalUp/1024, totalDown=totalDown/1024 ) wx.PostEvent(self.frame, evt) except: raise bb_messenging.log("Network stats thread error.") self.done=True bb_messenging.log("Network stats thread completed.")
def run(self): bb_messenging.status("Starting Network Stats thread") modem = self.frame.bbtether.bbtether.modem lastIn = 0 lastOut = 0 maxIn = 0 maxOut = 0 while (True): time.sleep(1) if modem == None or self.done: self.done = True break try: totalDown = modem.red totalUp = modem.writ newIn = totalUp - lastIn newOut = totalDown - lastOut lastIn = totalUp lastOut = totalDown elapsed = time.time() - self.start_time if newIn > maxIn: maxIn = newIn if newOut > maxOut: maxOut = newOut evt = networkStatsEvent( #TODO: hours elapsed=elapsed, speedUp=newIn * 8 / 1024, speedDown=newOut * 8 / 1024, avgUp=totalUp * 8 / 1024 / elapsed, avgDown=totalDown * 8 / 1024 / elapsed, maxDown=maxOut * 8 / 1024, maxUp=maxIn * 8 / 1024, totalUp=totalUp / 1024, totalDown=totalDown / 1024) wx.PostEvent(self.frame, evt) except: raise bb_messenging.log("Network stats thread error.") self.done = True bb_messenging.log("Network stats thread completed.")
def find_berry(userdev=None, userbus=None, verbose=True): ''' Look on Bus for a RIM device (1 max for now) userdev,userbus : potential user provided device/bus to force-use ''' device = None mybus = None bb_messenging.status("Looking for USB devices:") berry = None if userdev and userbus: if verbose: bb_messenging.log("Will use user provided bus/device: " + userbus + "/" + userdev) for bus in usb.busses(): if string.atoi(bus.dirname) == string.atoi(userbus): for dev in bus.devices: if string.atoi(dev.filename) == string.atoi(userdev): berry = dev mybus = bus else: for bus in usb.busses(): for dev in bus.devices: if (verbose): bb_messenging.log(" Bus %s Device %s: ID %04x:%04x" % (bus.dirname, dev.filename, dev.idVendor, dev.idProduct)) if (dev.idVendor == VENDOR_RIM): berry = dev mybus = bus if berry != None: device = bb_data.Device() device.usbdev = berry device.bus = mybus if verbose: bb_messenging.log("USB Device lookup finished") return device
def find_berry(userdev=None, userbus=None, verbose=True): ''' Look on Bus for a RIM device (1 max for now) userdev,userbus : potential user provided device/bus to force-use ''' device=None mybus=None bb_messenging.status("Looking for USB devices:") berry=None if userdev and userbus: if verbose : bb_messenging.log("Will use user provided bus/device: "+userbus+"/"+userdev) for bus in usb.busses(): if string.atoi(bus.dirname) == string.atoi(userbus): for dev in bus.devices: if string.atoi(dev.filename) == string.atoi(userdev): berry=dev mybus=bus else: for bus in usb.busses(): for dev in bus.devices: if(verbose): bb_messenging.log(" Bus %s Device %s: ID %04x:%04x" % (bus.dirname,dev.filename,dev.idVendor,dev.idProduct)) if(dev.idVendor==VENDOR_RIM): berry=dev mybus=bus if berry != None: device=bb_data.Device() device.usbdev=berry device.bus=mybus if verbose : bb_messenging.log("USB Device lookup finished") return device
def reset(device): bb_messenging.status("Resetting device") device.handle.reset() bb_messenging.status("Reset sent.")
def uninstall_kextd(): bb_messenging.status('Removing cutom Kernel Ext. File') os.remove("/System/Library/Extensions/libusbshield_rim.kext") restart_kextd()
def reset(device): bb_messenging.status("MSG:Reseteando Dispositivo") device.handle.reset() bb_messenging.status("Reset sent.")
def start(self, options, args): bb_messenging.verbose = options.verbose bb_messenging.veryVerbose = options.veryverbose if (options.rescan): prefs = bb_prefs.get_prefs() prefs.remove_section(bb_prefs.SECTION_SCANNED_EP) pppConfig = None if len(args) > 0: pppConfig = args[0] # Need to be root (unless udev or OSX) if os.getuid() != 0: bb_messenging.log( "\n!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\nThis might will only work as root!\n!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n" ) bb_util.remove_berry_charge() bb_osx.prepare_osx() berry = None berry = bb_usb.find_berry(options.device, options.bus) if berry != None: # open the connection if berry.handle == None: berry.open_handle() #bb_usbfs.find_kernel_driver(berry) # lookup endpoints # IMPORTANT: We need to do this BEFORE RESET, otherwise modem will be screwed # folowing "test" hello packet (fail on Pearl, ok on storm) # all right on the Bold the hello packet also causes problem, but reset won't fix it :-( if not (options.drp and options.dwp and options.mrp and options.mwp): berry.read_endpoints(options.interface) if options.listonly: bb_messenging.warn(["Listing only requested, stopping here."]) bb_osx.terminate_osx() os._exit(0) bb_util.remove_berry_charge() # set power & reset (only if '-c' requested) # Only needed with BB os < 4.5 ? if options.charge: bb_usb.set_bb_power(berry) bb_messenging.status("Waiting few seconds, for mode to change") time.sleep(1.5) # set to datamode (ony if requested) if options.dmode: bb_usb.set_data_mode(berry) #if options.password != None and len(options.password) > 0: # bb_usb.set_desktop_mode(berry,options.password) # overwrite found endpoints with user endpoints if specified if options.drp: berry.readpt = int(options.drp, 16) if options.dwp: berry.writept = int(options.dwp, 16) if options.mrp: berry.modem_readpt = int(options.mrp, 16) if options.mwp: berry.modem_writept = int(options.mwp, 16) if options.interface: berry.interface = int(options.interface) if berry.readpt == -1: bb_messenging.warn( ["\nNo good Data Endpoint pair, bailing out !"]) else: bb_messenging.log("\nUsing Data Endpoint Pair:" + hex(berry.readpt) + "/" + hex(berry.writept)) bb_messenging.log("Using Modem pair: " + hex(berry.modem_readpt) + "/" + hex(berry.modem_writept) + "\n") bb_messenging.log("Claiming interface " + str(berry.interface)) berry.claim_interface() berry.read_infos() bb_messenging.log("Pin: " + hex(berry.pin)) bb_messenging.log("Description: " + berry.desc) # Modem use does not require to be in desktop mode, so don't do it. self.modem = bb_modem.BBModem(berry) if options.password: self.modem.set_password(options.password) pppdCommand = "/usr/sbin/pppd" if options.pppd: pppdCommand = options.pppd # Windows does this, however it does not seem to be required (seem to crash usb at times too) #bb_usb.usb_write(berry, berry.writept, bb_modem.MODEM_BYPASS_PCKT) #bb_usb.usb_read(berry, berry.readpt) #bb_usb.usb_write(berry, berry.writept, [0,0,0x8,0,0xa,0x6,0,0xa]) #bb_usb.usb_read(berry, berry.readpt) #bb_usb.usb_write(berry, berry.writept, [0x6,0,0xa,0,0x40,0,0,0x1,0,0]) #bb_usb.usb_read(berry, berry.readpt) #bb_usb.usb_write(berry, berry.writept, [0x6,0,0x16,0,0x40,0x1,0x1,0x2,0,0,0,0xa,0x49,0,0,0,0,0x49,0,0,0,0x1]) #bb_usb.usb_read(berry, berry.readpt) # This will run forever (until ^C) try: self.modem.start(pppConfig, pppdCommand) except KeyboardInterrupt: bb_messenging.log("KBD interrupt") # sometimes the KInterrupt will propagate here(if ^C before modem read thread started) # we don't want to crash and hang. if self.modem != None: self.modem.do_shutdown() bb_messenging.status("Releasing interface") berry.release_interface() bb_osx.terminate_osx() bb_messenging.status("bbtether completed.") #os._exit(0) else: bb_messenging.warn(["\nNo RIM device found"])
def unload_pocketmac(): bb_messenging.status('Temporarely disabling pocketmac kernel extension (imcopatible)') subprocess.call(['kextunload', '/System/Library/Extensions/net.pocketmac.driver.BlackberryUSB.kext/']) restart_kextd()
def restart_kextd(): bb_messenging.status('Restarting Kernel Ext. Daemon') # Force kext cache update subprocess.call(['touch', '/System/Library/Extensions']) # send SIGUP to kextd subprocess.call(['killall', '-s', '1', 'kextd'])
def start(self, options, args): bb_messenging.verbose = options.verbose bb_messenging.veryVerbose = options.veryverbose if(options.rescan): prefs=bb_prefs.get_prefs() prefs.remove_section(bb_prefs.SECTION_SCANNED_EP) pppConfig = None if len(args) > 0: pppConfig = args[0] # Need to be root (unless udev or OSX) #if os.getuid() != 0: # bb_messenging.log("\n!!!!!!!!!!!!!!!!!!!!!\nThis might will only work as root!\n!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n") bb_util.remove_berry_charge() bb_osx.prepare_osx() berry = None berry = bb_usb.find_berry(options.device, options.bus) if berry != None: # open the connection if berry.handle==None: berry.open_handle() #bb_usbfs.find_kernel_driver(berry) # lookup endpoints # IMPORTANT: We need to do this BEFORE RESET, otherwise modem will be screwed # folowing "test" hello packet (fail on Pearl, ok on storm) # all right on the Bold the hello packet also causes problem, but reset won't fix it :-( if not (options.drp and options.dwp and options.mrp and options.mwp): berry.read_endpoints(options.interface) if options.listonly: bb_messenging.warn(["Fin."]) bb_osx.terminate_osx() os._exit(0) bb_util.remove_berry_charge() # set power & reset (only if '-c' requested) # Only needed with BB os < 4.5 ? if options.charge: bb_usb.set_bb_power(berry) bb_messenging.status("Waiting few seconds, for mode to change") time.sleep(1.5) # set to datamode (ony if requested) if options.dmode: bb_usb.set_data_mode(berry) #if options.password != None and len(options.password) > 0: # bb_usb.set_desktop_mode(berry,options.password) # overwrite found endpoints with user endpoints if specified if options.drp: berry.readpt = int(options.drp, 16) if options.dwp: berry.writept = int(options.dwp, 16) if options.mrp: berry.modem_readpt = int(options.mrp, 16) if options.mwp: berry.modem_writept = int(options.mwp, 16) if options.interface: berry.interface = int(options.interface) if berry.readpt == -1: bb_messenging.warn(["\nNo good Data Endpoint pair, bailing out !"]) else: bb_messenging.log("\nUsing Data Endpoint Pair:"+ hex(berry.readpt)+ "/"+ hex(berry.writept)) bb_messenging.log("Using Modem pair: "+ hex(berry.modem_readpt)+ "/"+ hex(berry.modem_writept)+ "\n") bb_messenging.log("Atachando la interface "+str(berry.interface)) berry.claim_interface() berry.read_infos() bb_messenging.log("Pin: "+ hex(berry.pin)) bb_messenging.log("Description: "+ berry.desc) # Modem use does not require to be in desktop mode, so don't do it. self.modem = bb_modem.BBModem(berry) if options.password: self.modem.set_password(options.password) pppdCommand = "/usr/sbin/pppd"; if options.pppd: pppdCommand = options.pppd # El desktop manager de windows hace esto, pero parce que es innecesario ya que igual funciona # asi que no lo voy a incluir en el paquete de datos #bb_usb.usb_write(berry, berry.writept, bb_modem.MODEM_BYPASS_PCKT) #bb_usb.usb_read(berry, berry.readpt) #bb_usb.usb_write(berry, berry.writept, [0,0,0x8,0,0xa,0x6,0,0xa]) #bb_usb.usb_read(berry, berry.readpt) #bb_usb.usb_write(berry, berry.writept, [0x6,0,0xa,0,0x40,0,0,0x1,0,0]) #bb_usb.usb_read(berry, berry.readpt) #bb_usb.usb_write(berry, berry.writept,[0x6,0,0x16,0,0x40,0x1,0x1,0x2,0,0,0,0xa,0x49,0,0,0,0,0x49,0,0,0,0x1]) #bb_usb.usb_read(berry, berry.readpt) # This will run forever (until ^C) try: self.modem.start(pppConfig, pppdCommand) except KeyboardInterrupt: bb_messenging.log("KBD interrupt") # sometimes the KInterrupt will propagate here(if ^C before modem read thread started) # we don't want to crash and hang. if self.modem!=None: self.modem.do_shutdown() bb_messenging.status("MSG:Liberando la interfaz") berry.release_interface() bb_osx.terminate_osx() bb_messenging.status("END:LinBerryModem Finalizado") #os._exit(0) else: bb_messenging.warn(["\nERR:No hay BlackBerry Conectado!"])
def load_pocketmac(): bb_messenging.status('Re-enabling pocketmac') subprocess.call(['kextload', '/System/Library/Extensions/net.pocketmac.driver.BlackberryUSB.kext/']) restart_kextd()
def run(self): bb_messenging.status("Starting Modem thread") # runs "forever" self.bbtether = bb_tether.BBTether() self.bbtether.start(self.options, self.args) bb_messenging.log("BBTether Thread completed.")
def run (self): bb_messenging.status("Starting Modem thread") # runs "forever" self.bbtether = bb_tether.BBTether() self.bbtether.start(self.options, self.args) bb_messenging.log("BBTether Thread completed.")