벨킨 블루투스 키보드(F5L150/F5L107) 매트릭스

meh에서 지난 달에 샀던 갤럭시 탭 2/노트 1세대 10.1용 벨킨 블루투스 키보드를 잘 쓰고 있었으나, 평소 쓰는 키보드가 해피해킹 프로 2와 주옥션이었던 탓에 극악의 키감을 이기지 못하고 개조의 충동을 느꼈다. 주옥션이 고장난 지 좀 되었기 때문에 스위치를 추출해서 이식해 보려는 시도를 하고 있었고, winkeyless 사이트에서 파는 기판에 주옥션에서 적출한 스위치를 이식해서 성공시켜 보았다. 곁다리로 얻은 정보 중에 삼성 DT-35와 같은 멤브레인 키보드에서 컨트롤러만 적출해서 쓰는 사례가 있었고, 마침 2개 중 1개는 내다 버려도 되는 상황이었기 때문에 부술 각오를 하고 작업을 시작했다.

문제의 블루투스 키보드는, 멤브레인 스위치와 보강판이 양면 테이프로 붙어 있고, 그 아래에는 고무판과 플라스틱 케이스가 있는데 모든 게 다 양면 테이프로 붙어 있다. 컨트롤러 및 배터리는 고무판 아래에 숨겨진 나사를 돌려서 적출할 수 있으나, 멤브레인 스위치에 접근하려면 키보드를 거의 부숴야 한다. 아, iFixit 같은 데 파는 열을 가해서 접착제 떼내는 걸 모르는 건 아니지만 원래 키보드 그 자체는 하나 더 있기 때문에 컨트롤러만 적출한다는 생각으로 미련없이 부쉈다. 이 와중에 접착제로 붙어 있는 190mAh 리튬 이온 배터리가 분해 중에 걸리적거려서 이걸 먼저 떼야 했다. 떼는 과정에서 배터리에 생긴 생채기 때문에 다시 쓰기는 좀 꺼려지긴 한다.

멤브레인 스위치와 기판이 연결되는 부분을 보면 L1-L24 인덕터 부품이 있고 그 옆으로 TP12-TP35 테스트 패드가 있다. 주의해야 할 점이 L1-L5까지는 L1, L2, L5, L3, L4 순서대로 되어 있고 TP35와 TP34는 순서가 바뀌어 있다. 이 매트릭스에 나와 있는 것은 회로 기판 내에 배치된 순서를 따른다. 이 키보드는 L12-L19와 그 나머지로 Row/Column이 구분된다.

belkin_f5l107_matrix주옥션에서 적출한 스위치를 직접 연결하여 확인하였다. 이제 기판을 만들어야 하는데 어떻게 하나.

자급제 단말기 SKT/KT 3G HD 보이스(와이드밴드 오디오) 사용법

m4s0n501

국내에 단말기 자급제가 정착된 지도 제법 오래 되었지만, 아직까지는 유럽 국가처럼 아무 설정 없이 단말기의 모든 기능을 완벽하게 사용하기는 전산을 완전히 갈아 엎지 않는 한 어렵다. 한때는 외국산 LTE 단말기를 사용하려면 이통사 전산에 등록해야 하는 시절도 있었지만, 이제는 LTE 밴드만 맞으면 등록시켜 주는 정도까지 되었고, 이제 남아있는 것은 3G HD 보이스, VoLTE 등의 기능 정도다.

3G HD 보이스(와이드밴드 오디오)는 3G 서킷 스위치(CS) 망에서 AMR-WB 코덱을 사용하는 음성 통화이다. 소니 에릭슨 시절 정발된 엑스페리아 일부 기종이 AMR-WB를 지원하기는 했지만, 통화 양방이 모두 AMR-WB를 사용해야 하고 그것도 통신사 안에서만 가능하였기 때문에 아이폰 5가 등장하기 전까지는 국내에서 거의 기억하지 않았다.

아이폰 5가 정발된 이후 통신사 전산이 개선되어 KT는 3G HD 보이스를 모든 자급제 단말기에 대해서 개방하였고, SKT는 한동안 자사를 통해 유통되는 단말만 3G HD 보이스를 허용하였다가 최근에서야 자급제 단말에도 개방하였다. 물론 바로는 안 되고 별도로 IMEI를 등록(통신사 지점에서 모델명 변경)해야 한다. KT의 경우 해외 단말기에 최초로 USIM을 장착하면 전산상에서 “OPENMODEL1/2″로 인식하고, SKT의 경우 “OMD DEFAULT 핸드셋”으로 인식한다. (홈페이지 상 기기 모델로 구분 가능) 이 모델을 변경해 주어야 3G HD 보이스를 사용할 수 있다. VoLTE와 비슷하게 현재는 같은 통신사를 사용하고 VoLTE/3G HD 보이스를 사용하는 사람끼리만 HD 보이스 통화가 가능하다.

KT의 경우 3G 전용 휴대폰은 PTA-TYPE1HD(PTA-TYPE1과는 다름), LTE 지원 휴대폰은 PTA-TYPE3HD(PTA-TYPE3과는 다름)로 모델명을 변경하면 된다. PTA-TYPE2/4는 각각 3G/LTE 태블릿에 해당한다. (출처: 토렌트고고) SKT의 경우 한동안 이렇게 사용하는 것이 불가능하였다가, 최근에서야 ODH2(OMD DEFAULT 핸드셋_3G HD Voice)로 모델명 변경이 허용되었다. (출처: 뽐뿌클리앙) 이 외 통신사를 통해 정발된 3G HD 보이스 지원 단말기는 유통한 통신사마다 정책이 다르다. MVNO(알뜰폰)을 사용하는 경우, 알뜰폰 회사마다 모회사(SKT/KT) 전산 접근 권한이 다르기 때문에 알뜰폰 고객센터에서 변경이 불가능하면 모회사 휴대폰을 사용하는 사람을 USIM 기변 상태로 모델명 변경을 하면 가능하다.

kt_pta_type3

문제는 이러한 작업을 동네 대리점에서는 해 주지 않으려고 하고 114에 전화를 걸면 신분증을 팩스로 보내야 하기 때문에 오프라인으로 하려면 각 통신사 지점을 찾아가야 한다. KT의 경우 대전 시내 서로 다른 2개 지점에서 모델명 변경 요청 시 신분증만 제시하면 가능하였다. (안드로이드나 iOS가 아닌 휴대폰은 IMEI 화면을 표시해 두는 것을 추천) KT 개통 이력이 없는 단말기의 경우 전산상에서 미등록 단말기로 분류되므로, 한 번은 USIM 기변을 한 상태로 대리점을 찾는 것을 추천한다. 여러 대의 단말을 동시에 등록할 경우 USIM 기변 이력만 있으면 된다. 아직까지 SKT는 시도해 보지 않았다.

3G HD 보이스는 표준 요금제에서도 사용 가능하다. 자신의 휴대폰이 3G HD 보이스를 지원하는 지 여부는 제조사에 문의해야 한다. 블랙베리 10 OS를 탑재한 휴대폰은 모두 지원하며, Jolla 역시 지원한다. 소니 휴대폰의 경우 다이얼러에 *#*#7378423#*#*(SERVICE)을 입력한 다음 Service Info -> Configuration과 같은 메뉴에서(기종마다 세부 항목은 다를 수 있음) 부트로더 언락 상태와 함께 Available Speech Codec에 AMR-WB가 있는 지 여부로 판단 가능하다. 블랙베리 10 OS의 전화 통화 화면에서는 HD 보이스 사용 여부가 시간 표시줄 위에 나타나지만, 표시기가 없는 휴대폰의 경우 통화 음질 등으로 판단하는 방법밖에 없다.

IMG_20141030_202035

2011년 베를린 여행기 – 3

8월 9일에는 포츠담 상수시 궁, 작센하우센 수용소를 둘러보았고, 8월 10일에는 베를린 통신 박물관, 8월 11일에는 베를린 지하 벙커 관광, 8월 12일에는 동독 박물관 등을 다녀왔다. 이미 이 시점에서는 Desktop Summit 정규 프로그램이 끝났고, KDE e.V. 회원이 아니었기 때문에 e.V. 모임에 들어가 봤자 할 수 있는 것도 없었고, BoF 세션 참가는 정규 발표에 비하면 널널하기 때문에 관광에 쓸 시간이 많이 있었다. 인텔에서 AppUp 프로그램을 소개하면서(지금은 확실히 망했다고 기억하지만) 별도의 신청을 받는 BoF를 열었는데 여기에서 기념품으로 아톰 기반 태블릿 ExoPC를 나눠 주는 사태가 발생했고, 나는 그 시간대의 다른 BoF를 듣는다고 이걸 취소해 버리는 바람에 눈 앞에서 ExoPC를 놓쳐 버렸다. 이 사건의 교훈으로 나는 별도의 신청을 받는 BoF가 있다면 신청을 해 두는 것이 좋다는 것을 깨달았다. 이 외에도 번역자 BoF가 내 기억이 맞다면 이 해부터 진행되었고, 그 이후 KDE 번역자들끼리 Akademy에서 계속 만나고 있다.

모든 여행의 출발점은 숙소 근처인 베를린 프리드리히슈트라세 역이었다. 제3제국 시기 베를린에 있었던 유대인들이 빠져나가는 통로이자, 베를린으로 집결하여 강제 수용소로 보내지는 허브 역을 담당하기도 하였다. 아래에 있는 동상은 이들의 엇갈리는 운명을 나타낸 삶을 향한 열차, 죽음을 향한 열차라는 제목이 붙어 있다. 베를린 분단 이후 과거 동베를린에 있었고, 서베를린과 동베를린 간 국경역으로 활용되었다. 역 앞을 지나는 지하철 U6호선은 베를린 분단 시기엔 잠시 동베를린 구간을 지났는데 이 역에서 환승이 가능하다. 국경 통과 지점 주변은 서독과 동독의 가족이 눈물의 이별을 하였다는 뜻으로 Tränenpalast라고 불렸다.

프리드리히슈트라세 역 앞 동상

프리드리히슈트라세 역 앞 동상

포츠담은 베를린의 서쪽에 있고, RE/RB/S반으로 이동할 수 있다. 포츠담에서는 상수시 궁을 둘러보고 다음 목적지인 작센하우젠 수용소로 이동하였다. 나치 시기 중부 및 동부 유럽에 많은 강제 수용소가 건설되었고, 현재는 해체되거나 박물관으로 용도가 변경되었다. 작센하우젠 수용소는 지금의 독일 영토 내에 남아 있는 수용소 중 가장 큰 규모이며, 동독이 살아 있었을 때에는 소련군에 의해서 비슷한 목적으로 사용되었다. 유명한 문구인 “Arbeit Macht Frei”의 복제품은 여기에도 있다. 수용소가 해방되기 전 죽음의 행진을 기념하는 비석이 설치되어 있다.

베를린의 통신 박물관은 전신, 우편, 현대의 통신에 관해서 다루고 있으며 DHL로 유명한 현대 독일 우편이 어떻게 발달했는지를 보여 주고 있다. 근처에 있는 커리부어스트(Currywurst) 박물관은 전후 베를린의 경제 상황에서 어떻게 커리부어스트가 탄생했는지를 다루고 있다. 단순히 소시지를 구워서 카레 가루와 케찹을 쳐서 내놓는 음식이지만, 베를린 시내에서는 패스트푸드 가게와 술집을 비롯한 여러 곳에서 찾을 수 있는 음식이기도 하다.

베를린 게준트브루넨(Gesundbrunnen) 역에서는 베를린 지하 투어에 참가할 수 있다. 게준트브루넨 역 근처에 매표소에서 투어를 시작할 수 있으며, 사람이 꽤나 많기 때문에 일찍 와서 예약해야 한다. 내가 참가했던 베를린 지하 관광은 게준트브루넨 역 근처의 나치 시기 지하 벙커에서 시작하였다. 그 때의 벙커는 전기를 사용하려면 직접 발전기를 돌리는 시스템이었고, 폭격을 견딜 수 있는 수준의 단순한 벙커였다. 베를린 분단 이후 서베를린 지역에 지어진 벙커는 내부가 현대화되었고, 비상 식량과 식수를 나치 시기 벙커보다 더 많이 저장할 수 있었다. 현재 이 벙커는 당초 계획된 목적을 상실하고 관광 자원으로 사용되고 있지만, 만에 하나 비상 사태가 생기면 원래 목적대로 복원이 가능할 수준으로 관리되고 있다.

박물관 섬 근처에는 동독 박물관이 있으며, 동독 시기의 정치사보다는 동독 국민의 생활사를 위주로 전시하고 있다. 동독에서 사용되었던 소비재와 더불어 슈타지의 감시가 어떠한 식으로 진행되었고, 동독의 의회가 작동하는 방식을 상당히 재미있는 모형으로 만들어 두었다. 손잡이를 돌리면 안건이 전환되고 동독 의회 의원들이 전부 손을 든다. 하나의 안건만 있는 것이 아니라 여러 안건들이 돌아가면서 튀어나오긴 하는데 손을 다같이 든다는 점은 완전히 동일하다.

이 외에도 베를린 TV 송신탑, 박물관 섬의 나머지 박물관 근처를 둘러보기는 했지만 시간상의 이유로 전부 입장해 보지는 못했다. TV 송신탑은 3년 후 다른 이유로 방문하게 된다. Akademy가 끝난 다음에는 다른 숙소로 이동하여 독일 동부를 잠깐 동안 둘러볼 준비를 하였다.

Enabling Qualcomm diagnostic mode on Jolla

Since Jolla uses Qualcomm MSM8930AA, it is possible to use Qualcomm diagnostic tools in theory. They are not available by default and the way to enable this functionality is not yet discovered. I poked various options of usb-moded but diagnostic mode did not came out. I ended up editing some files and finally managed to get the diagnostic mode on my Jolla.

DISCLAIMER: you may void your warranty, especially poking with various Qualcomm-related tools. You have been warned.

usb-moded files are located under /etc/usb-moded and there are several ini files defining modes. USB mode selection UI gives options for PC Suite, Developer mode, Charging only. Those two modes are defined in /etc/usb-moded/dyn-modes/developer_mode-android.ini and pc_suite-android.ini. The file contains USB gadget settings like vendor and product ID, and most importantly, USB mode.

What is exposed via USB interface is determined by /sys/class/android_usb/android0/functions file. Directly modifying sysfs values seems not to work, only via editing usb-moded configuration files. usb-moded changes these values accordingly to the INI file. This is setting for developer mode.

$ cat /etc/usb-moded/dyn-modes/developer_mode-android.ini 
[mode]
name = developer_mode
module = none
network = 1
network_interface = rndis0

[options]
sysfs_path = /sys/class/android_usb/android0/functions
sysfs_value = rndis
sysfs_reset_value = none
softconnect_path = /sys/class/android_usb/android0/enable
softconnect = 1
softconnec_disconnect = 0
idProduct = 0A02

To enable diagnostic mode, you can append diag into sysfs_value and extra lines like this (you must be root to edit INI files):

$ cat /etc/usb-moded/dyn-modes/developer_mode-android.ini 
[mode]
name = developer_mode
module = none
network = 1
network_interface = rndis0

[options]
sysfs_path = /sys/class/android_usb/android0/functions
sysfs_value = rndis,diag
sysfs_reset_value = none
softconnect_path = /sys/class/android_usb/android0/enable
softconnect = 1
softconnec_disconnect = 0
idProduct = 0A02
android_extra_sysfs_path = /sys/class/android_usb/android0/f_diag/clients
android_extra_sysfs_value = diag

You need to restart phone or “systemctl restart usb-moded.service” to take the effect. When the file is modified, selecting developer mode on USB connection also activates diagnostics interface on USB. On Windows system there is no driver available for newly added diagnostics port. You can use driver from other Qualcomm-based devices, but the device name should include “diagnostics port”. I used driver from LTE USB stick.

If device is normally detected, you can now use Qualcomm tools to poke Jolla’s radio. Be careful not to brick this part! They are independent from OS!

When there are problems in USB usage, restore the values to original. Back up your system before potentially dangerous operations!

Extracting official firmware image of Casio G’zOne LTE (C811)

Most stock rom of Casio G’zOne 4G LTE (C811) is extracted from stock devices after uploading corresponding firmware. Verizon also supports firmware restoration tool from PC. There were some efforts to extract real stock firmware from that image but that never happened. I analyzed the Verizon firmware restoration tool and how to extract (not flash) firmware images uploaded on NEC Casio server.

There are some INI files bundled with Verizon tool (TL-Bootstrap). It specifies base address where all required tools are uploaded. When executed, the program checks all required tools’ version from http://baseaddress/ToolVersion.txt, downloads newer version when available. Real upgrade processes are hidden in the tool downloaded by bootstrap. Latest version of firmware is checked via /files.txt which contains version, size and some other information. Downloading firmware itself is straightforward by using filename from the text file, but only latest version is available from official server. All previous versions were deleted.

The firmware consists of single ZIP  file, which then contains single MBN file for flashing. Despite same extension as Qualcomm tools, it uses proprietary format to encode and encrypt the image. Metadata is located at the last 2KB of MBN file. It starts with header, something like version and number of partitions. Each partition record basic information of partition and “flags”. EXT4 partition images are stored in standard sparce format which could be restored using simg2img. Other images stored with trailing zero bytes stripped, with separate original size information. All binary data except header is XOR encrypted, which differs among partition and even among firmware version.

I deduced XOR keys by comparing “extracted” file system images with encrypted images, which share same header bytes. XOR key of EXT4 sparce partition is also easily deducible since they use standard Android magic numbers. Attached source code calculates XOR key and extracts file system image. Probably works on Linux and OS X.

eut_extract

Using the attached source code, you can obtain “pure” stock ROM which is not altered by flashing and dumping.