몇주전 Font를 바꾸기 위해 /system/fonts에 접근해서 파일명을 변경하고 추가하는 작업을 했었는데,
그 이후로 Identity Tab이 부팅이 되지 않았다. Android 캐릭터만 보일 뿐...

결국 KT 측 A/S를 받아볼까 하다가 최근에 알게된 odin, adb와 같은 툴이면 접근하여 파일 변경이 가능하지 않을까 하는 생각이 들었다.
(실은 KT까지 찾아가는 수고가 귀찮아서 이런 방법을 생각하게 되었다.)

결론적으로 말하면, root로도 접근이 가능하며 시스템 파일의 잘못 변경되어 부팅이 안되던 사람들에게 이 방법이 다 통할 것 같았다. (아님 말고)
방법을 천천히 되새김질하며 여기에 기록하고 싶어 이렇게 늦은(?) 시간에 글을 쓰게 되었다.

방법은 의외로 간단했다. 단, Identity Tab에 대한 자료가 정확하게 나오지 않았을 뿐이다.

1. 먼저, Identity Tab 홈페이지를 통해 USB Driver를 다운로드 받아 설치한다.
  - http://www.identitytab.com - 다운로드 - 기타 소프트웨어 - USB Driver 에서 "자동설치(WinXP)"를 사용했다.


2. 위 상태에서 Identity Tab의 전원을 인가하여 PC에 연결하여 Driver가 제대로 설치되도록 하며, 잘 설치되었을 경우 아래와 같은 USB 장치가 인식되게 된다.
 - Enspert Android Composite ABD Interface
 - USB 대용량 저장장치

3. SuperOneClick 프로그램을 가동하여 "Root Shell"을 클릭한다. (SuperOneClick 프로그램은 지난번 포스팅을 통해 다운로드 가능함)

4. 이 상태에서 시작-실행-cmd 를 실행하여 SuperOneClick이 설치된 폴더로 이동 후 adb를 통해 shell 접속을 한다.
 - adb shell 을 실행할 경우 server가 가동하여 "#" 프롬프트를 만나면 root 계정으로 접근이 된 것이다.
 - adb shell 로 해도 "$" 프롬프트만 나올 경우, adb kill-server 실행 후 adb root 나 adb shell을 해본다. (이래도 안되면 댓글로 문의 바람)

5. # mount 실행을 하면 /system 이 read-only인지 read-write 상태인지 알 수 있으며, 보통 read-only 이므로 파일 변경을 위해서는 변경 작업이 필요하다.
 - # mount -o rw,remount -t yaffs2 /dev/block/mtdblock4 /system

# mount
mount
rootfs / rootfs ro,relatime 0 0
tmpfs /dev tmpfs rw,relatime,mode=755 0 0
devpts /dev/pts devpts rw,relatime,mode=600 0 0
proc /proc proc rw,relatime 0 0
sysfs /sys sysfs rw,relatime 0 0
none /acct cgroup rw,relatime,cpuacct 0 0
tmpfs /mnt/asec tmpfs rw,relatime,mode=755,gid=1000 0 0
none /dev/cpuctl cgroup rw,relatime,cpu 0 0
/dev/block/mtdblock4 /system yaffs2 ro,relatime 0 0   -> ro 에서 rw로 변경 필요!!!!
/dev/block/mmcblk0p1 /data ext4 rw,nodev,noatime,commit=60,barrier=0,journal_async_commit,nobh,data=writeback,noauto_da_alloc 0 0
/dev/block/mtdblock5 /cache yaffs2 rw,nosuid,nodev,relatime 0 0
/dev/block/mmcblk0p3 /upgrade vfat rw,nosuid,nodev,noatime,fmask=0000,
dmask=0000,allow_utime=0022,codepage=cp437,iocharset=iso8859-,shortname=mixed,errors=remount-ro 0 0

5. 이후 원하는 작업을 수행하면 시스템을 복원할 수 있다. (나 같은 경우에는 /system/fonts에 있던 파일들을 올바른 파일명으로 수정하여 부팅 되도록 하였음)

Driver는 다른 포스팅을 통해 설치했다면 인식이 가능할 것이다. 단, 수동으로 설치했을 경우에는 수동으로 장치관리자-드라이버 업데이트 작업을 통해 연결해주어야 한다.

Posted by wbhacker :

Identity Tab (아이덴티티 탭)을 우연찮게 얻게 되었는데, 이것저것 사용하다 보니 루팅이 필요했다.
아이폰만 쓰던 나에게 안드로이드를 꽤 많이 생소했지만, 그만큼 자료도 많아 금방 익숙해졌다.

먼저 Identity Tab을 루팅하려고 했으나 자료가 충분치 않아 커널과 안드로이드 버전에 따라 방법을 찾아보았다.
우연찮게 삼성 갤럭시폰 쪽에서 같은 버전이 있는 것을 알았고 SuperOneClick을 이용하면 왠만한 폰은 루팅이 다 된다는 것을 알았다.

1. Identity Tab의 Android 버전과 커널 버전을 살펴보자. 맞지 않다면 업그레이드를 하기 바란다.
  - Identity Tab에서 홈 → 설정 → 시스템 정보을 통해 확인
  - Android 버전 : 2.2
  - 커널 버전 : 2.6.32.9 (yk2134@overseer #2)
  나의 경우에는 위와 같았으며, 최근에 Identity Tab 홈페이지(http://www.identitynet.co.kr)을 통해서 최신 F/W(11072504)로 업그레이드 한 상황이다.

2. Identity Tab의 USB 디버깅 모드를 켜고 PC 상에 관련 Driver를 설치하자.
  - Identity Tab에서 홈 → 애플리케이션 → 개발 → USB 디버깅 [사용]으로 설정
  - PC와 USB로 연결 후, Android로 잡히는 Device에 Driver를 연결해준다. (Identity Tab에서 다운받을 수 있음) 


3. 이젠 Identity는 준비가 되었으며 PC에 SuperOneClick을 띄우면 된다.
  - SuperOneClick.exe 파일을 실행하면 창이 뜨는데 "Root"를 클릭하면 끝이다.
  - "Shell Root"를 클릭한 후 Identity Tab을 재부팅하라고 하면 지시대로 하게 되면 루팅이 된 상태로 부팅이 될 것이다.


추가적으로 SSHDroid 같은 어플을 통해 shell로 접속해서 확인할 수 있다.




참고사이트 : super one click으로 갤럭시U, 루팅 하는 법 그리고 언루팅 하는 법, [Android] 안드로이드폰 루팅하는 방법

Posted by wbhacker :

아침에 일어나서 할 일이 있었는데, 알람이 울리지 않았다.
혹시나 하는 마음에 다시 한번 설정해보고 기다려보기도 하고, 전원을 껐다켜보기도 하고 했지만 알람이 울리지 않았다.

어떻게 해야하나??
2011년 1월 1일부터 아이폰 버그로 새해를 맞이하다니;;;

네이버에 검색해보니, 오후부터 관련 글이 생기기 시작했다.
해결방법은 아직까지 임시로 요일마다 설정하는 방법 뿐이었다.



아직까진 Patch가 나올 때까진 이렇게 쓰는 수 밖에 없다.

Posted by wbhacker :

mpx on serial port

2009. 5. 31. 04:22 from 컴퓨터/Linux
멀티포인트 프로젝트를 시작한지 벌써 두달이..

다시 되새겨보면, 임베디드 보드에서 멀티 좌표 정보를 보내주고, USB를 통해 리눅스 디바이스 드라이버를 만드는 것이 최종 목적이다.
하지만 현재 임베디드 보드 상에서 멀티 좌표 정보를 보내줄 수 있는 형편이 아니다. 문제로는 보드 상에서 영상처리를 위해 제공되는 라이브러리나 드라이버 등을 고려해서 제한적인 웹캠만 가능하기 때문이다... ln2440의 r1.4 lcd를 이용해서 임베디드 리눅스를 탑재해서 하려고 했으나, 결국 해당 lcd에 대한 리눅스 디바이스 드라이버가 존재하지 않아서 포기! (제조사에서 제공을 안해줌).
그리고, smdk2440 보드에서 임베디드 리눅스를 포팅하고 하고 있는데, 웹캠 드라이버가 적재되었지만, 해당 qt 버전과 gcc 컴파일러 버전이 너무 낮아서 현재 설치된 서버용 리눅스에서 가동이 안된다는 점.. 아무튼 어려움이 많았다.

그런 상황에서 일단, ln2440 보드에 winCE를 탑재하고나서 로지텍Pro5000 웹캠을 기다리는 중이다... 일단은 winCE에서 lcd에 터치를 하면, 그 좌표 정보를 서버용 리눅스에 전송하게 하였고(강세욱 담당), 전송받은 데이터를 리눅스 드라이버단에서 처리하여 터치스크린 이벤트로 전달하여 mpx기반의 X-window에서 두개 이상의 좌표로 인식하게 하는 것으로 마무리를 지었다. 영상처리를 추가해야 진짜 멀티 포인트인데...

암튼 현 상황은 아래와 같다.



뭐니뭐니해도 임베디드 보드에서 보내는 시리얼 데이터를 가동되는 리눅스 상에서 인터럽트로 처리하는 것이 중요하다. 물론, 터치 스크린 드라이버는 기존 리눅스에 있는 시리얼 기반의 터치 스크린 드라이버를 참조해서, 최대한 비슷하게 구현하였다. (0x80의 의미는 몇년이 지나도 잊혀지지 않을 만큼 나에게 충격을 주었다.. 시리얼 기반이라 0x00이 전송이 불가능하다는 거.. 이걸 어찌 알고 0x80으로 미리 선수를 썼는지..암튼.. 존경스러운 전세계 해커들..)

실행 방법을 까먹을 듯하여 정리해본다.

1) 터치 스크린용 이벤트 드라이버를 생성하는 시리얼 디바이스 드라이버 적재

# insmod uv_mtd.ko
# ./inputattach --uv_mtd /dev/ttyS0 &
# dmesg
May 31 11:20:22 mola_server uv_mtd_init
May 31 11:20:27 mola_server serio: Serial port ttyS0
May 31 11:20:27 mola_server uv_mtd_connect
May 31 11:20:27 mola_server uv_mtd[0] ttyS0/serio0/input0
May 31 11:20:27 mola_server uv_mtd[1] ttyS0/serio0/input1
May 31 11:20:27 mola_server input: UV Serial Multi-TouchScreen #1 as /class/input/input8
May 31 11:20:27 mola_server input: UV Serial Multi-TouchScreen #2 as /class/input/input9


2) 임베디드 보드에서 시리얼로 좌표값을 보내는 프로그램 실행 후 터치 테스트

# dmesg
uv_mtd->count = 2
uv_mtd->length = 13
0 input_report_abs(uv_mtd->dev, ABS_X, 543)
0 input_report_abs(uv_mtd->dev, ABS_Y, 176)
0 input_report_key(uv_mtd->dev, BTN_TOUCH, 0)
1 input_report_abs(uv_mtd->dev, ABS_X, 553)
1 input_report_abs(uv_mtd->dev, ABS_Y, 176)
1 input_report_key(uv_mtd->dev, BTN_TOUCH, 0)

3) X-server 가동

ssh1# ./start_xserver
ssh2# ./start_xclient
ssh3# ./start_mpwm
ssh4# xterm &
ssh4# xinput --list --short
"Virtual core pointer"  id=0    [XPointer]
"Virtual core keyboard" id=1    [XKeyboard]
"Virtual core Xtst pointer"     id=2    [XExtensionPointer]
"Virtual core Xtst keyboard"    id=3    [XExtensionKeyboard]
"Mouse0"        id=4    [XExtensionPointer]
"Mouse1"        id=5    [XExtensionPointer]
"Keyboard0"     id=6    [XExtensionKeyboard]
"<default pointer>"     id=7    [XExtensionPointer]
# xinput --create-master "foobar1"
# xinput --reattach "Mouse0" "foobar1 pointer"
# xinput --create-master "foobar2"
# xinput --reattach "Mouse1" "foobar2 pointer"
# xinput --list --short
"Virtual core pointer"  id=0    [XPointer]
"Virtual core keyboard" id=1    [XKeyboard]
"Virtual core Xtst pointer"     id=2    [XExtensionPointer]
"Virtual core Xtst keyboard"    id=3    [XExtensionKeyboard]
"Mouse0"        id=4    [XExtensionPointer]
"Mouse1"        id=5    [XExtensionPointer]
"Keyboard0"     id=6    [XExtensionKeyboard]
"<default pointer>"     id=7    [XExtensionPointer]
"foobar1 pointer"       id=8    [XPointer]
"foobar1 keyboard"      id=9    [XKeyboard]
"foobar1 Xtst pointer"  id=10   [XExtensionPointer]
"foobar1 Xtst keyboard" id=11   [XExtensionKeyboard]
"foobar2 pointer"       id=12   [XPointer]
"foobar2 keyboard"      id=13   [XKeyboard]
"foobar2 Xtst pointer"  id=14   [XExtensionPointer]
"foobar2 Xtst keyboard" id=15   [XExtensionKeyboard]

4) 추가적인 설정 사항 (Xorg.conf)

Section "ServerLayout"
        Identifier     "X.org Configured"
        Screen      0  "Screen0" 0 0
        InputDevice    "Mouse0" "SendCoreEvents"     <- 중요
        InputDevice    "Mouse1" "SendCoreEvents"     <- 중요
        InputDevice    "Keyboard0" "CoreKeyboard"
        Option         "AllowEmptyInput" "off"
        Option         "AutoAddDevices" "off"
EndSection
...........중략..........
Section "InputDevice"
        Identifier  "Mouse0"
        Driver      "evdev"
        Option      "Protocol" "usb"
        Option      "Device" "/dev/input/event6"       <- 위에 적재된 모듈에 의해 생성된 event 파일 #1
        Option      "ZAxisMapping" "4 5"
EndSection
Section "InputDevice"
        Identifier  "Mouse1"
        Driver      "evdev"
        Option      "Protocol" "usb"
        Option      "Device" "/dev/input/event7"       <- 위에 적재된 모듈에 의해 생성된 event 파일 #2
        Option      "ZAxisMapping" "4 5"
EndSection



p.s. 시리얼 디바이스 드라이버를 개인적으로 꼭 정리하고 싶다. 너무나 고생한 걸 생각하면... ㅡ.ㅜ
Posted by wbhacker :



너무나 돌아온 느낌이다. 시리얼 통신으로 터치스크린 이벤트 좌표값을 가져오기 위해서 구현하는 것인데... 원래는 USB로 할 예정이지만, 그 전에 시리얼로 한번 해보는 것이다. 특별한 설정 없이도 되는 줄 알고.. 하지만, 시리얼 디바이스 드라이버 구현보다는, 연결에 어려움이 꽤 있었다.

우선 kernel의 driver/input/touchscreen/mtouch.c 파일의 내용을 수정해서 새로운 uv_mtd 장치에 대한 시리얼 디바이스 드라이버를 작성하였다.

static int __init mtouch_init(void)
{
        return serio_register_driver(&mtouch_drv);
}

static void __exit mtouch_exit(void)
{
        serio_unregister_driver(&mtouch_drv);
}

module_init(mtouch_init);
module_exit(mtouch_exit);




위 소스는 모듈의 등록과 해제를 담당하는 루틴으로, 보면 insmod 해당모듈.ko를 하게 되면, 그냥 serio_register_driver이 호출되고, 드라이버가 새로이 등록되버린 상태로 가만히 있게 된다.

static irqreturn_t mtouch_interrupt(struct serio *serio,
                unsigned char data, unsigned int flags)
{
        struct mtouch* mtouch = serio_get_drvdata(serio);

        mtouch->data[mtouch->idx] = data;

        if (MTOUCH_FORMAT_TABLET_STATUS_BIT & mtouch->data[0])
                mtouch_process_format_tablet(mtouch);
        else if (MTOUCH_RESPONSE_BEGIN_BYTE == mtouch->data[0])
                mtouch_process_response(mtouch);
        else
                printk(KERN_DEBUG "mtouch.c: unknown/unsynchronized data from device, byte %x\n",mtouch->data[0]);

        return IRQ_HANDLED;
}



위 루틴은 해당 드라이버의 인터럽트 처리 부분이다. 즉, 시리얼 포트(ttyS0)를 통해 데이터가 들어오면, 위 루틴에서 처리를 담당하는 것이다. 이 말은, 데이터가 들어오게 되면 무조건 인터럽트가 걸리게 된다는 것으로, 이 함수에 들어와야 정상이다.. 하지만, 단순히 모듈을 적재하는 것으로 인터럽트를 연결하진 못했다. 이 전에 인터럽트 자체가 등록이 되지 않은 상황이었다. ㅡ.ㅜ

static int mtouch_connect(struct serio *serio, struct serio_driver *drv)
{
        struct mtouch *mtouch;
        struct input_dev *input_dev;
        int err;

        mtouch = kzalloc(sizeof(struct mtouch), GFP_KERNEL);
        input_dev = input_allocate_device();
        if (!mtouch || !input_dev) {
                err = -ENOMEM;
                goto fail1;
        }

        mtouch->serio = serio;
        mtouch->dev = input_dev;
        snprintf(mtouch->phys, sizeof(mtouch->phys), "%s/input0", serio->phys);

        input_dev->name = "MicroTouch Serial TouchScreen";
        input_dev->phys = mtouch->phys;
        input_dev->id.bustype = BUS_RS232;
        input_dev->id.vendor = SERIO_MICROTOUCH;
        input_dev->id.product = 0;
        input_dev->id.version = 0x0100;
        input_dev->dev.parent = &serio->dev;
        input_dev->evbit[0] = BIT_MASK(EV_KEY) | BIT_MASK(EV_ABS);
        input_dev->keybit[BIT_WORD(BTN_TOUCH)] = BIT_MASK(BTN_TOUCH);
        input_set_abs_params(mtouch->dev, ABS_X, MTOUCH_MIN_XC, MTOUCH_MAX_XC, 0, 0);
        input_set_abs_params(mtouch->dev, ABS_Y, MTOUCH_MIN_YC, MTOUCH_MAX_YC, 0, 0);

        serio_set_drvdata(serio, mtouch);

        err = serio_open(serio, drv);
        if (err)
                goto fail2;

        err = input_register_device(mtouch->dev);
        if (err)
                goto fail3;

        return 0;

 fail3: serio_close(serio);
 fail2: serio_set_drvdata(serio, NULL);
 fail1: input_free_device(input_dev);
        kfree(mtouch);
        return err;
}



우선 인터럽트를 등록하는 위 connect 함수가 호출되어야 한다. 하지만, 이 함수 역시 모듈 적재만으론 되지 않았다. 솔직히 이 문제를 해결하기 위해 약 3일간 밤낮없이 고생한 것 같다. 구글에 검색을 해봐도 이 문제에 봉착한 경우만 있지, 해결 방법에 대해선 별다른 말이 없었기 때문이다. 그 과정에서 알게 된 것이 setserial과 inputattach 프로그램 뿐이었고, 이것에 대한 자세한 설명도 없는 상황이었다.

/*
 * The serio driver structure.
 */

static struct serio_device_id mtouch_serio_ids[] = {
        {
                .type   = SERIO_RS232,
                .proto  = SERIO_MICROTOUCH,
                .id     = SERIO_ANY,
                .extra  = SERIO_ANY,
        },
        { 0 }
};

MODULE_DEVICE_TABLE(serio, mtouch_serio_ids);

static struct serio_driver mtouch_drv = {
        .driver         = {
                .name   = "mtouch",
        },
        .description    = DRIVER_DESC,
        .id_table       = mtouch_serio_ids,
        .interrupt      = mtouch_interrupt,
        .connect        = mtouch_connect,
        .disconnect     = mtouch_disconnect,
};



위 소스와 같이 mtouch_drv는 mtouch_init 함수에 의해서 시리얼 디바이스 드라이버로 등록이 되지만, 실제로 .connect로 정의된 mtouch_connect 함수는 호출이 되지 않는 문제...

결국은, 구글 검색의 힘(해커들의 질의응답... 검색어는 "lagacy serial driver .connect")으로 해결할 수 있었다.

- 참고사이트1 : http://kerneltrap.org/mailarchive/linux-kernel-mentors/2007/12/5/477437
- 참고사이트2 : http://lkml.org/lkml/2007/6/19/254 - Writing a driver for a legacy serial device
- 참고사이트3 : http://lkml.indiana.edu/hypermail/linux/kernel/0706.2/1755.html

The problem is that taos_connect is never called. I suppose that I need
different values for .type, .proto or .id, except that I just don't
know what to put there. I tried a few random values without success.
What's the trick?


참고로 위 질문에서 나의 문제와 똑같다는 것을 느끼게 되었다. 이 never called라는 메시지가 정말 반가웠다 ㅡ.ㅜ
해당 글의 쓰레드를 조금 추적해서 들어가면 inputattach.c 소스를 구할 수 있고(http://linuxconsole.cvs.sourceforge.net/viewvc/*checkout*/linuxconsole/ruby/utils/inputattach.c), 이 프로그램에 새로운 시리얼 디바이스의 속성을 지정하고, 실행하면 해당 시리얼 디바이스 드라이버와 연결된다는 것을 알게 되었다.
inputattach를 실제 실행하면, 키보드 입력을 받게 되어 있어서 어떻게 사용하는지 조금 난해했었다.

kernel/Documentation/input/joystick.txt 문서에서 inputattach -xxx /dev/tts/X & 를 보고, 이렇게 하니 잘 되었다;;

May 30 09:55:29 mola_server uv_mtd_init
May 30 09:55:59 mola_server serio: Serial port ttyS0
May 30 09:55:59 mola_server uv_mtd_connect
May 30 09:55:59 mola_server uv_mtd ttyS0/serio0/input0
May 30 09:55:59 mola_server input: UV Serial Multi-TouchScreen as /class/input/input13
May 30 09:56:12 mola_server uv_mtd_interrupt
May 30 09:56:12 mola_server uv_mtd unknown/unsynchronized data from device, byte 53
May 30 09:56:12 mola_server uv_mtd_interrupt
May 30 09:56:12 mola_server uv_mtd unknown/unsynchronized data from device, byte 63
May 30 09:56:12 mola_server uv_mtd_interrupt
May 30 09:56:12 mola_server uv_mtd unknown/unsynchronized data from device, byte 72



위 메시지는 커널의 메시지이며, insmod uv_mtd.ko를 하고 ./inputattach --uv_mtd /dev/ttyS0 & 를 한 후, 시리얼을 통해 데이터를 보낸 상태이다. 아직 인터럽트에서 제대로 처리를 하지 않아 위 메시지가 나왔지만, 인터럽트 내에 제대로 진입한 것을 볼 수 있다.;;

p.s.#1 이거 안되면 드라이버단에서 sys_open( /dev/ttyS0 )을 해서 처리하려고 했었다..
         장치에서 값이 들어오든 안들어오든 무조건 blocking된 상태에서 말이다.;;; 그래도 다행이다. 드라이버 단에서 되서~
p.s.#2 앞으로는 이벤트 드라이버와 연결해서 시리얼에서 온 데이터를 이벤트화 하면 된다.
         (이벤트 드라이버는 이미 테스트 종료 상태 ^^;;)

Posted by wbhacker :