コード例 #1
0
ファイル: bb_osx.py プロジェクト: CesarBallardini/linberry
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.")
コード例 #2
0
ファイル: bb_usb.py プロジェクト: tcolar/berry4all
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.")
コード例 #3
0
ファイル: bb_osx.py プロジェクト: tcolar/berry4all
def load_pocketmac():
    bb_messenging.status('Re-enabling pocketmac')
    subprocess.call([
        'kextload',
        '/System/Library/Extensions/net.pocketmac.driver.BlackberryUSB.kext/'
    ])
    restart_kextd()
コード例 #4
0
ファイル: bb_osx.py プロジェクト: tcolar/berry4all
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()
コード例 #5
0
ファイル: bb_usb.py プロジェクト: tcolar/berry4all
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.")
コード例 #6
0
ファイル: bb_osx.py プロジェクト: tcolar/berry4all
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."
    )
コード例 #7
0
ファイル: bb_usb.py プロジェクト: tcolar/berry4all
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.")
コード例 #8
0
ファイル: bb_usb.py プロジェクト: tcolar/berry4all
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))
コード例 #9
0
ファイル: bb_usb.py プロジェクト: tcolar/berry4all
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))
コード例 #10
0
ファイル: bb_usb.py プロジェクト: tcolar/berry4all
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.")
コード例 #11
0
	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.")
コード例 #12
0
 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.")
コード例 #13
0
ファイル: bb_usb.py プロジェクト: tcolar/berry4all
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
コード例 #14
0
ファイル: bb_usb.py プロジェクト: tcolar/berry4all
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
コード例 #15
0
ファイル: bb_usb.py プロジェクト: tcolar/berry4all
def reset(device):
    bb_messenging.status("Resetting device")
    device.handle.reset()
    bb_messenging.status("Reset sent.")
コード例 #16
0
ファイル: bb_osx.py プロジェクト: CesarBallardini/linberry
def uninstall_kextd():
    bb_messenging.status('Removing cutom Kernel Ext. File')
    os.remove("/System/Library/Extensions/libusbshield_rim.kext")
    restart_kextd()
コード例 #17
0
ファイル: bb_usb.py プロジェクト: CesarBallardini/linberry
def reset(device):
	bb_messenging.status("MSG:Reseteando Dispositivo")
	device.handle.reset()
	bb_messenging.status("Reset sent.")
コード例 #18
0
ファイル: bb_tether.py プロジェクト: tcolar/berry4all
    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"])
コード例 #19
0
ファイル: bb_osx.py プロジェクト: CesarBallardini/linberry
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()
コード例 #20
0
ファイル: bb_osx.py プロジェクト: tcolar/berry4all
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'])
コード例 #21
0
ファイル: bb_usb.py プロジェクト: tcolar/berry4all
def reset(device):
    bb_messenging.status("Resetting device")
    device.handle.reset()
    bb_messenging.status("Reset sent.")
コード例 #22
0
	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!"])
コード例 #23
0
ファイル: bb_osx.py プロジェクト: CesarBallardini/linberry
def load_pocketmac():
	bb_messenging.status('Re-enabling pocketmac')
	subprocess.call(['kextload', '/System/Library/Extensions/net.pocketmac.driver.BlackberryUSB.kext/'])
	restart_kextd()
コード例 #24
0
 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.")
コード例 #25
0
ファイル: bb_osx.py プロジェクト: tcolar/berry4all
def uninstall_kextd():
    bb_messenging.status('Removing cutom Kernel Ext. File')
    os.remove("/System/Library/Extensions/libusbshield_rim.kext")
    restart_kextd()
コード例 #26
0
	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.")
コード例 #27
0
ファイル: bb_osx.py プロジェクト: CesarBallardini/linberry
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'])