안드로이드 전체 소스를 git에서 다운받아서 빌드하고 테스트 해보자.
개발환경
-- OS : Ubuntu 8.10 desktop
구글도 우분투를 권장하고 있을 뿐만뿐만 아니라 안드로이드 개발에 있어서는 우분투에서 개발하는 것이 좋은 점이 많다. 특히특히 에뮬레이터 네트워크 이슈등으로 인해서.
안드로이드 전체 소스코드 빌드 방법에 대해서는대해서는 다음의 글을 참고하여 직접 해 본 것이다.
http://www.kandroid.org/board/board.php?board=androidsource&command=body&no=4
1. 환경설정
위의 kandroid.org 의 글에서처럼 필요한필요한 패키지들을 설치해 준다.
다음의 예제들은 우분투 데스트탑 터미널이나 원격 터미널을 통해서통해서 실행할 수 있다.
해당 패키지들을 설치하는 중에 의존성의존성 에러등이 발생할 경우에는 해당 의존 패키지들을 설치해 준다. 대부분은 'yes'를 통해서통해서 설치만 해 주면 된다.
다음으로는 Java SDK가 설치되어 있지 않다면않다면 Java SDK를 설치해 주어야 한다. kandroid.org 글에서는 우분투 apt-get을 통한 SUNSUN SDK를 설치하도록 되어 있는데 여기서는 아래의 링크를 통해서 SUN Java SDKSDK 버전을 다운받아서 설치하도록 한다.
우분투에서 Java 설치하기
여기서 잠시 살펴볼살펴볼 것은 현재 버전이 JDK1.6.0_14 임으로 update-alternatives를 다음과 같이 실행해 준다.
기존에 기설치된 JDK가 존재할 경우 -config 옵션을 통해서 선택하게선택하게 해 준다. 방금 설치한 JDK1.6.0_14 버전을 선택해 준다.
"java -version" 커맨드를 통해서 자바 버전을 확인해 본다.
다음은 reporepo 명령어를 실행하기 위해서 계정 내에서 bin 디렉토리를 만들어 준다.
지금까지 설정한 환경에 대한 셋팅을 마무리한다.
해당 파일에 다음을 추가한다.
시스템을 재로그인 하거나 원격일원격일 경우 로그아웃 한 후 재접속해 준다.
2.2. git 설치
git는 최근의 연구대상이다. 인터넷을 통해서 많은많은 자료를 찾을 수 있다. 다음의 자료를 통해서 대략적인 것을 이해할 수수 있다.
git 사용자 설명서
우분투 터미널에서 다음과 같은 명령어를 통해서통해서 git 를 설치하고, android.git의 repo를 로컬로 옮겨온다.
repo 커맨드를커맨드를 실행할 수 있는 파일로 변경해 준다.
3. Android 소스 다운로드 하기
안드로이드 소스를소스를 다운로드하기 위한 로컬의 저장소를 만들어주고, 해당 디렉토리로 이동한다.
android 소스가 존재하는 git 주소로 초기화 해 준다.
원격 git 주소와 로컬의 저장소를 동기화 해 준다. 이 과정이 안드로이드안드로이드 소스를 다운로드 받는 것이다.
이 과정을 통해서 안드로이드안드로이드 소스를 다운받게 되는데 다운로드를 받아보니 현재(2009.06.16) 기존으로 1.4GB 이다. 따라서 식사시간식사시간 전에 sync를 걸어주는 게 좋다.
간혹 네트워크 상태가 좋치 않거나 서버와의서버와의 접속이 끊어지는 경우가 있다. repo sync 명령어를 계속해서 입력해 주면 된다.된다.
4. Android 소스 빌드
안드로이드 소스 코드를 다 받게 되면 make 명령어를 통해서 빌드하게빌드하게 된다.
현재 테스트해 본 결과로는 별도의 에러가에러가 발생하지 않는다. 하지만 Java 관련 명령어의 링크가 제대로 동작하지 않아 에러를에러를 발생하는 경우를 볼 수 있었다. 예를 들면 다음의 에러와 같다.
javac 커맨드를 찾을 수 없다는 말이니깐 "sudo update-alternativesupdate-alternatives --install "/usr/bin/javac" "javac" "/usr/local/jdk1.6.0_14/bin/javac 1" 명령어를 통해서 해결할 수 있다.
javah, javadoc, jar 에 대해서도 동일한 에러가 발생하였음으로 위의 명령어를 통해서통해서 해결할 수 있다.
빌드 시간이 2시간 남짓 걸렸다...ㅡㅡ;; 암튼 많은많은 시간을 투자해야 하니 처음부터 긴 시간을 각오하는게 좋다^^
5. 빌드 테스트
전체 소스 빌드를 성공하였다면성공하였다면 img 파일이 정상적으로 동작하는 지 살펴보아야 한다. "mydroid/out/target/product/generic" 디렉토리를 살펴보자. 아래의아래의 그림과 같이 system.img, ramdisk.img, userdata.img 파일을 포함한 다양한 파일, 폴더가 생성되어져생성되어져 있어야 한다.
이제 ramdisk.img, system.img, userdata.img 파일들을파일들을 이용하여 실제로 SDK의 에뮬레이터를 구동해 보면 된다.
이를 위해서 Android SDK1.5_r2SDK1.5_r2 를 설치해 주어야 한다.
http://developer.android.com/sdk/1.5_r2/index.html
각 플랫폼에 맞는맞는 SDK를 설치해 주면 된다. 만약 SDK1.5 버전을 최초로 설치하였다면 AVD(Android VirtualVirtual Device)를 생성해 주어야 한다. 다음과 같이 해 준다. 이 때 AndroidAndroid SDK 설치 디렉토리의 "ANDROID_HOME/tools" 디렉토리에서 해 주어야 한다.
위의 명령어 옵션 중에 -n 다음에 붙는 것은 이미지의 이름이고, -t-t 다음에 붙는 것은 SDK 버전을 뜻한다. 인터넷 상에 Android SDK 1.51.5 설치 관련된 자료가 많으니 참고하길 바란다.
이제 모든 준비가 되었다.되었다. 에뮬레이터를 먼저 구동해 보고 Android SDK 1.5가 정상적으로 설치되었는지 확인해 본본 다음 위에서 빌드한 파일로 테스트해 보자.
위의위의 명령어를 통해서 에뮬레이터를 실행하면 SDK로 설치한 img 파일로 실행된다. App 들이들이 정상적으로 동작하는지 확인해 보자.
다음은 에뮬레이터를 종료시키고 빌드한 img 파일을파일을 이용하여 에뮬레이터를 동작시켜 보자.
형태로 실행하면 되는데되는데 <file> 에 해당하는 img 파일들을 절대경로로 지정해 주면 된다.
-ramdisk 다음의다음의 파일을 "ramdisk.img", -system 다음의 파일은 "system.img", -initdata 다음의 파일은 "userdata.img" 이다.이다.
Android SDK 1.x 에서는 -system 옵션이 -image 였다. 이전의 자료들을 보면 -image 옵션으로 설명한 곳들이 있으니 주의하기 바란다.
에뮬레이터가 정상적으로 구동하고 application 들이 정상적으로 구동되면 안드로이드 전체전체 소스 빌드를 성공한 것이다.
개발환경
-- OS : Ubuntu 8.10 desktop
구글도 우분투를 권장하고 있을 뿐만뿐만 아니라 안드로이드 개발에 있어서는 우분투에서 개발하는 것이 좋은 점이 많다. 특히특히 에뮬레이터 네트워크 이슈등으로 인해서.
안드로이드 전체 소스코드 빌드 방법에 대해서는대해서는 다음의 글을 참고하여 직접 해 본 것이다.
http://www.kandroid.org/board/board.php?board=androidsource&command=body&no=4
1. 환경설정
위의 kandroid.org 의 글에서처럼 필요한필요한 패키지들을 설치해 준다.
다음의 예제들은 우분투 데스트탑 터미널이나 원격 터미널을 통해서통해서 실행할 수 있다.
sudo apt-get install flex bison gperf libsdl-dev libesd0-dev libwxgtk2.6-dev build-essential zip curl
sudo apt-get install valgrind
sudo apt-get install valgrind
해당 패키지들을 설치하는 중에 의존성의존성 에러등이 발생할 경우에는 해당 의존 패키지들을 설치해 준다. 대부분은 'yes'를 통해서통해서 설치만 해 주면 된다.
다음으로는 Java SDK가 설치되어 있지 않다면않다면 Java SDK를 설치해 주어야 한다. kandroid.org 글에서는 우분투 apt-get을 통한 SUNSUN SDK를 설치하도록 되어 있는데 여기서는 아래의 링크를 통해서 SUN Java SDKSDK 버전을 다운받아서 설치하도록 한다.
우분투에서 Java 설치하기
여기서 잠시 살펴볼살펴볼 것은 현재 버전이 JDK1.6.0_14 임으로 update-alternatives를 다음과 같이 실행해 준다.
sudo update-alternatives --install "/usr/bin/java" "java" "/usr/local/jdk1.6.0_14/bin/java" 1
sudo update-alternatives --config java
sudo update-alternatives --config java
기존에 기설치된 JDK가 존재할 경우 -config 옵션을 통해서 선택하게선택하게 해 준다. 방금 설치한 JDK1.6.0_14 버전을 선택해 준다.
java -version
java version "1.6.0_14"
Java(TM) SE Runtime Environment (build 1.6.0_14-b08)
Java HotSpot(TM) Client VM (build 14.0-b16, mixed mode, sharing)
java version "1.6.0_14"
Java(TM) SE Runtime Environment (build 1.6.0_14-b08)
Java HotSpot(TM) Client VM (build 14.0-b16, mixed mode, sharing)
"java -version" 커맨드를 통해서 자바 버전을 확인해 본다.
다음은 reporepo 명령어를 실행하기 위해서 계정 내에서 bin 디렉토리를 만들어 준다.
mkdir bin
지금까지 설정한 환경에 대한 셋팅을 마무리한다.
vi ~/.bashrc
해당 파일에 다음을 추가한다.
export LANG=c
export PATH=/home/<user_home>/bin:$PATH:.
export JAVA_HOME=/usr/local/jdk1.6.0_14
export ANDROID_JAVA_HOME=$JAVA_HOME
export PATH=/home/<user_home>/bin:$PATH:.
export JAVA_HOME=/usr/local/jdk1.6.0_14
export ANDROID_JAVA_HOME=$JAVA_HOME
시스템을 재로그인 하거나 원격일원격일 경우 로그아웃 한 후 재접속해 준다.
2.2. git 설치
git는 최근의 연구대상이다. 인터넷을 통해서 많은많은 자료를 찾을 수 있다. 다음의 자료를 통해서 대략적인 것을 이해할 수수 있다.
git 사용자 설명서
우분투 터미널에서 다음과 같은 명령어를 통해서통해서 git 를 설치하고, android.git의 repo를 로컬로 옮겨온다.
sudo apt-get install git-core gnupg
curl http://android.git.kernel.org/repo >/home/<user_home>/bin/repo
curl http://android.git.kernel.org/repo >/home/<user_home>/bin/repo
chmod a+x ~/bin/repo
3. Android 소스 다운로드 하기
안드로이드 소스를소스를 다운로드하기 위한 로컬의 저장소를 만들어주고, 해당 디렉토리로 이동한다.
mkdir mydroid & cd mydroid
android 소스가 존재하는 git 주소로 초기화 해 준다.
repo init -u git://android.git.kernel.org/platform/manifest.git
원격 git 주소와 로컬의 저장소를 동기화 해 준다. 이 과정이 안드로이드안드로이드 소스를 다운로드 받는 것이다.
repo sync
이 과정을 통해서 안드로이드안드로이드 소스를 다운받게 되는데 다운로드를 받아보니 현재(2009.06.16) 기존으로 1.4GB 이다. 따라서 식사시간식사시간 전에 sync를 걸어주는 게 좋다.
간혹 네트워크 상태가 좋치 않거나 서버와의서버와의 접속이 끊어지는 경우가 있다. repo sync 명령어를 계속해서 입력해 주면 된다.된다.
4. Android 소스 빌드
안드로이드 소스 코드를 다 받게 되면 make 명령어를 통해서 빌드하게빌드하게 된다.
cd mydroid
make
make
현재 테스트해 본 결과로는 별도의 에러가에러가 발생하지 않는다. 하지만 Java 관련 명령어의 링크가 제대로 동작하지 않아 에러를에러를 발생하는 경우를 볼 수 있었다. 예를 들면 다음의 에러와 같다.
build/core/product_config.mk:261: WARNING: adding test OTA key
============================================
TARGET_PRODUCT=generic
TARGET_BUILD_VARIANT=eng
TARGET_SIMULATOR=
TARGET_BUILD_TYPE=release
TARGET_ARCH=arm
HOST_ARCH=x86
HOST_OS=linux
HOST_BUILD_TYPE=release
BUILD_ID=
============================================
build/core/copy_headers.mk:15: warning: overriding commands for target `out/target/product/generic/obj/include/libpv/getactualaacconfig.h'
build/core/copy_headers.mk:15: warning: ignoring old commands for target `out/target/product/generic/obj/include/libpv/getactualaacconfig.h'
make: execvp: /bin/bash: Argument list too long
host Java: clearsilver (out/host/common/obj/JAVA_LIBRARIES/clearsilver_intermediates/classes)
/bin/bash: javac: command not found
make: *** [out/host/common/obj/JAVA_LIBRARIES/clearsilver_intermediates/javalib.jar] Error 41
============================================
TARGET_PRODUCT=generic
TARGET_BUILD_VARIANT=eng
TARGET_SIMULATOR=
TARGET_BUILD_TYPE=release
TARGET_ARCH=arm
HOST_ARCH=x86
HOST_OS=linux
HOST_BUILD_TYPE=release
BUILD_ID=
============================================
build/core/copy_headers.mk:15: warning: overriding commands for target `out/target/product/generic/obj/include/libpv/getactualaacconfig.h'
build/core/copy_headers.mk:15: warning: ignoring old commands for target `out/target/product/generic/obj/include/libpv/getactualaacconfig.h'
make: execvp: /bin/bash: Argument list too long
host Java: clearsilver (out/host/common/obj/JAVA_LIBRARIES/clearsilver_intermediates/classes)
/bin/bash: javac: command not found
make: *** [out/host/common/obj/JAVA_LIBRARIES/clearsilver_intermediates/javalib.jar] Error 41
javac 커맨드를 찾을 수 없다는 말이니깐 "sudo update-alternativesupdate-alternatives --install "/usr/bin/javac" "javac" "/usr/local/jdk1.6.0_14/bin/javac 1" 명령어를 통해서 해결할 수 있다.
javah, javadoc, jar 에 대해서도 동일한 에러가 발생하였음으로 위의 명령어를 통해서통해서 해결할 수 있다.
빌드 시간이 2시간 남짓 걸렸다...ㅡㅡ;; 암튼 많은많은 시간을 투자해야 하니 처음부터 긴 시간을 각오하는게 좋다^^
5. 빌드 테스트
전체 소스 빌드를 성공하였다면성공하였다면 img 파일이 정상적으로 동작하는 지 살펴보아야 한다. "mydroid/out/target/product/generic" 디렉토리를 살펴보자. 아래의아래의 그림과 같이 system.img, ramdisk.img, userdata.img 파일을 포함한 다양한 파일, 폴더가 생성되어져생성되어져 있어야 한다.
이제 ramdisk.img, system.img, userdata.img 파일들을파일들을 이용하여 실제로 SDK의 에뮬레이터를 구동해 보면 된다.
이를 위해서 Android SDK1.5_r2SDK1.5_r2 를 설치해 주어야 한다.
http://developer.android.com/sdk/1.5_r2/index.html
각 플랫폼에 맞는맞는 SDK를 설치해 주면 된다. 만약 SDK1.5 버전을 최초로 설치하였다면 AVD(Android VirtualVirtual Device)를 생성해 주어야 한다. 다음과 같이 해 준다. 이 때 AndroidAndroid SDK 설치 디렉토리의 "ANDROID_HOME/tools" 디렉토리에서 해 주어야 한다.
./android create avd -n <device_name> -t 2
위의 명령어 옵션 중에 -n 다음에 붙는 것은 이미지의 이름이고, -t-t 다음에 붙는 것은 SDK 버전을 뜻한다. 인터넷 상에 Android SDK 1.51.5 설치 관련된 자료가 많으니 참고하길 바란다.
이제 모든 준비가 되었다.되었다. 에뮬레이터를 먼저 구동해 보고 Android SDK 1.5가 정상적으로 설치되었는지 확인해 본본 다음 위에서 빌드한 파일로 테스트해 보자.
./emulator -avd <device_name>
위의위의 명령어를 통해서 에뮬레이터를 실행하면 SDK로 설치한 img 파일로 실행된다. App 들이들이 정상적으로 동작하는지 확인해 보자.
다음은 에뮬레이터를 종료시키고 빌드한 img 파일을파일을 이용하여 에뮬레이터를 동작시켜 보자.
./emulator -adv <device_name> -ramdisk <file> -system <file> -initdata <file>
형태로 실행하면 되는데되는데 <file> 에 해당하는 img 파일들을 절대경로로 지정해 주면 된다.
-ramdisk 다음의다음의 파일을 "ramdisk.img", -system 다음의 파일은 "system.img", -initdata 다음의 파일은 "userdata.img" 이다.이다.
Android SDK 1.x 에서는 -system 옵션이 -image 였다. 이전의 자료들을 보면 -image 옵션으로 설명한 곳들이 있으니 주의하기 바란다.
에뮬레이터가 정상적으로 구동하고 application 들이 정상적으로 구동되면 안드로이드 전체전체 소스 빌드를 성공한 것이다.
'기본 카테고리' 카테고리의 다른 글
이슈포커스 : HTML5의 특장점 (0) | 2010.09.05 |
---|---|
REAL TARGET BOARD 없이 안드로이드 포팅기술 익히기 (1) | 2010.09.03 |
우분투 새키모음 반복 오류 해결 (0) | 2010.08.10 |
ubuntu 에서 tcl/tk 설치 (0) | 2010.08.08 |
ubuntu에서 wxPython 설치법 (0) | 2010.08.08 |