當前位置:首頁 » 編程軟體 » aosp編譯指定gcc

aosp編譯指定gcc

發布時間: 2023-05-10 02:13:10

❶ 大牛們是怎麼閱讀 Android 系統源碼

由於工作需要大量修改framework代碼, 在AOSP(Android Open Source Project)源碼上花費了不少功夫, Application端和Services端都看和改了不少.
如果只是想看看一些常用類的實現, 在Android包管理器里把源碼下載下來, 隨便一個IDE配好Source Code的path看就行.
但如果想深入的了解Android系統, 那麼可以看下我的一些簡單的總結.

知識
java
Java是AOSP的主要語言之一. 沒得說, 必需熟練掌握.
熟練的Android App開發
linux
Android基於Linux的, 並且AOSP的推薦編譯環境是Ubuntu 12.04. 所以熟練的使用並了解Linux這個系統是必不可少的. 如果你想了解偏底層的代碼, 那麼必需了解基本的Linux環境下的程序開發. 如果再深入到驅動層, 那麼Kernel相關的知識也要具備.
Make
AOSP使用Make系統進行編譯. 了解基本的Makefile編寫會讓你更清晰了解AOSP這個龐大的項目是如何構建起來的.
Git
AOSP使用git+repo進行源碼管理. 這應該是程序員必備技能吧.
C++
Android系統的一些性能敏感模塊及第三方庫是用C++實現的, 比如: Input系統, Chromium項目(WebView的底層實現).

硬體
流暢的國際網路
AOSP代碼下載需要你擁有一個流暢的國際網路. 如果在下載代碼這一步就失去耐心的話, 那你肯定沒有耐心去看那亂糟糟的AOSP代碼. 另外, 好程序員應該都會需要一個流暢的Google.
一台運行Ubuntu 12.04的PC.
如果只是閱讀源碼而不做太多修改的話, 其實不需要太高的配置.
一台Nexus設備
AOSP項目默認只支持Nexus系列設備. 沒有也沒關系, 你依然可以讀代碼. 但如果你想在大牛之路走的更遠, 還是改改代碼, 然後刷機調試看看吧.
高品質USB線
要刷機時線壞了, 沒有更窩心的事兒了.
軟體
Ubuntu 12.04
官方推薦, 沒得選.
Oracle Java 1.6
注意不要用OpenJDK. 這是個坑, 官方文檔雖然有寫, 但還是單獨提一下.
安裝:
sudo apt-get install python-software-properties
sudo add-apt-repository ppa:webupd8team/java
sudo apt-get update
sudo apt-get install oracle-java6-installer
sudo apt-get install oracle-java6-set-default

Eclipse
估計會有不少人吐槽, 為什麼要用這個老古董. 其實原因很簡單, 合適. 剛開始搞AOSP時, 為了找到效率最優的工具, 我嘗試過Eclipse, IntelliJ IDEA, Vim+Ctags, Sublime Text+Ctags. 最終結果還是Eclipse. 主要優點有:
有語法分析 (快速准確的類, 方法跳轉).
支持C++ (IntelliJ的C++支持做的太慢了).
嵌入了DDMS, View Hierarchy等調試工具.
為了提高效率, 花5分鍾背下常用快捷鍵非常非常值得.
調整好你的classpath, 不要導入無用的代碼. 因為AOSP項目代碼實在是太多了. 當你還不需要看C++代碼時, 不要為項目添加C++支持, 建索引過程會讓你崩潰.
Intellij IDEA
開發App必備. 當你要調試系統的某個功能是, 常常需要迅速寫出一個調試用App, 這個時候老舊的Eclipse就不好用了. Itellij IDEA的xml自動補全非常給力.
巨人的肩膀

這個一定要先讀. 項目介紹, 代碼下載, 環境搭建, 刷機方法, Eclipse配置都在這里. 這是一切的基礎.

這個其實是給App開發者看的. 但是裡面也有不少關於系統機制的介紹, 值得細讀.

此老羅非彼老羅. 羅升陽老師的博客非常有營養, 基本可以作為指引你開始閱讀AOSP源碼的教程. 你可以按照博客的時間順序一篇篇挑需要的看.但這個系列的博客有些問題:
早期的博客是基於舊版本的Android;
大量的代碼流程追蹤. 讀文章時你一定要清楚你在看的東西在整個系統處於什麼樣的位置.

鄧凡平老師也是為Android大牛, 博客同樣很有營養. 但是不像羅升陽老師的那麼系統. 更多的是一些技術點的深入探討.

Android官方Issue列表. 我在開發過程中發現過一些奇怪的bug, 最後發現這里基本都有記錄. 當然你可以提一些新的, 有沒有人改就是另外一回事了.

一定要能流暢的使用這個工具. 大量的相關知識是沒有人系統的總結的, 你需要自己搞定.
其它
代碼組織
AOSP的編譯單元不是和git項目一一對應的, 而是和Android.mk文件一一對應的. 善用mmm命令進行模塊編譯將節省你大量的時間.
Binder
這是Android最基礎的進程間通訊. 在Application和System services之間大量使用. 你不僅要知道AIDL如何使用, 也要知道如何手寫Binder介面. 這對你理解Android的Application和System services如何交互有非常重要的作用. Binder如何實現的倒不必著急看.
HAL
除非你對硬體特別感興趣或者想去方案公司上班, 否則別花太多時間在這一層.
CyanogenMod
這是一個基於AOSP的第三方Rom. 從這個項目的wiki里你能學到很多AOSP官方沒有告訴你的東西. 比如如何支持Nexus以外的設備.
DIA
這是一個Linux下畫UML的工具, 能夠幫你梳理看過的代碼.
XDA

這里有最新資訊和最有趣的論壇.
想到了再補充.

❷ Android aosp源碼編譯後root許可權問題

ROOT獲得最高許可權是刪除這些應用的唯一途徑
實際手動操作的流程非常復雜,並且有版本限制
我推薦你款不錯的手機ROOT工具吧,
我一直都是在用的,很不錯
使用應用寶獲取手機root許可權在工具
選項里找到一鍵ROOT即可或者KINGROOT也行。

❸ 解決ubuntu編譯aosp報錯問題:error while loading shared libraries: libncurses.so.5

報錯如下:

解決方案:安裝libncurses5解決,命令如下

❹ android studio里的ndk toolchains問題,請問怎麼解決

我用的是android studio 1.5的版本,所以gradle配置相比舊旦悉燃版本有了不少變化。可參考如下文檔

http://tools.android.com/tech-docs/new-build-system/gradle-experimental

首先貼出我的完整gradle配置,讓大陸困家有個模虛直觀認識

apply plugin: 'com.android.model.application'

model{
android {
compileSdkVersion = 19
buildToolsVersion = "22.0.1"

defaultConfig.with {
applicationId = "com.example.testhook"
minSdkVersion.apiLevel = 10
targetSdkVersion.apiLevel = 19
versionCode = 1
versionName = "1.0"
}
}

android.packagingOptions {
pickFirst 'lib/armeabi-v7a/libtest.so'
pickFirst 'lib/x86/libtest.so'
}

android.buildTypes {
release {
minifyEnabled = false
proguardFiles += file('proguard-rules.pro')

ndk.with {
CFlags += ["-O3"]
cppFlags += ["-DNDEBUG", "-O3"]
}
}
}

android.ndk {
moleName = "test"

toolchain = "gcc"
toolchainVersion = "4.9"

cppFlags += ["-DPLATFORM_SDK_VERSION=14", "-DHAVE_LITTLE_ENDIAN", "-D__ARM_ARCH_7__"]
ldLibs += ["cutils","utils", "binder", "android_runtime", "dvm", "stlport", "dl"]

abiFilters += ["x86"]
abiFilters += ["armeabi-v7a"]

def android_branch = "android-2.3.3_r1.1";

ldFlags += "-L${getRootDir()}/dexposed-AOSP/${android_branch}/jniLibs/x86".toString()
ldFlags += "-L${getRootDir()}/dexposed-AOSP/${android_branch}/jniLibs/armeabi-v7a".toString()

Properties properties = new Properties()
properties.load(project.rootProject.file('local.properties').newDataInputStream())
def ndkDir = properties.getProperty('ndk.dir')

cppFlags += "-I${ndkDir}/sources/cxx-stl/stlport/stlport".toString()
cppFlags += "-I${getRootDir()}/dexposed-AOSP/${android_branch}/include/dalvik".toString()
cppFlags += "-I${getRootDir()}/dexposed-AOSP/${android_branch}/include/dalvik/vm".toString()
cppFlags += "-I${getRootDir()}/dexposed-AOSP/${android_branch}/include/external/stlport/stlport".toString()
cppFlags += "-I${getRootDir()}/dexposed-AOSP/${android_branch}/include/bionic".toString()
cppFlags += "-I${getRootDir()}/dexposed-AOSP/${android_branch}/include/bionic/libstdc++/include".toString()
cppFlags += "-I${getRootDir()}/dexposed-AOSP/${android_branch}/include/system/core/include".toString()
cppFlags += "-I${getRootDir()}/dexposed-AOSP/${android_branch}/include/frameworks/native/include".toString()
cppFlags += "-I${getRootDir()}/dexposed-AOSP/${android_branch}/include/frameworks/base/include".toString()
cppFlags += "-I${getRootDir()}/dexposed-AOSP/${android_branch}/include/libnativehelper/include".toString()
}
}

dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
compile files('libs/commons-lang3-3.4.jar')
}

有幾點需要注意:

一、如果這是個library,則第一行應改為
apply plugin: 『com.android.model.library』

二、框架整體的build.gradle中要改成如下
classpath 『com.android.tools.build:gradle-experimental:0.2.0』

三、gradle-wrapper.properties里要改成gradle-2.5,如下
distributionUrl=https://services.gradle.org/distributions/gradle-2.5-all.zip

四、編譯cpp時提示以下錯誤,而在c中就沒有這個問題
java.lang.UnsatisfiedLinkError: Native method not found

解決辦法,在函數前面加上extern 「C」,如下

extern "C" JNIEXPORT JNICALL jstring
Java_com_example_testhook_Tester_getName(JNIEnv *env, jclass object) {
return env->NewStringUTF("hello world!");
}

五、接下來,最重要的是,如果我需要引用到android內核框架中的某些功能,該怎麼做呢?

首先要引用android內核中對應模塊的so文件,然後包含其頭文件並一起編譯。而要得到內核模塊的so文件,需要先下載並編譯android內核。而引用so和頭文件都是在gradle中配置的,分別對應的是ldFlags和cppFlags。注意,如果是C文件,則為CFlags,否則會提示找不到頭文件。

❺ Android Studio 3.5導入AOSP編譯的classes.jar

一、適用場景

    我們在寫應用時可能會需要調用系統隱藏的API,這些API是我們無法直接訪問的,報如下錯誤:

 此時,我們需要將系統AOSP的out/target/common/obj/JAVA_LIBRARIES/framework_intermediates/classes.jar導入到Android Studio中,使app能夠訪問這些介面。

二、實現步驟

Step1 . 在app目錄下建立libs文件夾,並將classes.jar包放入該路徑

Step2 .在app目錄上右鍵【Open Mole Settings】,點擊左側【Dependencies】,選擇app,點擊【+】選擇【2 Jar Dependency】,添加

選擇我們的libs/classes.jar,點擊【OK】

Step3 .在Mole的build.gradle中,dependencies自動增加依賴配置,注釋掉下面一行

implementation fileTree(dir: 'libs', include: ['*.jar'])  

並將implementation files('libs/classes.jar')改為

compileOnly files('libs/classes.jar')

最終如下圖所示

Step4 .修改Project的build.gradle,在allProjects中增加如下語句

    gradle.projectsEvaluated {

        tasks.withType(JavaCompile) {

            options.compilerArgs.add('-Xbootclasspath/p:app\\libs\\classes.jar')

        }

    }

Step5 .修改jar包優先順序,在Moels的app.iml文件中找到我們的classes.jar包所在行,

<orderEntry type="library" name="Gradle: __local_aars__:/Users/mrwong/AndroidStudioProjects/uart_daemon/app/libs/classes.jar:unspecified@jar" level="project" />

將其移動到

<orderEntry type="jdk" jdkName="Android API 29 Platform" jdkType="Android SDK" />

這一行之上,最終如下圖所示:

至此,app可以優先訪問我們自己的jar包 。

❻ 自己可以編譯安卓源碼嗎

用最新的Ubuntu 16.04,請首先確保自己已經安裝了Git.沒安裝的同學可以通過以下命令進行安裝:

sudo apt-get install git git config –global user.email 「[email protected]」 git config –global user.name 「test」

其中[email protected]為你自己的郵箱.

簡要說明

android源碼編譯的四個流程:1.源碼下載;2.構建編譯環境;3.編譯源碼;4運行.下文也將按照該流程講述.

源碼下載

由於某牆的原因,這里我們採用國內的鏡像源進行下載.
目前,可用的鏡像源一般是科大和清華的,具體使用差不多,這里我選擇清華大學鏡像進行說明.(參考:科大源,清華源)

repo工具下載及安裝

通過執行以下命令實現repo工具的下載和安裝

mkdir ~/binPATH=~/bin:$PATHcurl https://storage.googleapis.com/git-repo-downloads/repo > ~/bin/repochmod a+x ~/bin/repo

補充說明
這里,我來簡單的介紹下repo工具,我們知道AOSP項目由不同的子項目組成,為了方便進行管理,Google採用Git對AOSP項目進行多倉庫管理.在聊repo工具之前,我先帶你來聊聊多倉庫項目:

我們有個非常龐大的項目Pre,該項目由很多個子項目R1,R2,...Rn等組成,為了方便管理和協同開發,我們為每個子項目創立自己的倉庫,整個項目的結構如下:


這里寫圖片描述

執行完該命令後,再使用make命令繼續編譯.某些情況下,當你執行jack-admin kill-server時可能提示你命令不存在,此時去你去out/host/linux-x86/bin/目錄下會發現不存在jack-admin文件.如果我是你,我就會重新repo sync下,然後從頭來過.

錯誤三:使用emulator時,虛擬機停在黑屏界面,點擊無任何響應.此時,可能是kerner內核問題,解決方法如下:
執行如下命令:

  • ./out/host/linux-x86/bin/emulator -partition-size 1024 -kernel ./prebuilts/qemu-kernel/arm/kernel-qemu-armv7

  • 通過使用kernel-qemu-armv7內核 解決模擬器等待黑屏問題.而-partition-size 1024 則是解決警告: system partion siez adjusted to match image file (163 MB >66 MB)

    如果你一開始編譯的版本是aosp_arm-eng,使用上述命令仍然不能解決等待黑屏問題時,不妨編譯aosp_arm64-eng試試.

    結束吧

    到現在為止,你已經了解了整個android編譯的流程.除此之外,我也簡單的說明android源碼的多倉庫管理機制.下面,不妨自己動手嘗試一下.

    ❼ aosp系統怎麼樣

    AOSP 全名為 Android Open-Source Project,中文為安卓開源項目,開源即開放源代碼!Android 是一個基於 Linux 的、由 Google 主導的開源系統。嚴格意義上來說,Android=AOSP+GMS,那麼這個GMS又是什麼呢?GMS 全名為 Google Mobile Service,即谷歌移動服務,也就是我們常刷的谷歌服務包。由於你懂的原因,國內無法使用 GMS,所以國內的各種定製 ROM 都是 AOSP 的定製修改加上自家的雲服務,比如 MIUI、ColorOS 等!所以,所有的 ROM 最終的根源就是 AOSP,沒有AOSP,也就沒有現在的 Androi關於 CM,全名為 CyanogenMod,全球最大的第三方 ROM 編譯團隊。CM 是基於 AOSP 進行二次開發,在 AOSP 的基礎上添加功能、適配更多機型、編寫眾多機型的內核和驅動!CM 是在底層多 AOSP 進行改進,並且遵循 Android 設計規范,所以 UI 與交互方面,與 AOSP 保持一致,所以很多人說的CM的UI應該

    ❽ Android學習之Build環境介紹


    這里略過對android在手機上的文件系統框架的闡述(google或者都能幫助你找到對應的信息),主要看google是如何把生成合適的rootfs的工作整合到它的build體系當中,同時,會順帶看一下CyanogenMod中對應各種機型的build機制。
    首先,來看一下Android的build系統中,使用到的編譯選項和相關工具
    具體的目錄在:mydroid/build/tools/下
    |-- acp
    這是一個稍微改良的cp命令,用來應付在windows/MAC/Linux下的cp命令的缺陷,其中的README很值得一看!
    |-- adbs
    這是一個用來查看crash問題的工具,詳細請看《Android調試工具之adbs》
    |-- Android.mk
    |-- apicheck
    用來進行發布前的API檢查(參見mydroid/build/core/tasks/apicheck.mk),是否新編譯的系統中有破壞API兼容性或是非法的API
    這里的代碼是用Java寫的用來檢查編譯時生成的API相關信息的xml文件(mydroid/framework/base/api/中),可以參考裡面對於xml文件解析的代碼
    |-- apriori
    實現prelink的工具,簡單介紹參見(mydroid/bionic/linker/README.TXT)
    |-- atree
    為android SDK服務的一個工具,用來按照指定xxx.atree文件中的內容進行一些文件操作
    |-- bin2asm
    不太明白具體的用處,應該是用來應付mac上編譯android一些與gcc相關的問題
    |-- buildinfo.sh
    生成target中的各種xxx.prop文件,如system.prop, build.prop等
    |-- check_builds.sh
    包裝了diff,用來看2個發布版本之間變化
    |-- check_prereq
    device上進行ota升級時的工具之一
    |-- compare_fileslist.py
    與check_builds.sh配合完成版本比較的腳本
    |-- droiddoc
    Android更具javadoc的一些移植
    |-- mp-package-stats
    簡單的查看一個jar/apk文件內的dex和其它文件的大小信息
    |-- event_log_tags.py
    處理event-log-tags的內容,關於event-log-tags文件的意義參見《Android學習之event-log-tags是神馬》
    |-- fileslist.py
    簡化的列出指定目錄下所有文件及大小的腳本 -- 可以放入自己的工具庫了使用:)
    |-- findleaves.py
    在指定目錄中(可多個)找指定文件的腳本 -- 可以放入自己的工具庫了使用:)
    |-- fixlinebreaks.sh
    把windows中的換行改為linux下的 -- 可以放入自己的工具庫了使用:大散蘆)
    |-- fs_config
    列出指定文件夾滾帶及文件的許可權
    |-- fs_get_stats
    得到指定文件夾下文件的簡單stats信息
    |-- iself
    判斷文件是否是ELF格式
    |-- isprelinked
    判斷文件是否是prelink過的
    |-- java-event-log-tags.py
    處理event-log-tags的內容,關於event-log-tags文件的意義參見《Android學習之event-log-tags是神馬》
    |-- kcm
    key character map的工具, 相關資料參照:
    |-- lsd
    !!!!!! ???
    |-- merge-event-log-tags.py
    處理event-log-tags的內容,關於event-log-tags文件的意掘野義參見《Android學習之event-log-tags是神馬》
    |-- mktarball.sh
    與fs_get_stats配合而執行的打包工具
    |-- print_mole_licenses.sh
    顯示當前目錄下所有mole信息
    |-- releasetools
    -- check_target_files_signatures
    |-- common.py
    |-- edify_generator.py
    |-- img_from_target_files
    |-- ota_from_target_files
    `-- sign_target_files_apks
    |-- rgb2565
    rgb轉換工具
    |-- signapk
    命令行下對jar包簽名的工具
    |-- soslim
    Android定製的編譯工具之一,簡單介紹參見(mydroid/bionic/linker/README.TXT)
    |-- warn.py
    解析Android系統編譯log的工具
    `-- zipalign
    zipfile的對齊工具,參見該文件夾下的README.TXT
    #p#副標題#e#
    在來看看Android編譯系統中定義的一些通用XXX.mk文件
    mydroid/build/core/
    |-- armelflib.x
    |-- armelf.x
    |-- armelf.xsc
    |-- base_rules.mk
    |-- binary.mk
    |-- build_id.mk
    |-- build-system.html
    |-- checktree
    |-- cleanbuild.mk
    |-- cleanspec.mk
    |-- clear_vars.mk
    |-- combo
    |-- config.mk
    |-- _headers.mk
    |-- definitions.mk
    |-- device.mk
    |-- dex_preopt.mk
    |-- distdir.mk
    |-- droiddoc.mk
    |-- mpvar.mk
    |-- dynamic_binary.mk
    |-- envsetup.mk
    |-- executable.mk
    |-- filter_symbols.sh
    |-- find-jdk-tools-jar.sh
    |-- help.mk
    |-- host_executable.mk
    |-- host_java_library.mk
    |-- host_native_test.mk
    |-- host_prebuilt.mk
    |-- host_shared_library.mk
    |-- host_static_library.mk
    |-- java_library.mk
    |-- java.mk
    |-- legacy_prebuilts.mk
    |-- main.mk
    |-- Makefile
    |-- multi_prebuilt.mk
    |-- native_test.mk
    |-- node_fns.mk
    |-- notice_files.mk
    |-- package.mk
    |-- pathmap.mk |-- phony_package.mk
    |-- prebuilt.mk
    |-- process_wrapper_gdb.cmds
    |-- process_wrapper_gdb.sh
    |-- process_wrapper.sh
    |-- proct_config.mk
    |-- proct.mk
    |-- proguard.flags
    |-- proguard_tests.flags
    |-- raw_executable.mk
    |-- raw_static_library.mk
    |-- root.mk
    |-- shared_library.mk
    |-- static_java_library.mk
    |-- static_library.mk
    |-- tasks
    |-- user_tags.mk
    `-- version_defaults.mk
    #p#副標題#e#
    這里,目錄在mydroid/build/core/tasks/有一些特別的task
    |-- apicheck.mk, 判斷api是否符合AOSP的規范
    |-- cts.mk cts測試, 可以在代碼根目錄, make cts, 編譯結束之後,進入out/host/linux-x86/bin/下,執行cts命令
    |-- ide.mk IDE開發環境
    |-- proct-graph.mk
    `-- sdk-addon.mk
    NDK的build環境沒有包含在標注難得AOSP的/build/目錄下
    而是在mydroid/ndk/build下
    $ cd ndk/build/tools
    $ export ANDROID_NDK_ROOT=aosp-root/ndk
    $ ./make-release --help
    一些小技巧
    如何顯示每次編譯所包含的所有xxx.mk文件
    找到build/core/main.mk
    把include $(subdir_makefiles)替換為
    [plain] view plain $(foreach subdir_makefile, $(subdir_makefiles),
    $(info Including $(subdir_makefile))
    $(eval include $(subdir_makefile)))
    subdir_makefile :=
    如果遇見API相關的PACKAGING/checkapi-current-timestamp] Error 38
    需要執行:make update-api
    如何在AOSP代碼目錄之外編譯
    [plain] view plain # Paths and settings
    TARGET_PRODUCT = generic
    ANDROID_ROOT = /home/karim/android/aosp-2.3.x
    BIONIC_LIBC = $(ANDROID_ROOT)/bionic/libc
    PRODUCT_OUT = $(ANDROID_ROOT)/out/target/proct/$(TARGET_PRODUCT)
    CROSS_COMPILE =
    $(ANDROID_ROOT)/prebuilt/linux-x86/toolchain/arm-eabi-4.4.3/bin/arm-eabi-
    # Tool names
    AS = $(CROSS_COMPILE)as
    AR = $(CROSS_COMPILE)ar
    CC = $(CROSS_COMPILE)gcc
    CPP = $(CC) -E
    LD = $(CROSS_COMPILE)ld
    NM = $(CROSS_COMPILE)nm
    OBJCOPY = $(CROSS_COMPILE)obj
    OBJDUMP = $(CROSS_COMPILE)objmp
    RANLIB = $(CROSS_COMPILE)ranlib
    READELF = $(CROSS_COMPILE)readelf
    SIZE = $(CROSS_COMPILE)size
    STRINGS = $(CROSS_COMPILE)strings
    STRIP = $(CROSS_COMPILE)strip
    export AS AR CC CPP LD NM OBJCOPY OBJDUMP RANLIB READELF
    SIZE STRINGS STRIP
    # Build settings
    CFLAGS = -O2 -Wall -fno-short-enums
    HEADER_OPS = -I$(BIONIC_LIBC)/arch-arm/include
    -I$(BIONIC_LIBC)/kernel/common
    -I$(BIONIC_LIBC)/kernel/arch-arm
    LDFLAGS = -nostdlib -Wl,-dynamic-linker,/system/bin/linker
    $(PRODUCT_OUT)/obj/lib/crtbegin_dynamic.o
    $(PRODUCT_OUT)/obj/lib/crtend_android.o
    -L$(PRODUCT_OUT)/obj/lib -lc -ldl
    # Installation variables
    EXEC_NAME = example-app
    INSTALL = install
    INSTALL_DIR = $(PRODUCT_OUT)/system/bin
    # Files needed for the build
    OBJS = example-app.o
    # Make rules
    all: example-app
    .c.o:
    $(CC) $(CFLAGS) $(HEADER_OPS) -c {1}lt;
    example-app: ${OBJS}
    $(CC) -o $(EXEC_NAME) ${OBJS} $(LDFLAGS)
    install: example-app
    test -d $(INSTALL_DIR) || $(INSTALL) -d -m 755 $(INSTALL_DIR)
    $(INSTALL) -m 755 $(EXEC_NAME) $(INSTALL_DIR)
    clean:
    rm -f *.o $(EXEC_NAME) core
    distclean:
    rm -f *~
    rm -f *.o $(EXEC_NAME) core
    如何增加一個新的設備
    [plain] view plain $ cd ~/android/aosp-2.3.x
    $ . build/envsetup.sh
    $ mkdir -p device/acme/coyotepad
    $ cd device/acme/coyotepad
    進入AndroidProcts.mk
    PRODUCT_MAKEFILES :=
    $(LOCAL_DIR)/full_coyotepad.mk
    對於full_coyotepad.mk
    $(call inherit-proct, $(SRC_TARGET_DIR)/proct/languages_full.mk)
    $(call inherit-proct, $(SRC_TARGET_DIR)/proct/full.mk)
    DEVICE_PACKAGE_OVERLAYS :=
    PRODUCT_PACKAGES +=
    PRODUCT_COPY_FILES +=
    PRODUCT_NAME := full_coyotepad
    PRODUCT_DEVICE := coyotepad
    PRODUCT_MODEL := Full Android on CoyotePad, meep-meep
    在BoardConfig.mk中
    TARGET_NO_KERNEL := true
    TARGET_NO_BOOTLOADER := true
    TARGET_CPU_ABI := armeabi
    BOARD_USES_GENERIC_AUDIO := true
    USE_CAMERA_STUB := true
    打開vendorsetup.sh
    add_lunch_combo full_coyotepad-eng
    #p#副標題#e#

    ❾ ubuntu/mac android aosp源碼編譯遇到的坑

    以上是編譯aosp問題總結
    ========================分割線==========================

    直接在命令行中設置臨時變數就行

    以上是刷機問題總結
    ========================分割線==========================

    ❿ 編譯aosp為什麼要安裝gcc

    如果你的源程序是 C 語言的話,而你又是在 LINUX 系統下開發程序,那你就必須使用 gcc 編譯器;如果你是在 UNIX 系統下開發 C 語言源程序,那麼就要使用 cc 編譯器。所以說,最關鍵的還是要看你的軟體開發平台。

    熱點內容
    國密演算法獲取 發布:2024-05-04 16:38:24 瀏覽:68
    腳本精靈荒野亂斗 發布:2024-05-04 16:28:33 瀏覽:518
    剛到的筆記本怎麼看配置 發布:2024-05-04 16:26:58 瀏覽:2
    蘋果7怎麼給支付寶加密碼 發布:2024-05-04 16:13:12 瀏覽:404
    sql培訓視頻 發布:2024-05-04 16:00:59 瀏覽:263
    極無雙平新伺服器什麼時候出 發布:2024-05-04 15:50:47 瀏覽:661
    c語言千分數 發布:2024-05-04 15:46:31 瀏覽:345
    資料庫no 發布:2024-05-04 15:38:00 瀏覽:220
    ionic編譯android 發布:2024-05-04 15:20:45 瀏覽:488
    雲伺服器在哪買 發布:2024-05-04 15:19:18 瀏覽:85