207 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C++
		
	
	
		
			Executable File
		
	
	
			
		
		
	
	
			207 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C++
		
	
	
		
			Executable File
		
	
	
| /*
 | ||
|  * Copyright (C) 2008 The Android Open Source Project
 | ||
|  *
 | ||
|  * Licensed under the Apache License, Version 2.0 (the "License");
 | ||
|  * you may not use this file except in compliance with the License.
 | ||
|  * You may obtain a copy of the License at
 | ||
|  *
 | ||
|  *      http://www.apache.org/licenses/LICENSE-2.0
 | ||
|  *
 | ||
|  * Unless required by applicable law or agreed to in writing, software
 | ||
|  * distributed under the License is distributed on an "AS IS" BASIS,
 | ||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | ||
|  * See the License for the specific language governing permissions and
 | ||
|  * limitations under the License.
 | ||
|  */
 | ||
| #include <stdio.h>
 | ||
| #include <stdlib.h>
 | ||
| #include <string.h>
 | ||
| #include <errno.h>
 | ||
| #include <sys/wait.h>
 | ||
| #include <sys/types.h>
 | ||
| 
 | ||
| 
 | ||
| #define LOG_TAG "USB_DONGLE"
 | ||
| 
 | ||
| #include <cutils/log.h>
 | ||
| #include <sysutils/NetlinkEvent.h>
 | ||
| 
 | ||
| #include "G3Dev.h"
 | ||
| #include "MiscManager.h"
 | ||
| #include <unistd.h>
 | ||
| 
 | ||
| #if PLATFORM_SDK_VERSION >= 16
 | ||
| #define LOGV(fmt,args...) ALOGV(fmt,##args)
 | ||
| #define LOGD(fmt,args...) ALOGD(fmt,##args)
 | ||
| #define LOGI(fmt,args...) ALOGI(fmt,##args)
 | ||
| #define LOGW(fmt,args...) ALOGW(fmt,##args)
 | ||
| #define LOGE(fmt,args...) ALOGE(fmt,##args)
 | ||
| #endif
 | ||
| 
 | ||
| static char modeswitch_cmd[256] = "";
 | ||
| 
 | ||
| 
 | ||
| G3Dev::G3Dev(MiscManager *mm):Misc(mm)
 | ||
| {
 | ||
| 	
 | ||
| }
 | ||
| 
 | ||
| G3Dev::~G3Dev() {
 | ||
| }
 | ||
| 
 | ||
| int G3Dev::handleUsbEvent(NetlinkEvent *evt) {
 | ||
|  const char *devtype = evt->findParam("DEVTYPE");
 | ||
|     if( devtype!=NULL &&strcmp(devtype, "usb_device") )
 | ||
|         return 0;
 | ||
| 	pid_t status ;
 | ||
| 
 | ||
| 	NetlinkEvent::Action action = evt->getAction();
 | ||
| 	if( action == NetlinkEvent::Action::kAdd)
 | ||
| 	{
 | ||
|         const char *product = evt->findParam("PRODUCT");
 | ||
|         if(product!=NULL && product[0] != 0 && devtype[0] != 0 )
 | ||
|         {
 | ||
|             // »ñÈ¡VID/PID
 | ||
|             int vid = 0;
 | ||
|             int pid = 0;
 | ||
|             char * next = (char*)product;
 | ||
|             vid = strtol(product, &next, 16);
 | ||
| 		
 | ||
| 			//char pre[]="sVe.GT";
 | ||
|             ++next;
 | ||
|             pid = strtol(next, NULL, 16);
 | ||
| 
 | ||
|             SLOGD("== current usb device: %04X/%04X ===", vid, pid);
 | ||
| 
 | ||
|             char configure_file[2048];
 | ||
| 			
 | ||
| 			
 | ||
|             sprintf(configure_file, "/vendor/etc/usb_modeswitch.d/%04x_%04x", vid, pid);
 | ||
|             if( access(configure_file, 0) == 0 )
 | ||
|             {
 | ||
| 		sprintf(modeswitch_cmd, "/vendor/bin/usb_modeswitch -W -v %04x -p %04x -c %s &", vid, pid,configure_file);
 | ||
| 	    	SLOGD("=== USB Switch: %s", modeswitch_cmd);
 | ||
|                 system(modeswitch_cmd);
 | ||
|             }
 | ||
|         }
 | ||
| 	}
 | ||
| 	
 | ||
|     return 0;
 | ||
| }
 | ||
| int G3Dev::handleScsiEvent(NetlinkEvent *evt) {
 | ||
| /*
 | ||
|     ÓÐÒ»¶¨¸ÅÂÊÔÚusb_device Õâ¸öeventÖÐÖ´ÐеÄusb_modeswitchûÓгɹ¦£¬×÷Ϊ²¹×ã
 | ||
|     ÊֶΣ¬ÔÚSCSIÕâ¸öeventÖÐÔÙ´ÎÖ´ÐÐusb_modeswitch
 | ||
|  */
 | ||
|     if(evt->getAction()==NetlinkEvent::Action::kAdd && modeswitch_cmd[0] != 0)
 | ||
|     {
 | ||
|         SLOGD("=== SCSI Switch: %s", modeswitch_cmd);
 | ||
|         system(modeswitch_cmd);
 | ||
|         modeswitch_cmd[0] = 0;
 | ||
|     }
 | ||
| 
 | ||
|     return 0;
 | ||
| }
 | ||
| int G3Dev::handleUsb(){
 | ||
| 
 | ||
|  
 | ||
|  char configure_file[2048];
 | ||
|  int pid,vid;
 | ||
|  this->get_tty_id(&vid,& pid);
 | ||
|   
 | ||
|  sprintf(configure_file, "/vendor/etc/usb_modeswitch.d/%04x_%04x", vid,pid);
 | ||
|  SLOGD("=== config_file is: %04x_%04x", vid ,pid);
 | ||
|  if( access(configure_file, 0) == 0 )
 | ||
|  {
 | ||
| 	sprintf(modeswitch_cmd, "/vendor/bin/usb_modeswitch -W -v %04x -p %04x -c %s &", vid, pid,configure_file);
 | ||
| 	SLOGD("=== USB Switch: %s", modeswitch_cmd);
 | ||
| 	system(modeswitch_cmd);
 | ||
|  
 | ||
|   }
 | ||
|  return 0;
 | ||
|  }
 | ||
| int G3Dev:: get_tty_id(int *vid, int* pid)
 | ||
| {
 | ||
|    
 | ||
| 	   char linkto[1024]="";
 | ||
| 	   //SLOGD("began find device path");
 | ||
| 	  // SLOGD("device path: %s", tty_path);////	  
 | ||
| 	   		   
 | ||
| 	   //  LOGD("USB device path: %s", plink);
 | ||
| 	   char pidpath[PATH_MAX]="/sys/bus/usb/devices/1-1";
 | ||
| 	   
 | ||
| 		   FILE* fp = NULL;
 | ||
| 		   char buf[5] = {0};
 | ||
| 		   strlcat(pidpath, "/idVendor",PATH_MAX);
 | ||
| 	   	 SLOGD("Vendor path: %s", pidpath);
 | ||
| 		   fp = fopen(pidpath, "r");
 | ||
| 		   if(fp == NULL)
 | ||
| 			   return -2;
 | ||
| 		   if(fread(buf, 1, 4, fp) != 4)
 | ||
| 		   {
 | ||
| 			   fclose(fp);
 | ||
| 			   return -2;
 | ||
| 		   }
 | ||
| 		   fclose(fp);
 | ||
| 		   *vid = atox(buf, 16);
 | ||
| 	   char vidpath[PATH_MAX]="/sys/bus/usb/devices/1-1";
 | ||
| 	//sys/bus/usb/devices/1-1	
 | ||
| 		   strlcat(vidpath, "/idProduct",PATH_MAX);
 | ||
| 	   //	 LOGD("Product path: %s", plink);
 | ||
| 		   fp = fopen(vidpath, "r");
 | ||
| 		   if(fp == NULL)
 | ||
| 			   return -3;
 | ||
| 		   if(fread(buf, 1, 4, fp) != 4)
 | ||
| 		   {
 | ||
| 			   fclose(fp);
 | ||
| 			   return -3;
 | ||
| 		   }
 | ||
| 		   fclose(fp);
 | ||
| 		   *pid =atox(buf, 16);
 | ||
| 
 | ||
|     return 0;
 | ||
| }
 | ||
| #define EATCHAR(x, c) for (; *(x) == (c); (x)++) ; 
 | ||
| /* -1:error. */
 | ||
| int G3Dev:: atox( const char * line, int f_base )
 | ||
| {
 | ||
|     int base = 10;
 | ||
|     char max = '9';
 | ||
|     int v = 0;
 | ||
| 
 | ||
|     EATCHAR(line, ' ');
 | ||
|     if(*line == 0) return 0;
 | ||
|     
 | ||
|     if( line[1] == 'x' || line[1] == 'X' ){
 | ||
|         base = 16;
 | ||
|         max = 'f';      /* F*/
 | ||
|         line += 2;
 | ||
|     }
 | ||
|     else if(f_base==16)
 | ||
|     {
 | ||
|         base = 16;
 | ||
|         max = 'f';      /* F*/
 | ||
|     }
 | ||
|     
 | ||
|     if( base == 10 ) {
 | ||
|             while( *line >= '0' && *line <= max ) {
 | ||
|                         v *= base ;
 | ||
|                         v += *line-'0';
 | ||
|                         line++;
 | ||
|             }
 | ||
|     } else {
 | ||
|             while( *line >= '0' && *line <= max ) {
 | ||
|                         v *= base ;
 | ||
|                         if( *line >= 'a' )
 | ||
|                                 v += *line-'a'+10;
 | ||
|                         else if ( *line >= 'A' )
 | ||
|                                 v += *line-'A'+10;
 | ||
|                         else
 | ||
|                                 v += *line-'0';
 | ||
|                         line++;
 | ||
|                 }
 | ||
|     }
 | ||
|     return v;
 | ||
| }
 | ||
| 
 |