http://www.handhelds.org/moin/moin.cgi/HpIpaqHx4700HowtoInstallLinux
 

◎ Introduction


   iPAQ hx4700에서 WinCE 대신 Linux를 설치한다.

 ◦ 준비물

   ∘ iPAQ hx4700 기기

   ∘ USB 크래들

   ∘ 32MB 이상의 CompactFlash (CF) 메모리 카드

   ∘ 256MB 이상의 SD 혹은 MMC 메모리 카드

   ∘ CF/SD 메모리 카드를 PC에서 인식할 수 있게 해주는 컨버터 


◦ 백업 방법

   1. HTC bootloader shell 로 들어간다.


     ▪
Contacts 버튼과 iTask 버튼을 동시에 누른 후 장치의 하단에 있는 버튼 스타일러스 펜으로
      
눌러준다. 

   2. hx4700을 USB 크래들에 연결하고 크래들은 PC와 연결시켜 준다.

    ▪ USB로 연결된 상태라면 리눅스 시스템에서 /dev/ttyUSB0 에서 장치를 확인할 수 있다. 


   3. Linux에서 minicom을 실행
     ▪ Ubuntu Linux의 경우 minicom을 따로 설치해 주어야 한다.

       

$sudo apt-get install minicom


     ▪ 다음의 명령으로 minicom의 셋업 모드로 진입한다.

       

$minicom -os


     ▪ 다음과 같은 상태가 나타날 수 있도록 Enter를 몇 번 누른다.

       

USB>


   4. Flash Rom을 백업한다.

     ▪ SD 혹은 MMC 메모리 카드를 hx4700에 삽입하고 다음과 같은 명령을 한다.

       

USB>d2s

 SD:Waiting for card insert.........

 CMD3 for SD, it's OK, ready to get RCA from response.

 SD:Detected one card

 SD:ready for transfer OK

 Total card size=3D680000e=0

 SDCARDD2S+,cStoragePlatformType=FF

 ***************************************************************************

 Store image to SD/MMC card successful.

USB>


     ▪ 위와 같은 문들이 나오고 다시 USB> 상태가 되면 백업이 완료된 것이다.


   5. SD카드를 hx4700에서 빼서 SD 메모리 카드를 PC에서 인식할 수 있게 해주는 컨버터
에 꽂아준다.


   6. 다음과 같은 명령으로 Linux 환경에서 SD 메모리 카드가 인식되어 있는지를 살핀다.

       

$sudo fdisk -l


   7. 만일 SD 메모리 카드가 /dev/sdb 로 잡혔다면 다음과 같이 명령을 준다.
 
     ▪ dd는 Disk Dump / if는 input file / of는 output file

       

$dd if=/dev/sdb of=mybackup.img bs=130M count=1


     ▪ 백업된 이미지 파일은 소중히 보관하도록 한다.

 

◦ 인스톨 방법


   1.
http://familiar.handhelds.org/releases/v0.8.4/install/download.html 사이트에 접속하여
 
      다음과 같은 파일을 다운로드 한다.

       

homefs.jffs2                                     15-Jun-2006 13:15   256k

reflash.ctl                                       15-Jun-2006 13:15     1k

rootfs-gpe.jffs2                                 15-Jun-2006 13:28  20.5M

zImage                                          15-Jun-2006 13:22   1.1M


   2. Compact Flash Card을 FAT16 의 파일 시스템으로 포맷한 후 다운로드 받은 파일을
 CF 카드에 
       저장합니다.


   3. CF 카드를 hx4700의 슬롯에 꼽고
Contacts Inbox 버튼을 동시에 누르고 있는 상태에서
       스타일러스 펜으로 하단의 리셋 버튼을 눌러줍니다.


   4. 그러면 SDG Systems logo 와 함게
Scanning for images... 라는 메시지를 볼 수 있고 
      
잠시 후 이미지 파일을 불러오겠느냐는 물음을 볼 수 있습니다.

  
    ▪ 때로
Can't read control file 라는 메시지를 볼 수 있지만 Record 버튼을 여러번 누르다보면
      이런 문제를 해결할 수 있을 것입니다.

   5. Control file을 읽어들이는 작업이 끝나면 다음의 순서로 설치를 합니다.

     ▪ ↑버튼 : Contacts / ↓버튼 : Calendar / Select 버튼 : iTask

       

 kernel 설치 → root image 설치


     ▪ Erase 하는 중에 Erase failed 라는 메시지가 뜬다면 Reset 버튼을 누르고 배터리를 분리합니다.

       그리고 5-10분 후에 2. 의 단계부터 다시 실행합니다.

     ▪ root image 설치 시에는 상당한 시간이 소요되므로 끈기있게 기다립니다.

 

출처 : ZDNet Korea

 

프로그래밍은 잘하는데 하드웨어를 잘 몰라도 임베디드 시스템 개발자가 될 수 있을까? 전자공학을 전공했는데 임베디드 시스템 소프트웨어 프로그램을 잘할 수 있을까? 필자 또한 임베디드 시스템을 처음 시작할 때 이와 같은 심정이었다. 필자는 학부와 대학원에서 전자통신을 전공했다. 그리고 학부 때 배운 컴퓨터 언어는 포트란이 전부였다. 그것도 컴퓨터 없이 칠판수업을 받았다. OS와 32비트 프로세서를 접하기 시작한 것도 서른 살이 넘어서였으며, 프로그램 언어도 8비트 마이콤용 어셈블리 정도만 사용하는 수준이었다. 상상이 가는가?

필자는 임베디드 리눅스 기반 프로젝트를 다년간 수행하였으며, 현재 임베디드 리눅스 교육을 짧게는 5일 길게는 6개월 과정을 주관하며 가르치고 있다. 이 글은 그러한 경험을 바탕으로 임베디드 개발자가 되기 위해 필요한 기술적인 범위에 대해 말하고자 한다. 여기서는 먼저 PC 환경 개발과 임베디드 시스템 환경 개발과의 차이를 살펴 보고, 임베디드 시스템이 무엇인가를 효율적으로 설명하기 위해서 밥솥이라는 가전제품을 예로 들어 임베디드 시스템 개발자가 되기 위해서 필요한 것이 무엇인가를 알아 본다.

PC와 임베디드 시스템 환경의 개발 차이
PC와 임베디드 시스템의 개발 환경은 소프트웨어 개발 환경과 소프트웨어 개발 범위에서 차이가 있다.

현재까지 대부분의 소프트웨어 개발자들은 PC에서 작업을 수행해 왔다. <그림 1>과 같이 기존의 소프트웨어 개발과정은 소스 코딩을 하고 컴파일하고 실행하는 형태가 모두 PC 환경에서 이루어졌다. 하지만 임베디드 시스템 소프트웨어 개발 과정은 소스 코딩을 하고 컴파일을 수행한 후 이를 타겟 시스템으로 전송한다. 그리고 전송된 실행 코드를 타겟에서 실행한다.

<그림 1> PC와 임베디드 시스템 환경


이처럼 기존의 소프트웨어 개발자가 가장 먼저 어려움을 겪고 있는 것은 개발 환경이 다르다는 것이다. 임베디드 시스템에서 프로그램의 대상이 PC가 아닌 타겟 보드이기 때문이다. PC 소프트웨어 개발은 별도의 보드가 필요 없이 PC상에서 모든 것이 이루어지기 때문에 보드가 없어도 개발이 진행된다. 그러나 임베디드 시스템의 소프트웨어 개발은 타겟 보드가 필요하다. 그러므로 개발 보드가 없이는 임베디드 환경에서 소프트웨어 개발이 불가능하다.

또한 소프트웨어 개발자라 할지라도 타겟 보드에 대한 지식이 필요하다. 타겟 보드의 CPU 구조에 대한 이해와 어셈블러, 개발 보드의 주변장치의 이해 등이 필요하다. 이러한 것이 순수 소프트웨어만을 하던 개발자들이 겪는 어려움이라고 할 수 있다. 현재의 소프트웨어 개발 환경은 임베디드 환경으로 급속히 변해가고 있기 때문에 이러한 개발 환경의 이해 없이는 개발에 매우 큰 어려움을 겪을 수 있다.

이처럼 임베디드 시스템 소프트웨어 개발자가 되기 위해서는 개발 환경을 이해하고 이러한 시스템을 PC 사용하듯 능숙히 조작하는 것이 첫 번째 과제라고 할 수 있다.

소프트웨어 개발 범위의 차이
PC에서 소프트웨어 작업은 커널이나 디바이스 드라이버가 이미 준비된 상태에서 애플리케이션 작업만을 수행하는 것이었다. 물론 하드웨어도 거의 비슷한 형태로 제공된다. 그러나 임베디드 시스템에서는 사용되는 CPU가 다르고 이를 위한 개발 환경을 구축해야 하며, 직접 커널을 포팅해야 한다. 또한 디바이스 드라이버도 해당 시스템에 맞게 제작하여야 하며 그 이후에야 애플리케이션 프로그램을 작성한다.

임베디드 시스템이란 무엇인가?
임베디드 시스템은 우리 생활에서 쓰이는 각종 전자기기, 가전제품, 제어장치 등을 말한다. 이러한 장비의 특징은 단순히 전기, 전자회로로만 구성된 것이 아니라 마이크로프로세서가 내장되어 있다는 것이다. 이렇게 내장된 마이크로프로세서는 시스템을 구동해 그 장비가 해야 하는 특정 기능을 수행하도록 프로그램이 내장돼 있다.

이와 같은 임베디드 시스템은 산업, 가전, 사무, 군사 등의 다양한 응용 분야를 가지고 있으며 적용 사례도 휴대폰, PDA, 사이버 아파트의 홈 관리 시스템, 홈 네트워크 게이트웨이 장치, 교통관리 시스템, 주차 관리시스템, 홈 관리 시스템, 엘리베이터 시스템, 현금지급기(ATM), 항공 관제 시스템, 우주선 제어 장치, 군사용 제어 장치 등 다양한 곳에 응용이 된다.

임베디드 시스템을 좀더 쉽게 이해하기 위해서 생활가전 제품인 밥솥을 예를 살펴 보자. 다음은 밥솥의 발전 단계를 나타낸 것이다.

① 전기 회로로만 구성된 전기밥솥(초기)
② 간단한 4비트 또는 8비트 마이콤이 내장된 전자밥솥(현재)
③ 일반 PC 같은 기능을 가진 32비트급 프로세서가 내장된 전자밥솥(미래)


①은 단순히 히터라는 전기회로를 통해서 열을 가하여 밥을 짓는 장치이다. ①은 사람이 모든 제어를 수행하며, 독립적인 기능을 수행할 수 없기 때문에 임베디드 시스템이라 할 수 없다. ②와 ③은 독립적으로 기능을 수행할 수 있기 때문에 임베디드 시스템이라 말할 수 있다. 이렇듯이 임베디드 시스템은 CPU가 내장되어 있어서 시스템의 기능을 제어하는 시스템이라 할 수 있다.

②와 같은 경우는 사람이 하던 제어 기능을 4비트 또는 8비트의 마이콤이 펌웨어를 통해 수행한다. 이때 펌웨어란 OS 없이 동작되는 프로그램을 말하며, 4비트 8비트 마이콤에서 사용된다. 즉 프로세스가 하나라는 의미이다. ③은 밥을 하는 고유 기능 이외에 외부와 네트워크로 연결되어서 밥을 짓는 정보를 영상이나 음성 정보를 통해서 전달받으며 이를 사용자가 쉽게 사용할 수 있도록 GUI 환경을 제공하는 기능이 추가된 시스템을 말한다.

<그림 2>와 같이 32비트를 사용하며 여러 개의 프로세스가 존재하기 때문에 펌웨어를 사용할 수 없고, OS 환경 하에 동작하는 애플리케이션이 동작되는 시스템이다. 그리고 통신 기능을 구현하여야 하기 때문에 TCP/IP와 같은 프로토콜을 구현해야 하며 그래픽 LCD 기반의 GUI 환경이 기본적인 시스템이기 때문에 시스템 규모가 ②와는 매우 다르다. 마치 PC 하나가 밥솥에 들어가 있는 형태라고 할 수 있다.

<그림 2> 임베디드 시스템 구성


③과 같이 임베디드 시스템은 2000년대로 들어서면서 트렌드의 변화가 오기 시작했다. ②와 같이 마이콤에 펌웨어 기반의 고유 기능을 가지고 있는 것이 기존의 임베디드 시스템이었다면 ③은 고유 기능 이외에 부가 기능을 가지고 있고 이러한 부가 기능은 많은 정보량을 요구하기 때문에 단순한 8비트의 구조를 가지고 사용할 수 없다. 그 대안으로 사용된 32비트 프로세서 기반은 여러 개의 애플리케이션을 실행하기 위한 운영체제를 필요로 했으며 이에 따라 임베디드 시스템의 수요는 날로 커져가고 있다.

현재 임베디드 시스템의 특징은 PC가 가지고 있는 기능이 임베디드 시스템에 적용된다는 것이다. 그래서 이를 포스트 PC라고도 하고, 가전에 정보 전달 기능이 강화된 형태를 유지하기 때문에 이를 정보가전이라고도 일컫는다.

임베디드 시스템 개발 과정
임베디드 개발 과정은 크게 3가지로 나눌 수 있다.

① 임베디드 시스템 하드웨어 개발 과정
② 임베디드 시스템 교차 개발환경 구축 과정
③ 임베디드 시스템 소프트웨어 개발 과정


여기서는 일반 PC 같은 기능의 32비트급 프로세서를 내장한 전자밥솥을 통해 임베디드 시스템의 개발 과정을 설명한다. 개발 순서는 먼저 밥솥의 기능을 정하고 그에 맞는 하드웨어와 소프트웨어 기능을 협의한 후 각 기능을 구현하는 것이다. 개략적으로 하드웨어의 32비트 CPU는 X스케일 기반 PXA255이고, 운영체제는 임베디드 리눅스를 사용한다.

임베디드 시스템 HW 개발 과정
<그림 3>은 밥솥의 하드웨어 구성을 나타낸 것이다. CPU는 ARM 기반의 인텔에서 제공하는 PXA 255를, 메모리는 SDRAM 32MB, 플래시 16MB를 사용했으며 밥솥의 기능을 수행하기 위해 히터 로직(Heater Logic)이 있으며 외부에 TCP/IP 기반으로 통신하기 위해서 이더넷 컨트롤러를 달았다.

또한 사용자 인터페이스 역할을 하는 3.5인치 TFT LCD를 달았고, 터치스크린을 통해 사용자로부터 입력을 받을 수 있도록 했다. 그리고 사운드 로직을 통하여 음향 및 음성 정보를 사용자에 전달할 수 있도록 하드웨어를 설계했다.

<그림 3> 임베디드 시스템 하드웨어 구조


여기서 사용되는 PXA 255는 400MHz의 속도를 가진 고성능 CPU이다. 이는 몇 년 전 PC의 CPU 속도와 같은 수준의 CPU인 것이다. 그리고 메모리 또한 PC의 메모리와 비교해도 손색이 없을 정도의 용량이다. 일반 PC는 파일 시스템을 하드디스크에 구현하지만 여기서는 플래시 메모리에 구축한다.

크로스 개발 환경 구축과정
하드웨어 제작이 끝나면 교차(cross) 개발 환경을 구축하여야 한다. 크로스 개발 환경이란 호스트에 타겟 디바이스용 리눅스를 개발하기 위한 모든 환경을 말한다. 그리고 부트로더를 컴파일하여 해당 코드를 플래시 메모리에 넣은 후 부트로더를 수정해 원하는 기능을 구현한다. 임베디드 시스템의 개발 환경은 크게 3개 사항을 고려하여야 한다.

① 컴파일 환경인 XScale용 크로스 툴 체인(tool chain)
② 부트로더를 플래시에 올리기 위한 JTAG fusing 시스템
③ 부트로더 제작


개발 환경을 설명하기에 앞서 먼저 <그림 1>의 임베디드 시스템 환경에서 나오는 용어를 살펴 보자.

◆ 타겟 디바이스 : 개발하고자 하는 임베디드 시스템 보드, 여기서는 전자밥솥이 하드웨어이며, 사양은 <그림 3>과 같다.
◆ 호스트 시스템 : 타겟을 개발하기 위한 환경을 제공하는 시스템으로서 교차 컴파일러, 모니터, 디버거 등을 제공하며, 일반적으로 PC가 호스트가 된다.
◆ 백엔드(backend) : 호스트와 타겟이 통신을 하기 위한 매개체로, <그림 1>에서와 같이 시리얼은 통신 에뮬레이터를 통해 타겟과 통신할 수 있는 통신 채널을 제공한다. 패러럴은 JTAG을 통해서 플래시에 fusing할 수 있는 통신 채널을 제공한다. 이더넷은 zImage, root filesystem image를 호스트에서 타겟으로 다운로드할 수 있는 통신 채널을 제공한다.
◆ 타겟 터미널 : 타겟의 상황을 호스트에 표시해 주는 프로그램, 즉 통신 에뮬레이터를 말한다.


컴파일 환경 - X스케일용 크로스 툴 체인
먼저 해당 CPU에 맞는 툴 체인 환경을 구축한다. 툴 체인이란 타겟 디바이스의 소프트웨어 개발을 진행하기 위해 필요한 호스트 시스템의 크로스 컴파일 환경을 말한다. 툴 체인은 각종 소스들을 컴파일하고 빌드해 실행 바이너리를 생성하는 데 필요한 각종 유틸리티 및 라이브러리의 모음이다. 기본적으로 어셈블리, 링커, C 컴파일러, C 라이브러리 등으로 구성돼 있다. 여기서 사용하는 툴 체인은 GNU에서 제공하는 것으로 다음과 같다.

- GNU gcc compilers for C, C++
- GNU 바이너리 유틸리티(어셈블러, linker various object file utilities)
- GNU C 라이브러리


X스케일에 사용하기 위한 ARM 툴 체인은 다음과 같은 사항으로 구성되어 있다.

- binutils-arm-2.11.2 : 유틸리티
- gcc-arm-2.95.3 : 컴파일러
- glibc-arm-2.2.3 : 라이브러리


부트로더를 플래시에 올리기 위한 fusing 시스템
일반적으로 JTAG(Joint Test Access Group)란 말보다 Boundary-Scan이란 말이 더 많이 사용된다. 그럼 Boundary-Scan이라는 ‘주변을 훑어보다’라고 할 수 있다. 먼저 Boundary-Scan의 역사를 살펴보자.

◆ 1980년대 후반의 JTAG라는 곳에서 연구 중이던 Boundary-scan 설계를 IEEE에서 1990년에 표준화하였고 IEEE std 1149.1가 제정되었다.


<그림 4>와 같이 호스트 시스템으로부터 타겟 보드에 있는 스트라타(strata) 플래시에 부트로더를 쓰기 위해서는 그림과 같은 구성이 필요하다. 먼저 호스트 시스템의 구성부터 살펴보면 호스트 시스템에서 동작하는 jflash라는 프로그램이 필요하다. 이 jflash는 패러럴 포트를 이용하여 타겟 보드에서 필요로 하는 JTAG 신호를 생성한다. 호스트 시스템에서 생성된 JTAG 신호는 패러럴 케이블을 통해 동글(dongle)에 전달된다. 동글은 TTL 74HCT541을 사용해 구현했으며, 이 기능은 단지 호스트 시스템의 패러럴 포트에서 발생한 5V 전압을 PXA255에 적합한 3.3V 전압 레벨로 변환하는 기능이다.

<그림 4> JTAG을 이용한 플래시 메모리 퓨징


동글을 통해서 전달된 JTAG 신호 중 TMS와 TCLK는 TAP에 전달되어 JTAG의 state 머신을 결정하고, TDO와 TDI는 JTAG의 명령의 상태에 따라 bypass register, boundary scan cell, ID 레지스터 등의 입력과 출력 부분에 연결된다. PXA255의 JTAG을 통해서 플래시 메모리가 필요로 하는 버스 타이밍(bus timing)을 발생해 플래시에 전달한다.

호스트 시스템의 셸(shell)에서 jflash blob을 입력하면 x-boot250의 바이너리 코드가 플래시 메모리의 0번지부터 퓨징(fusing)을 한다. 메모리에 쓰기 전에 기본적으로 쓰고자 하는 0번 블럭을 지우고, blob을 퓨징한 후, 에러 없이 퓨징이 되었는지를 검사하기 위해 검증한 후에 이상이 없으면 x-boot250이 정상적으로 로딩을 완료하게 된다. 이 상태에서 시리얼 통신 환경의 설정에 이상이 없다면 정상적으로 x-boot250이 동작하는 것을 볼 수 있을 것이다.

부트로더 제작
<그림 5>와 같이 일반적으로 부트로더라 하면 일반 x86 리눅스에서는 LILO를 많이 사용할 것이다. LILO란 Linux Loader로서 DOS나 윈도우 NT, 리눅스 등 다른 OS를 선택적으로 부팅할 수 있도록 하는 기능을 제공한다. LILO는 하드디스크의 MBR에서 동작하는 프로그램으로 OS가 실행할 수 있도록 점프하는 기능을 수행한다.

<그림 5> LILO와 X-boot250과 비교


그럼 우리가 사용하는 x-boot250이란 부트로더는 플래시 0블럭에서 실행되고 여러 가지 다양한 기능들을 수행한다. 먼저 커널이나 램디스크(ramdisk) 등의 데이터를 호스트로부터 SDRAM 영역으로 다운로드할 수 있는 기능이 있고 SDRAM에 있는 데이터를 플래시 영역으로 라이팅할 수도 있다. 그리고 커널이 이미 올라가 있다면 부팅할 수 있는 기능도 같이 제공한다. 부트로더는 다음과 같은 기능을 갖고 있다.

하드웨어의 초기화 : 부트로더에서 제일 먼저 실행, CPU, 속도, 메모리, 인터럽트, UART 등을 초기화해 준다.
리눅스 부팅 : 부트로더 상에서 리눅스를 부팅하는 기능이 있다.
커널 또는 램디스크 다운로드 : 부트로더의 가장 중요한 기능인 커널이나 램디스크 이미지를 다운로드하는 기능이 있다. 호스트 상에서 컴파일된 이미지를 시리얼이나 tftp를 이용해 이더넷을 통해 SDRAM 상으로 다운로드가 가능하다.
다운로드한 커널 및 램디스크를 플래시에 라이트 : 다운로드한 커널과 램디스크 이미지는 SDRAM 상에 있기 때문에 전원이 꺼지면 다운로드한 이미지는 날라가 버린다. 그러므로 플래시 기능을 통하여 SDRAM 상의 커널과 램디스크를 지정된 플래시 주소 영역에 라이팅하는 기능이다.
tftp를 통한 SDRAM에 다운로드 : 시리얼을 통해 커널 등을 다운로드하기에는 속도가 너무 느리다. 그러나 tftp를 이용한 이더넷으로 다운로드할 수 있는 기능을 추가하여 고속으로 커널이나 램디스크를 다운로드할 수 있다.
 
임베디드 시스템 소프트웨어 개발과정
하드웨어가 제작되고 개발 환경이 구축되면, 다음으로 진행되는 과정은 <그림 6>과 같이 소프트웨어를 개발하는 일이다.
① OS 포팅(임베디드 리눅스 포팅)
② 디바이스 드라이버 제작
③ TCP/IP 등 미들웨어 제작
④ GUI 등 애플리케이션 제작

OS 포팅(임베디드 리눅스 포팅)
타겟 보드에 부트로더가 올라가 있으면 이제는 커널을 이식하는 순서이다. 현재 전자밥솥에는 임베디드 리눅스를 포팅을 한다. 포팅을 위해 우선 리눅스의 정식 버전을 어느 것으로 사용할 것인가 결정한다. 현재 포팅하려고 하는 리눅스 정식 버전은 2.4.18이다.

여기에 ARM 패치와 PXA255용 패치를 인가한다. 이 두 가지 패치는 일반적으로 공개되어 있다. 나머지 밥솥용 패치는 개발자가 개발해 패치 처리를 해야 한다. 여기에는 밥솥용 타겟 보드의 특성에 맞는 리눅스 초기화 코드와 하드웨어에 있는 디바이스 드라이버가 추가된다. 이렇게 해서 개발된 리눅스 커널은 밥솥을 위한 전용 커널이 된다.

디바이스 드라이버 제작
다양한 하드웨어 장치를 구동시키기 위해서 운영체제는 장치 드라이버를 필요로 한다. 임베디드 리눅스는 디바이스 드라이버를 캐릭터, 블럭, 네트워크 디바이스 드라이버로 구분한다. <그림 3>의 임베디드 시스템 하드웨어 구조를 참조하여 디바이스 드라이버를 분리해 보면 다음과 같다.

◆ 캐릭터 디바이스 드라이버 : 히터 디바이스 드라이버 제작, 사운드 디바이스 드라이버 제작, LCD 디바이스 드라이버 제작, 터치 디바이스 드라이버 제작
◆ 블럭 디바이스 드라이버 : 여기서 블럭 디바이스 드라이버는 파일 시스템과 밀접한 관계를 가지고 있다. 밥솥용 임베디드 시스템에서는 파일 시스템을 플래시에 구현하였기 때문에 여기서 필요한 블럭 디바이스 드라이버는 플래시를 제어하는 디바이스 드라이버이다. 이를 흔히 MTD(Memoty Technology Device)라고 하며 임베디드 시스템에서는 매우 중요한 개념이다.
◆ 네트워크 디바이스 드라이버 : TCP/IP 제어를 받는 이더넷 디바이스 드라이버를 구현한다.

TCP/IP 등 미들웨어 제작
또한 앞으로의 임베디드 시스템에서는 통신이 기본으로 자리를 잡게 될 것이다. TCP/IP를 기반으로 하는 프로토콜을 사용하여 임베디드 시스템이 다른 기기와 정보를 공유할 수 있다면 다양한 네트워크 서비스를 사용자에게 제공할 수 있다.

GUI 등 애플리케이션 제작
애플리케이션은 크게 다음과 같이 3가지로 볼 수 있다.

① 기본 기능 : 밥솥의 본 기능
② 부가 기능 1 : TCP/IP를 이용한 통신 기능
③ 부가 기능 2 : LCD를 이용한 GUI 기능

이 시스템의 가장 기본 기능은 밥솥의 기능이다. 이를 하나의 프로세스에 할당하여 애플리케이션을 제작한다. 그리고 TCP/IP를 통해서 각종 네트워크 기능을 구현한다. 마지막으로 GUI 기능을 제공한다. 임베디드 시스템에서는 대부분 제한된 크기의 디스플레이를 사용하고 있으며 이러한 장치에서 텍스트, 그래픽 및 영상을 표시하기 위해서는 특별한 GUI 기술이 필요하다. 현재 널리 사용되고 있는 내장형 시스템 GUI 기술들(타이니 X, 피코구이, Qt, 마이크로윈도우)이 적용되어 텍스트, 그래픽, 영상 등을 사용자에게 제공한다.

무엇을 준비해야 할까?
앞서 살펴봤던 것과 같이 우리가 이제껏 알고 있던 그리고 흔히 접해왔던 일반적인 컴퓨터 기반의 하드웨어, 소프트웨어 개발과는 달리 임베디드 시스템의 경우엔 그 개발 환경 구축부터 개발에 이르기까지 여러 가지 상이한 점들이 존재하기 때문에 처음 이를 접하는 개발자들은 다소 혼란스럽고 적응에 실패하기도 한다.

그러나 임베디드 시스템 역시 CPU(프로세서)와 메모리로 되어 있는(어느 특정 목적을 위해 개발된) 조그만 컴퓨터라 생각하고 개발에 임한다면 그리 어렵지만은 않을 거라고 필자는 확신한다. 즉, 임베디드 시스템 개발시 다음의 기본 기술 요소들만 확실하게 닦아 놓는다면 나름대로 쉽게 적응할 수 있지 않을까 싶다.

소프트웨어와 하드웨어의 기본 동작 원리
처음 컴퓨터 전원 버튼을 누른 순간 컴퓨터 보드 안에 이미 내장되어 있던 BIOS 프로그램이 실행되어 부팅 순서를 결정하고 부팅 가능한 운영체제가 선택됨과 동시에 해당 운영체제가 부팅하기 시작한다.

부팅이 끝난 운영체제 상에서 원하는 애플리케이션을 실행시키기 위해 마우스로 더블 클릭하는 순간 운영체제는 해당 애플리케이션을 메모리에 상주시킨 뒤 이를 실행시키게 되며 이때 만약 USB 같은 외부 디바이스들을 제어할 필요가 있을 경우 이를 제어하게 된다.

임베디드 시스템 역시 이와 마찬가지다. 전원이 들어감과 동시에 이미 내장되어 있던 부트로더가 실행되고, 이후 해당 임베디드 리눅스나 윈도우 CE 같은 운영체제가 실행되는, 이와 같은 소프트웨어와 하드웨어의 동작 원리에 대해 개발자는 이들이 실행되는 구조를 그려가며 반드시 이해해야만 할 것이다.

하드웨어 개발
필자의 생각에 이는 모든 개발자들에게 해당되는 사항은 아니라고 본다. 자신의 전공 분야에 따라 전문적으로 개발하는 분야가 다른 만큼 소프트웨어 개발자들은 하드웨어 개발 방법에 관해 사실 몰라도 된다. 그러나 하드웨어를 개발하는 방법을 몰라도 된다는 얘기가 하드웨어를 몰라도 된다는 얘기는 아니다. 아무리 컴퓨터상에서 소프트웨어를 전문적으로 개발하는 사람이라 할지라도 해당 컴퓨터의 하드웨어 사양(스펙)을 모른다면 어찌 원하는 성능을 얻을 수 있겠는가?

따라서 어떤 개발자라도 하드웨어에 대해 기본적으로 알아야 하며 임베디드 개발자의 경우엔 소프트웨어 전문 개발자들보다 조금 더 깊이 알아둘 필요가 있다. 그래야 개발자가 원하는 대로 하드웨어를 제어할 수 있을 테니까.

프로그래밍 언어
이는 사실 언급할 필요도 없는 사항일지 모른다. 전쟁에 참여하는 군인이 총을 놓고 간다면 어찌 되겠는가? 그러나 필자가 겪어 본 바에 따르면 총을 놓고 가는 군인들이 더러 눈에 보여 굳이 언급을 하고자 한다. 요즘에 가끔 TV를 보면 정말 화려한 가수나 연예인들이 많이 보이는 데 이는 눈에 보이는 것만을 쫓고 있는 요즘 세태가 반영되어 그런 듯 싶어 썩 반갑지가 않다. 이는 개발에서도 그대로 적용되는 데, 요즘 보면 결과가 바로 눈에 보이는 언어들에 사람들이 몰리며 이에 대한 책들도 많이 나오고 있다. 그러나 이들 중 C 언어부터 차근차근 밟아 나가는 사람들은 그리 흔하지 않은 건 왜일까?

어떤 프로그래밍 언어이든 하나는 확실하게 알고 있어야 한다. 그래야 확장이 가능하기 때문이다. 그러나 이런 언어들은 공부에 대한 결과가 바로 눈에 띄지 않기 때문에 중도에 포기하는 개발자들이 많다. 이는 영어를 공부하는 것으로 생각해보면 알 수 있다. 영어에는 왕도가 없다지 않은가. 그저 묵묵히 최선을 다해 습득하는 것 그 길뿐이다. 프로그래밍 언어 역시 마찬가지라고 생각된다. 조급해 하지 말고 묵묵히 습득하다 보면 어느새 늘어 있는 자신의 실력에 놀랄 때가 반드시 있을 것이다.

임베디드에 거는 기대감과 희망
이 글에서는 임베디드 시스템을 32비트 CPU 기반 임베디드 하드웨어 시스템, OS, 미들웨어, 애플리케이션의 계층 구조를 가지는 임베디드 시스템에 대하여 살펴보고 이들을 개발하기 위해서는 어떤 식으로 접근해야 할지 살펴보았다.

‘무어의 법칙’에서 말해주듯 하드웨어 사양들은 하루가 다르게 변화하고 있고, 이보다 더 빠른 속도로 소프트웨어 환경은 급변하고 있다. 그리고 이러한 환경에서 다양한 분야가 생겨나고 또 사라져 가고 있다. 이런 광속의 시대를 살면서 과연 우리의 개발자들은 어디에 서야 할 것인가에 대해 오랜 기간 개발자의 길을 걸어온 사람들은 누구나 고민하고 있으리라 생각된다. 과연 이 땅의 개발자들은 어디로 가야 하는가?

필자는 임베디드라는 분야에 우리가 서야 할 길이 있다고 확신하고 있으며, 이를 다양한 개발 경험과 강의 현장에서 몸소 느끼고 있다. 그러나 아직 인식이 많이 되어 있지 않기에 어찌하면 이 분야에 쉽게 접근할 수 있을지를 생각해봤다.

앞서도 언급하였지만 임베디드는 우리가 이제껏 접해왔던 컴퓨터 환경과는 그 운용 방법이나 개발 방법 등 모든 면에서 다르다 할 수 있다. 하지만 그 속내를 들여다보면 우리가 이제까지 등한시했던 기본적인 내용들을 다시금 돌아보고 숙지한다면 결국 개발이라는 방법 자체가 아닌 개발 과정의 흐름은 동일하다는 사실을 이해하리라 생각한다.

CPU, 프로그래밍 언어, 컴파일러와 같은 기본 개발 분야에 있어서 이미 선진 유럽과 미국을 우리가 뛰어 넘기란 사실상 불가능해 보인다. 그러나 이제 막 꽃을 피우기 시작한 임베디드라면 기대해도 좋을 희망이 있지 않을까? 뛰어난 임베디드 개발자들이 무수히 쏟아져 나오길 간절히 바란다.