[转]如何制作tizen镜像文件(图文教程)?

http://blog.csdn.net/flydream0/article/details/9163119

之前已讲解了如何下载及编译tizen源码(http://blog.csdn.net/flydream0/article/details/9004746),接下来我将讲解如下将制作镜像文件。

1 安装mic工具

tizen是使用MIC工具来制作其镜像文件的,因此我们首先得安装它。

  1. $ sudo apt-get install mic  


查看MIC工具的当前版本:

  1. $ mic --version  
  2. mic 0.19.1 (Ubuntu 12.04 precise)  

2 下载ks文件

  1. wget http://download.tizen.org/releases/daily/2.0alpha/ivi-wayland/tizen-2.0alpha_20130522.2/images/ivi-wayland-release/ivi-wayland-release.ks  

下载完后会在当前目录下有一个名为ivi-wayland-release.ks的文件,打开此文件,如下内容:

  1. # -*-mic2-options-*- -f raw --copy-kernel --compress-disk-image=bz2 --generate-bmap -*-mic2-options-*-  
  2.   
  3. #   
  4. # Do not Edit! Generated by:  
  5. # kickstarter.py  
  6. #   
  7.   
  8. lang en_US.UTF-8  
  9. keyboard us  
  10. timezone --utc America/Los_Angeles  
  11. part /boot --size 64 --ondisk sdb --fstype=ext4 --label boot --active --align 1024  
  12. part /opt --size 676 --ondisk sdb --fstype=ext4 --label opt --align 1024  
  13. part / --size 3072 --ondisk sdb --fstype=ext4 --label platform --align 1024  
  14.   
  15. rootpw tizen   
  16. xconfig --startxonboot  
  17. bootloader  --timeout=0  --append="rootwait rootfstype=ext4 quiet"   --ptable=gpt  
  18.   
  19. desktop --autologinuser=tizen    
  20. user --name tizen  --groups audio,video --password 'tizen'  
  21.   
  22. repo --name=Tizen-base --baseurl=https://download.tizen.org/snapshots/2.0alpha/ivi-wayland/@BUILD_ID@/repos/base/ia32/packages/ --ssl_verify=no  
  23. repo --name=Tizen-ivi-wayland --baseurl=https://download.tizen.org/snapshots/2.0alpha/ivi-wayland/@BUILD_ID@/repos/ivi-wayland/ia32/packages/ --ssl_verify=no  
  24.   
  25. %packages  
  26.   
  27. @adaptation-automotive-intel  
  28. @commonwayland  
  29. @ivi-middleware  
  30. @appswayland  
  31. @toyota-ui  
  32.   
  33. kernel-x86-ivi  
  34.   
  35. release-repos  
  36. -simulator-opengl  
  37. -opengl-es  
  38. %end  
  39.   
  40. %prepackages  
  41. eglibc  
  42. systemd  
  43. busybox  
  44. libacl  
  45. libcap  
  46. dbus-libs  
  47. libgcc  
  48. libudev  
  49. libattr  
  50. default-files-slp  
  51. openssl  
  52. libprivilege-control  
  53. libprivilege-control-conf  
  54. security-server  
  55. libdlog  
  56. libsecurity-server-client  
  57. sqlite  
  58. tzdata-slp  
  59. vconf  
  60. tizen-coreutils  
  61. %end  
  62.   
  63.   
  64. %post  
  65. # to make udev happy  
  66. ln -sf /bin/busybox /sbin/blkid  
  67.   
  68. # where in the world is xinitrc?  
  69. ln -sf /etc/X11/xinitrc /usr/etc/X11/xinitrc  
  70.   
  71. # inittab hack to fix console - UI switching  
  72. sed -ri 's/--noclear tty1/tty3/' /etc/inittab  
  73. sed -ri 's/tty2/tty4/' /etc/inittab  
  74.   
  75. # modprobe fuse for sqlfs-mount  
  76. /bin/sed -i "3i /sbin/modprobe fuse || :" /etc/rc.d/init.d/sqlfs-mount   
  77.   
  78. if [ -d /etc/init.d ]; then  
  79.     cp /etc/init.d/* /etc/rc.d/init.d/ -rdf  
  80. fi  
  81. rm -rf /etc/init.d*  
  82. ln -sf /etc/rc.d/init.d /etc/init.d  
  83.   
  84. rm -rf /etc/localtime    
  85. ln -sf /opt/etc/localtime /etc/localtime    
  86.   
  87. # Without this line the rpm doesn't get the architecture right.  
  88. # echo -n 'armv7l-tizen-linux' > /etc/rpm/platform  
  89. > /etc/rpm/platform  
  90.   
  91. ssh-keygen -t rsa1 -f /etc/ssh/ssh_host_key -N ""  
  92. ssh-keygen -t dsa -f /etc/ssh/ssh_host_dsa_key -N ""  
  93. ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key -N ""  
  94.   
  95. pkg_initdb  
  96.   
  97. rm -fr /opt/dbspace/.app_info.*  
  98. INITDB=1 ail_initdb  
  99.   
  100. # ims-service domain setting  
  101. RESULT=`grep "192.168.0.163 config.45001.rcse" /etc/hosts`    
  102. if [ -z "$RESULT" ]; then    
  103.     echo "Set domain for auto configuration"    
  104.     echo "192.168.0.163 config.45001.rcse" >> /etc/hosts    
  105. else    
  106.     echo "Already setted domain for test auto configuration"    
  107. fi    
  108. # ims-service domain setting  
  109.   
  110. cat > /usr/bin/press << EOF  
  111. #!/bin/sh  
  112.   
  113. JUNK="SLP"  
  114.   
  115. [ "$1" ] && TIMEOUT="$1" || TIMEOUT="1"  
  116.   
  117. echo "Press return key to stop scripts"  
  118. read -t $TIMEOUT JUNK  
  119. exit $?  
  120. EOF  
  121. chmod +x /usr/bin/press  
  122.   
  123. ln -s /opt/etc/X11/xkb /usr/share/X11  
  124. ln -s /home/app /opt/home/app  
  125. ln -s /home/developer /opt/home/developer  
  126.   
  127. echo "UDEV_PERSISTENT_STORAGE=no" >> /etc/sysconfig/udev  
  128.   
  129. rm -rf /usr/share/man  
  130. rm -rf /usr/share/doc  
  131.   
  132. ldconfig  
  133.   
  134. mkdir -p /opt/var/lib/dbus  
  135.   
  136. rm -f /var/lib/rpm/__db*  
  137. mv -f /var/lib/rpm /opt/var/lib/   
  138. ln -sf /opt/var/lib/rpm /var/lib/rpm  
  139. rpmdb --rebuilddb  
  140.   
  141. if [ -e /usr/bin/build-backup-data.sh ]; then  
  142.            /usr/bin/build-backup-data.sh  
  143. fi  
  144.   
  145. sed -i s/ENGINE=gl/ENGINE=fb/ /etc/profile.d/menu-screen.sh  
  146.   
  147. # enable USB networking with IP address 192.168.1.1 by default  
  148. cat >/etc/rc.d/rc3.d/S01usbnet.sh <<END  
  149. #!/bin/sh  
  150. echo 0 > /sys/class/android_usb/android0/enable  
  151. echo adb,rndis > /sys/class/android_usb/android0/functions  
  152. echo 1 > /sys/class/android_usb/android0/enable  
  153. ifconfig rndis0 192.168.100.1  
  154. END  
  155. chmod 755 /etc/rc.d/rc3.d/S01usbnet.sh  
  156.   
  157. ln -sf /etc/rc.d/init.d/ssh /etc/rc.d/rc3.d/S90ssh  
  158.   
  159. # this file should be deleted after elegant fix merged  
  160. ############################### hacks to get   
  161. # usbnet, udev, ssh, and other stuff  
  162. cat > /etc/rc.d/rc3.d/S01debug << EOF  
  163.   
  164. # udev  
  165. /sbin/udevd --daemon  
  166. /sbin/udevadm trigger  
  167.   
  168. EOF  
  169.   
  170. chmod +x /etc/rc.d/rc3.d/S01debug  
  171.   
  172.   
  173. ###############################  
  174.   
  175.   
  176. mkdir /root  
  177. chmod 755 /root  
  178.   
  179.   
  180. %end  
  181.   
  182. %post --nochroot  
  183. if [ -n "$IMG_NAME" ]; then  
  184.     echo "BUILD: $IMG_NAME" >> $INSTALL_ROOT/etc/tizen-release  
  185. fi  
  186.   
  187.   
  188. %end  


此文件为mic的配置文件,描述mic如何制作镜像文件。有关此文件的说明请参考:http://blog.csdn.net/flydream0/article/details/9162187 一文的第5章。

默认情况下repo使用的是远程资料库的RPM包。

3 使用MIC工具从远程repo下载RPM包并制作镜像文件

使用如下指令生成镜像文件:

  1. $ sudo mic create raw ivi-wayland-release.ks --pack-to=test.tar.bz2 --logfile=log  

其 中 create表示创建镜像文件,raw表示raw格式的镜像, ivi-way...这里指定ks文件. --pack-to=xxx 表示打包生成test.tar.bz2文件,即此raw镜像文件打包到test.tar.bz2, --logfile=xxx表示将打印信息存放到log文件中.

如下图:

最终结束后,会在当前目录生成log文件,保存制作镜像文件过程中的打印信息,同时会生成mic-output目录,压缩打包后的镜像文件test.tar.bz2文件就放在此目录下。

  1. $ tree mic-output/ -L 3  
  2. mic-output/  
  3. ├── ivi-wayland-release-201306251509.xml  
  4. └── test.tar.bz2  
  5.   
  6. 0 directories, 2 files  

注:默认情况下,mic工具会在/var/tmp目录下创建一mic目录,然后在mic目录下创建cache目录用来保存从远程repo下载的RPM包:

  1. $ tree mic -L 2  
  2. mic  
  3. ├── build  
  4. ├── cache  
  5. │   ├── etc  
  6. │   ├── packages  
  7. │   ├── raw  
  8. │   ├── solv  
  9. │   ├── Tizen-base  
  10. │   ├── Tizen-ivi-wayland  
  11. │   └── var  
  12. └── device  
  13.     └── loop0  



4 使用本地RPM包生成镜像文件

使用如下指令:

  1. $ sudo mic create raw ivi-wayland-release.ks --pack-to=local_test.tar.bz2 --logfile=log1 --local-pkgs-path=/home/arthur/GBS-ROOT/local/repos  

其中--local-pkgs-path=后面为使用gbs build时生成的本地repo的所在目录。见:http://blog.csdn.net/flydream0/article/details/9004746一文的2.3节。

注:如果gbs build生成的目录下,即repos的tizenxxx目录下包含多个硬件平台架构的目录时,可以在MIC指令后通过-A选项来指令目标平台的架构,如:

  1. $ sudo mic create raw ivi-wayland-release.ks --pack-to=local_test.tar.bz2 --logfile=log1 --local-pkgs-path=/home/arthur/GBS-ROOT/local/repos -A i586  

下一章我将讲述如何在目标设备上烧录镜像文件,敬请关注!

注:有关如何烧录镜像文件,请参考下一篇文章:http://blog.csdn.net/flydream0/article/details/9179143

原文地址:https://www.cnblogs.com/androidme/p/3263461.html