2011년 11월 1일 화요일

android open GL ES 2.0 sample

단말기에서 Open GL ES 2.0이 동작하는 확인 할 수 있는 app

http://code.google.com/p/gdc2011-android-opengl/


svn checkout http://gdc2011-android-opengl.googlecode.com/svn/trunk/ gdc2011-android-opengl-read-only


동작하면 open GL ES 2.0 compatibility 하다고 할 수 있겠죠.


ODROID-A에서 동작하는 모습



2011년 10월 29일 토요일

android-2.3.6_r1(GRK39F) android-2.3.7_r1(GWK74)

android git가 부할해서 간만에 받아 odroid7(s5pc110), odroid-a(s5pc210)와 merge 하였습니다.

android-2.3.6_r1(GRK39F)은 통화에 bluetooth 기능이 추가 된것 같습니다. framework에 bluetooth 관련이 수정 되었고 settings에도 수정 되었더군요.

android-2.3.6_r1(GWK74)는 NFC(nxp)에 firmware upgrade 기능이 추가되었습니다.
저희가 따로 NFC를 개발하는게 있는 관계로 merge를 할 수가 없더군요. chip vendor에서 2.3.7을 release 해주면 그 때 고려 해 봐야 겠습니다.

각 버전은 일단 repo sync로 master를 받으시고 framework/base 폴더에서 git tag를 하시면 현재 어떤 tag가 있는지 확인이 가능합니다.


[~/projects/android-master/frameworks/base]$ git tag
android-1.6_r1
android-1.6_r1.1
android-1.6_r1.2
android-1.6_r1.3
android-1.6_r1.4
android-1.6_r1.5
android-1.6_r2
android-2.0.1_r1
android-2.0_r1
android-2.1_r1
android-2.1_r2
android-2.1_r2.1p
android-2.1_r2.1p2
android-2.1_r2.1s
android-2.2.1_r1
android-2.2.1_r2
android-2.2.2_r1
android-2.2_r1
android-2.2_r1.1
android-2.2_r1.2
android-2.2_r1.3
android-2.3.1_r1
android-2.3.2_r1
android-2.3.3_r1
android-2.3.3_r1.1
android-2.3.4_r0.9
android-2.3.4_r1
android-2.3.5_r1
android-2.3.6_r0.9
android-2.3.6_r1
android-2.3.7_r1
android-2.3_r1


 그리고 repo forall -c git checkout tag명 이렇게 하시면 특정 버전으로 source를 받으실 수 있습니다.

android-4.0.1 버전 emulate도 돌려봤는데 항상 느끼는 거지만 emulate가 너무 느려서...

곧 ICS가 공개 되겠죠... 기대 됩니다.

ODROID-7에 android-2.3.6...


android(Gingerbread)에서 USB 3G Modem 사용하기

android 2.2(froyo)에 HSDPA 3G Modem을 붙여 본 적있습니다.
제 blog에 post한 적이 있습니다.

이번에 gingerbrea(2.3)에 올리는데 성공은 했는데 삽질을 많이 했습니다.
아직 해결 못한 문제도 있고...

ril-daemon이 pppd가 동작하기 전에 특정 동작을 하면 SKTelecom이나 안테나 상태 등을 업데이트 할 수 있습니다. 그런데 이 상태가 되면 pppd로 연결이 실패가 됩니다.

그래서 부팅하고 usb modem이 ril-daemon의 어느 시점 보다 pppd로 접속을 먼저해야 하더라구요.

아래는 참고한 사이트...

그리고 성공 인증샷...

2011년 10월 1일 토요일

android에서 app을 SD에 설치하기 위해 kernel features.


android 2.2 froyo 버전 부터 app을 SD Card에 설치 할 수 있습니다.

2.6.35 kernel 이상부터 아래 feature를 켜 주면 SD Card로 옮기기가 가능합니다.

CONFIG_MD=y
CONFIG_BLK_DEV_DM=y
CONFIG_DM_CRYPT=y

CONFIG_CRYPTO_CBC=y
CONFIG_CRYPTO_TWOFISH=y
CONFIG_CRYPTO_TWOFISH_COMMON=y

2010년 10월 5일 화요일

android JNI을 이용하여 serial 읽어 오기

http://developer.android.com/sdk/ndk/index.html

위에 홈페이지에서 ndk를 다운 받고 적당한 디렉토리에 압축을 푼다.

eclipse에서 프로젝트를 하나 생성한다.

프로젝트 생성시 반드시 minSdkVersion="3"을 추가 해야 한다.

AndroidManifest.xml에 추가한다.

project 폴더에 jni 폴더를 만들다.

ndk/sample/ 폴더에 예제를 참조 하여 Android.mk를 생성한다.

LOCAL_PATH := $(call my-dir)

include $(CLEAR_VARS)

LOCAL_MODULE := gps_serial
LOCAL_SRC_FILES := gps_serial.c \
jni_serial.c

LOCAL_LDLIBS := -ldl -llog

include $(BUILD_SHARED_LIBRARY)



jni 폴더에 소스를 생성한다.

gps serial를 읽어 오는 gps_serial.h/c를 생성한다.

//---------------gps_serial.h-----------------------//
#ifndef GPS_SERIAL_H
#define GPS_SERIAL_H

char* read_serial();

#endif //GPS_SERIAL_H



//---------------gps_serial.c-----------------------//
#include
#include
#include
#include
#include
#include

#define GPS_SERIAL_NODE "/dev/ttyACM0"
#define READ_COUNT 256
#define LOG_TAG "GPS Serial"
#define LOGI(...) __android_log_print(ANDROID_LOG_INFO,LOG_TAG,__VA_ARGS__)

int fd = -1;
char buf[READ_COUNT];

int openGPS()
{
LOGI("oepnGPS()");

if (fd = open(GPS_SERIAL_NODE, O_RDONLY) >= 0) {
return fd;
} else {
LOGI("failed to oepn!");
return fd;
}
}

void closeGPS()
{
LOGI("closeGPS()");

if (fd)
close(fd);

fd = -1;
}

char* read_serial()
{
int read_count = 0;
int idx = 0;

memset(buf, 0x00, READ_COUNT);

if (fd == -1)
goto out;

read_count = read(fd, buf, READ_COUNT);
LOGI("count %d", read_count);
LOGI("%s", buf);

LOGI("read success!!");

out:
return buf;
}

여기까지는 일반적인 linux 프로그램이다. 단 printf로 메세지를 확인 할 수 없기 때문에 __android_log_print()를 이용하여 log를 확인 해야 한다.

그리고 java와 c library를 연결 할 jni 함수를 만든다.

//---------------jni_serial.c-----------------------/

#include
#include

#include

void Java_com_hardkernel_gpsserial_GPSSerialActivity_openGPS(JNIEnv* env, jobject obj)
{
openGPS();
}

jstring Java_com_hardkernel_gpsserial_GPSSerialActivity_readGPS(JNIEnv* env, jobject obj)
{
return (*env)->NewStringUTF(env, read_serial());
}

void Java_com_hardkernel_gpsserial_GPSSerialActivity_closeGPS(JNIEnv* env, jobject obj)
{
closeGPS();
}

JNI 함수의 이름 규칙은 Java_ 이후에 package name 그리고 jni를 호출 할 class 이름 그리고 함수 이름을 붙여 주면 됩니다.

Java_com_hardkernel_gpsserial_GPSSerialActivity_openGPS
_____패키지이름_______________class 이름_______함수 이름

이제 ndk를 이용하여 build를 해 보자.

jni 폴더에서 [android-ndk가 설치된 폴더]/ndk-build 명령으로 build를 한다.
하고 나면 아래의 그림과 같이 libs 폴더가 생성된다.


//---------------GPSSerialActivity.java-----------------------/
package com.hardkernel.gpsserial;

import com.hardkernel.gpsserial.R;

import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.util.Log;
import android.widget.TextView;

public class GPSSerialActivity extends Activity {
private TextView mTv;
private Thread mReadThread = null;
private String mString;
boolean mRunning = false;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
mTv = (TextView)findViewById(R.id.gps_textview);
}
@Override
protected void onPause() {
// TODO Auto-generated method stub
super.onPause();
if (mReadThread != null && mReadThread.isAlive()) {
Log.w("codewalker", "onPause()");
mRunning = false;
mReadThread = null;
}
closeGPS();
}

@Override
protected void onResume() {
// TODO Auto-generated method stub
Log.w("codewalker", "onResume()");
super.onResume();
openGPS();
if (mReadThread == null) {
mRunning = true;
mReadThread = new Thread(new Runnable() {
public void run() {
while (mRunning) {
try {
Thread.sleep(500);
} catch (InterruptedException ignore) {
}
mString = readGPS();
mHandler.sendMessage(mHandler.obtainMessage());
}
}
});
mReadThread.start();
}
}

@Override
protected void onDestroy() {
if (mReadThread != null && mReadThread.isAlive())
mReadThread.destroy();
// TODO Auto-generated method stub
super.onDestroy();
}
Handler mHandler = new Handler()
{
public void handleMessage(android.os.Message msg)
{
mTv.setText(mString);
};
};

public native String readGPS();
public native void openGPS();
public native void closeGPS();

static {
System.loadLibrary("gps_serial");
}
}

jni 함수를 위와 같이 등록해 주고 load해 주는 코드를 추가 한다.

2010년 8월 18일 수요일

odroid에 T-Login(LM-629HUL) 사용하기

이전에 HSDPA USB Modem(LM-629HUL )을 linux에서 사용하기 위한 내용을 posting 하였습니다.
linux에 먼저 작업한 이유는 odroid-t에 t-login을 사용하기 위해서 입니다.

그래서 이번 내용은 이전에 올렸던 linux 작업했던 내용을 이어서 android에 HSDPA USB Modem porting 방법을 posting합니다.

x86 usb-modeswitch는 libusb-0.1 버전을 사용하였습니다.
하지만 libusb android를 검색하면 libusb-1.0 버전이 있습니다.
그리고 libusb-1.0에 libusb-0.1버전을 사용할 수 있는 libusb-compat가 있습니다.
둘다 android용으로 library가 존재 합니다.
하지만 external에 넣고 빌드 하여 libusb.so와 libusb-compat.so를 만들어지만 dynamic link가 되지 않아서 configure에 --enable-static을 둘다 주고 usb_modeswitch도 static으로 만듭니다.
usbutils 역시 동일하게 static으로 만들면 lsusb를 통하여 usb mode switch가 되었는지 확인이 가능합니다.

여기서부터 추가
external 밑에 아래 세 폴더를 복사 합니다.
monaka-libusb-android-b35de21
monaka-libusb-compat-android-85dc44d
usb-modeswitch-1.1.3

monaka는 Android.mk가 있습니다.

usb-modeswitch-1.1.3에 Android.mk는 아래와 같습니다.

1 ifeq ($(TARGET_ARCH),arm)
2
3 LOCAL_PATH:= $(call my-dir)
4 include $(CLEAR_VARS)
5
6 LOCAL_SRC_FILES:= \
7 usb_modeswitch.c
8
9 LOCAL_SHARED_LIBRARIES := \
10 libusb-compat libusb
11
12 LOCAL_C_INCLUDES := \
13 $(LOCAL_PATH)/include
14
15 LOCAL_CFLAGS := \
16 -Iexternal/monaka-libusb-compat-android-85dc44d/libusb -pthread -rt
17
18 LOCAL_MODULE:= usb_modeswitch
19
20 include $(BUILD_EXECUTABLE)
21
22 endif

이렇게 추가하면 odroidt-img/system/bin/usb_modeswitch와 odroidt-img/system/lib/libusb.so, libusb-compat.so가 생깁니다.

그리고 추가로 external/monaka-libusb-android-b35de21/examples을 컴파일 하면 lsusb가 생깁니다.
Android.mk는 아래와 같습니다.

1 ifeq ($(TARGET_ARCH),arm)
2
3 LOCAL_PATH:= $(call my-dir)
4
5 include $(CLEAR_VARS)
6
7 LOCAL_SRC_FILES:= \
8 lsusb.c
9
10 LOCAL_C_INCLUDES += $(LOCAL_PATH)/android \
11 external/monaka-libusb-android-b35de21
12
13 LOCAL_SHARED_LIBRARIES := \
14 libusb
15
16 LOCAL_CFLAGS := \
17 -pthread -rt
18
19 LOCAL_MODULE:= lsusb
20
21 include $(BUILD_EXECUTABLE)
22
23 endif

이렇게 위에서 언급한 static문제는 해결 되었습니다.
추가 끝

다음 단계로 커널에 usb file system이 올라 가야 합니다. kernel에 usb file system을 추가 하시고
odroid-t는 ramdisk를 사용함으로 vendor/sec/android/conf/init_ramdisk.rc 파일에 usbfs를 mount하도록 추가 합니다.

mount usbfs none /proc/bus/usb

다음 부터는 아래 주소에 있는 x86 emulator에서 HSDPA를 연결한 내용을 참고하였습니다.

내용을 간략하게 설명하면 host linux에 modem을 연결하면 ttyUSB가 생성되고 여기서 command port인 ttyUSB3을 android의 ttyS1으로 연결한다는 내용입니다.

vendor/sec/odroidt/system.prop 파일을 아래와 같이 수정 합니다.

1 #
2 # system.prop for odroidt
3 #
4
5 rild.libpath=/system/lib/libreference-ril.so
6 #codewalker
7 #rild.libargs=-d /dev/ttyS0
8 rild.libargs=-d /dev/ttyUSB3
9 ro.sf.lcd_density=240

다음에 linux atdt sk라고 검색하면 HSDPA를 PPP에서 동작 하도록 하는 내용이 있습니다.
이 부분은 x86에서 가져온 chat이 있다면 desktop과 동일하게 처리 되는 부분입니다.

아래 사이트에 가면 ppp에 관한 내용이 있고 HSDAP USB modem에 AT command로 connection하는 내용이 있습니다.


usb_modeswitch를 통해 usb modem을 storage card에서 modem으로 변경 해줍니다.
insmod /modules/usbserial.ko 'vendor=0x1d74 product=0x00c9'으로 ttyUSB 노드를 생성해 줍니다.
여기서 따옴표를 주지 않으면 두번째 parameter product인자가 제대로 넘어가지 않습니다.
ppp call gprs를 호출 하면 t-login 모뎀이 녹색으로 바뀌면서 동작합니다.

지금은 간략하게 작성하였고 차후에 추가 보강하겠습니다.

2010년 8월 1일 일요일

Ubuntu에서 T-Login(HSDPA) 사용하기...

Ubuntu에서 T-Login을 사용하여 보자.


Ubuntu는 10.04, kernel 2.6.32-24이며 T-Login은 LG Innotek에 LM-629HUL 모델입니다.

기존에 IM-H100 (C-Motech) 모델의 경우 USB로 연결하면 /dev/ttyACM0로 연결이되기 때문에 kppp나 gnome-ppp에서 modem설정에서 ttyACM0로 설정을 하면 동작 됩니다.

하지만 C-Motech의 CHU-628S나 LG Innotek의 LM-629HUL의 경우 usb-modeswitch를 통해 mode를 변경해 줘야 합니다.


usb-modeswitch 1.1.3


libusb-0.1.12

컴파일하여 설치 합니다.

usb를 연결 후 lsusb 실행하면 아래와 같이 17d4:1004가 생깁니다.

codewalker@codewalker-desktop:~$ lsusb
Bus 007 Device 001: ID 1d6b:0001 Linux Foundation 1.1 root hub
Bus 006 Device 001: ID 1d6b:0001 Linux Foundation 1.1 root hub
Bus 005 Device 001: ID 1d6b:0001 Linux Foundation 1.1 root hub
Bus 004 Device 004: ID 0603:00f2 Novatek Microelectronics Corp.
Bus 004 Device 003: ID 045e:0040 Microsoft Corp. Wheel Mouse Optical
Bus 004 Device 002: ID 0ac8:301b Z-Star Microelectronics Corp. ZC0301 Webcam
Bus 004 Device 001: ID 1d6b:0001 Linux Foundation 1.1 root hub
Bus 003 Device 001: ID 1d6b:0001 Linux Foundation 1.1 root hub
Bus 002 Device 003: ID 1d74:1004
Bus 002 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
Bus 001 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
codewalker@codewalker-desktop:~$

Window에서도 PID가 1004로 붙고 driver 설치 후 PID가 00c9으로 변경되는 것을 확인 할 수 있습니다. 아마도 linux에서도 정상 동작 시키려면 1004가 00c9이 되면 되겠죠.
그래서 usb-modeswitch가 필요한 것입니다.

하지만 usb-modeswitch-data-20100707.tar.bz2 여기에는 LM-629HUL 모델 script가 없습니다.

usb-modeswitch-data-20100707를 설치 하셨다면 /etc/usb_modeswitch.d/에 1d74:1004로 아래의 파일을 만듭니다.

########################################################
# LG Innotek LM-629HUL

DefaultVendor=0x1d74
DefaultProduct=0x1004

TargetClass=0xff

CheckSuccess=20

MessageContent="55534243b82e238c240000008000081c020000000000000000000000000000"

위에 값을 어떻게 찾을 것인가가 최대의 문제 였습니다.

C-Motech CHU-629S가 제일 비슷하다고 판단하였습니다.

16d8:700a를 복사 하였고 DefaultVendor와 DefaultProduct는 lsusb의 값이 1d74그리고 1004를 입력 한다.

TargetClass의 경우 필요한지 판단할 수 없지만 Windows에서 드라이버 등록 정보를 보면 Class가 0xff로 되어 있는 부분을 확인 할 수 있다.

그리고 MessageContent 이 값은 usb-modeswitch의 설명 처럼 SniffUSB를 이용하여 logging을 할 수 있지만 plug/unplug를 해도 엄청난 line의 log가 생깁니다.

일단 UsbSnoop.log을 봅시다.

어떤 값을 MessageContent에 넣어야 할지 판단이 되지 않는다.


위에 사이트에 보면 IRP_MN_SURPRISE_REMOVAL를 검색해 보면 될거란 힌트를 얻을 수 있습니다.

아래의 log는 연결하고자 하는 pc에서 얻는 값이다.

[2577207 ms] <<<>
-- URB_FUNCTION_SELECT_INTERFACE:
ConfigurationHandle = 0x892e6698
Interface: Length = 56
Interface: InterfaceNumber = 0
Interface: AlternateSetting = 0
Interface: Class = 0x00000008
Interface: SubClass = 0x00000006
Interface: Protocol = 0x00000050
Interface: InterfaceHandle = 8911d440
Interface: NumberOfPipes = 2
Interface: Pipes[0] : MaximumPacketSize = 0x00000200
Interface: Pipes[0] : EndpointAddress = 0x00000001
Interface: Pipes[0] : Interval = 0x00000000
Interface: Pipes[0] : PipeType = 0x00000002 (UsbdPipeTypeBulk)
Interface: Pipes[0] : PipeHandle = 0x8911d45c
Interface: Pipes[0] : MaxTransferSize = 0x00001000
Interface: Pipes[0] : PipeFlags = 0x00000000
Interface: Pipes[1] : MaximumPacketSize = 0x00000200
Interface: Pipes[1] : EndpointAddress = 0x00000081
Interface: Pipes[1] : Interval = 0x00000000
Interface: Pipes[1] : PipeType = 0x00000002 (UsbdPipeTypeBulk)
Interface: Pipes[1] : PipeHandle = 0x8911d47c
Interface: Pipes[1] : MaxTransferSize = 0x00001000
Interface: Pipes[1] : PipeFlags = 0x00000000
[2577207 ms] UsbSnoop - FilterDispatchAny(adb9cfd2) : IRP_MJ_INTERNAL_DEVICE_CONTROL
[2577207 ms] UsbSnoop - FdoHookDispatchInternalIoctl(adb9d1ea) : fdo=88fcbc08, Irp=8924c678, IRQL=0
[2577207 ms] >>> URB 6 going down >>>
-- URB_FUNCTION_BULK_OR_INTERRUPT_TRANSFER:
PipeHandle = 8911d45c
TransferFlags = 00000002 (USBD_TRANSFER_DIRECTION_OUT, USBD_SHORT_TRANSFER_OK)
TransferBufferLength = 0000001f
TransferBuffer = b8513990
TransferBufferMDL = 00000000
00000000: 55 53 42 43 b8 2e 23 8c 24 00 00 00 80 00 08 1c
00000010: 02 00 00 00 00 00 00 00 00 00 00 00 00 00 00
UrbLink = 00000000
[2577209 ms] UsbSnoop - MyInternalIOCTLCompletion(adb9d126) : fido=00000000, Irp=8924c678, Context=8910a008, IRQL=2
[2577209 ms] <<<>
-- URB_FUNCTION_BULK_OR_INTERRUPT_TRANSFER:
PipeHandle = 8911d45c
TransferFlags = 00000002 (USBD_TRANSFER_DIRECTION_OUT, USBD_SHORT_TRANSFER_OK)
TransferBufferLength = 0000001f
TransferBuffer = b8513990
TransferBufferMDL = 8a32bcc8
UrbLink = 00000000
[2577209 ms] UsbSnoop - FilterDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_QUERY_CAPABILITIES)
[2577209 ms] UsbSnoop - FdoHookDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_QUERY_CAPABILITIES)
[2577209 ms] UsbSnoop - FilterDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_QUERY_PNP_DEVICE_STATE)
[2577209 ms] UsbSnoop - FdoHookDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_QUERY_PNP_DEVICE_STATE)
[2577209 ms] UsbSnoop - FilterDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_QUERY_DEVICE_RELATIONS)
[2577209 ms] UsbSnoop - FdoHookDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_QUERY_DEVICE_RELATIONS)
[2577213 ms] UsbSnoop - FilterDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_QUERY_DEVICE_RELATIONS)
[2577213 ms] UsbSnoop - FdoHookDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_QUERY_DEVICE_RELATIONS)
[2577213 ms] UsbSnoop - FilterDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_QUERY_DEVICE_RELATIONS)
[2577213 ms] UsbSnoop - FdoHookDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_QUERY_DEVICE_RELATIONS)
[2577213 ms] UsbSnoop - FilterDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_SURPRISE_REMOVAL)
[2577213 ms] UsbSnoop - FdoHookDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_SURPRISE_REMOVAL)
[2577243 ms] UsbSnoop - FilterDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_REMOVE_DEVICE)
[2577818 ms] UsbSnoop - FilterAddDevice(adba1748) : DriverObject 890f2950, pdo 893516b8
[2577818 ms] UsbSnoop - FilterDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_QUERY_LEGACY_BUS_INFORMATION)
[2577818 ms] UsbSnoop - FdoHookDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_QUERY_LEGACY_BUS_INFORMATION)
[2577818 ms] UsbSnoop - FilterDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_QUERY_RESOURCE_REQUIREMENTS)
[2577818 ms] UsbSnoop - FdoHookDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_QUERY_RESOURCE_REQUIREMENTS)
[2577818 ms] UsbSnoop - FilterDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_FILTER_RESOURCE_REQUIREMENTS)
[2577818 ms] UsbSnoop - FdoHookDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_FILTER_RESOURCE_REQUIREMENTS)
[2577818 ms] UsbSnoop - FilterDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_START_DEVICE)
[2577818 ms] UsbSnoop - FdoHookDispatchPnp(adba145c) : IRP_MJ_PNP (IRP_MN_START_DEVICE)
[2577819 ms] UsbSnoop - FilterDispatchAny(adb9cfd2) : IRP_MJ_SYSTEM_CONTROL
[2577822 ms] UsbSnoop - FilterDispatchAny(adb9cfd2) : IRP_MJ_INTERNAL_DEVICE_CONTROL
[2577822 ms] UsbSnoop - FdoHookDispatchInternalIoctl(adb9d1ea) : fdo=8a283890, Irp=890ce4d0, IRQL=0
[2577822 ms] >>> URB 1 going down >>>
-- URB_FUNCTION_GET_DESCRIPTOR_FROM_DEVICE:

#sudo usb_modeswitch -W -c /etc/usb_modeswitch.d/1d74:1004

codewalker@codewalker-desktop:~$ lsusb
Bus 007 Device 001: ID 1d6b:0001 Linux Foundation 1.1 root hub
Bus 006 Device 001: ID 1d6b:0001 Linux Foundation 1.1 root hub
Bus 005 Device 001: ID 1d6b:0001 Linux Foundation 1.1 root hub
Bus 004 Device 004: ID 0603:00f2 Novatek Microelectronics Corp.
Bus 004 Device 003: ID 045e:0040 Microsoft Corp. Wheel Mouse Optical
Bus 004 Device 002: ID 0ac8:301b Z-Star Microelectronics Corp. ZC0301 Webcam
Bus 004 Device 001: ID 1d6b:0001 Linux Foundation 1.1 root hub
Bus 003 Device 001: ID 1d6b:0001 Linux Foundation 1.1 root hub
Bus 002 Device 008: ID 1d74:00c9
Bus 002 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
Bus 001 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
codewalker@codewalker-desktop:~$

위와 같이 Product id가 바뀌어 있다.

이제 usbserial 드라이버를 올릴 차례입니다.

sudo lsmod usbserial vendor=0x1d74 product=0x00c9

그럼 /dev/ttyUSB 노드가 생성됩니다.

그후 kppp

오늘은 피곤해서 여기까지 낼 다시 작성하겠습니다.