กำลังดาวน์โหลดแหล่งที่มา

ต้นไม้ต้นทางของ Android อยู่ในที่เก็บ Git ที่โฮสต์โดย Google ที่เก็บ Git มีข้อมูลเมตาสำหรับแหล่งที่มาของ Android รวมถึงการเปลี่ยนแปลงที่มาและเวลาที่ทำการเปลี่ยนแปลง หน้านี้อธิบายวิธีดาวน์โหลดแผนผังแหล่งที่มาสำหรับบรรทัดโค้ด Android ที่ระบุ

หากต้องการเริ่มต้นด้วยอิมเมจจากโรงงานสำหรับอุปกรณ์เฉพาะแทนที่จะดาวน์โหลดแหล่งที่มา โปรดดู ที่การเลือกรุ่นอุปกรณ์

การเริ่มต้นไคลเอนต์ Repo

หลังจาก ติดตั้ง Repo Launcher ให้ตั้งค่าไคลเอนต์ของคุณเพื่อเข้าถึงที่เก็บซอร์ส Android:

  1. สร้างไดเร็กทอรีว่างเพื่อเก็บไฟล์งานของคุณ ตั้งชื่อตามที่คุณต้องการ:

    mkdir WORKING_DIRECTORY
    cd WORKING_DIRECTORY
    
  2. กำหนดค่า Git ด้วยชื่อจริงและที่อยู่อีเมลของคุณ ในการใช้เครื่องมือตรวจสอบโค้ดของ Gerrit คุณต้องมีที่อยู่อีเมลที่เชื่อมโยงกับ บัญชี Google ที่ลงทะเบียน ไว้ ตรวจสอบให้แน่ใจว่านี่คือที่อยู่จริงที่คุณสามารถรับข้อความได้ ชื่อที่คุณระบุที่นี่จะแสดงในที่มาสำหรับการส่งรหัสของคุณ

    git config --global user.name Your Name
    git config --global user.email you@example.com
    
  3. เรียกใช้ repo init เพื่อรับ Repo เวอร์ชันล่าสุดพร้อมการแก้ไขจุดบกพร่องล่าสุด คุณต้องระบุ URL สำหรับรายการ ซึ่งระบุตำแหน่งที่เก็บต่างๆ ที่รวมอยู่ในแหล่งที่มาของ Android ภายในไดเร็กทอรีการทำงานของคุณ

    repo init -u https://android.googlesource.com/platform/manifest
    

    เพื่อตรวจสอบสาขาหลัก:

    repo init -u https://android.googlesource.com/platform/manifest -b master
    

    หากต้องการตรวจสอบสาขา อื่นที่ไม่ใช่ master ให้ระบุด้วย -b สำหรับรายชื่อสาขา โปรดดู ที่ แท็กซอร์สโค้ดและบิล ด์

    สำหรับ Python2

    สำหรับ Python 3

    หากคุณได้รับข้อความแสดงข้อผิดพลาด " /usr/bin/env 'python' no such file or directory " ให้ใช้วิธีใดวิธีหนึ่งต่อไปนี้:

    หาก Ubuntu 20.04.2 LTS ของคุณเป็นเวอร์ชัน Linux ที่ติดตั้งใหม่ (เทียบกับที่อัปเกรดแล้ว):

    sudo ln -s /usr/bin/python3 /usr/bin/python

    หากใช้ Git เวอร์ชัน 2.19 ขึ้นไป คุณสามารถระบุ --partial-clone เมื่อดำเนินการ repo init สิ่งนี้ทำให้ใช้ความสามารถในการ โคลนบางส่วน ของ Git เพื่อดาวน์โหลดวัตถุ Git เมื่อจำเป็นเท่านั้น แทนที่จะดาวน์โหลดทุกอย่าง เนื่องจากการใช้โคลนบางส่วนหมายความว่าการดำเนินการหลายอย่างต้องสื่อสารกับเซิร์ฟเวอร์ โปรดใช้สิ่งต่อไปนี้หากคุณเป็นนักพัฒนาซอฟต์แวร์และคุณใช้เครือข่ายที่มีเวลาแฝงต่ำ:

    repo init -u https://android.googlesource.com/platform/manifest -b master --partial-clone --clone-filter=blob:limit=10M
    

    สำหรับระบบปฏิบัติการ Windows เท่านั้น: หากคุณได้รับข้อความแสดงข้อผิดพลาดที่ระบุว่าไม่สามารถสร้างลิงก์สัญลักษณ์ได้ ทำให้ repo init ล้มเหลว โปรดอ้างอิง เอกสารประกอบ GitHub Symbolic Links เพื่อสร้างลิงก์เหล่านี้ หรือเพื่อเปิดใช้งานการสนับสนุน สำหรับผู้ที่ไม่ใช่ผู้ดูแลระบบ โปรดดูส่วนการ อนุญาตให้ผู้ที่ไม่ใช่ผู้ดูแลระบบสร้างลิงก์สัญลักษณ์

การเริ่มต้นที่สำเร็จจะจบลงด้วยข้อความที่ระบุว่า Repo ถูกเตรียมใช้งานในไดเร็กทอรีการทำงานของคุณ ขณะนี้ไดเร็กทอรีไคลเอ็นต์ของคุณมีไดเร็กทอรี .repo ซึ่งเก็บไฟล์ต่างๆ เช่น รายการไว้

กำลังดาวน์โหลดแผนผังแหล่งที่มาของ Android

ในการดาวน์โหลดซอร์สทรีของ Android ไปยังไดเร็กทอรีการทำงานของคุณจากที่เก็บตามที่ระบุในรายการเริ่มต้น ให้รัน:

repo sync

หากต้องการเร่งความเร็วการซิงค์ ให้ส่งแฟล็ก -c (สาขาปัจจุบัน) และ -j threadcount :

repo sync -c -j8

ไฟล์ต้นฉบับของ Android จะถูกดาวน์โหลดในไดเร็กทอรีการทำงานของคุณภายใต้ชื่อโครงการ

หากต้องการระงับเอาต์พุต ให้ส่งแฟล็ก -q (เงียบ) ดูการ อ้างอิงคำสั่ง Repo สำหรับตัวเลือกทั้งหมด

ใช้การรับรองความถูกต้อง

โดยค่าเริ่มต้น การเข้าถึงซอร์สโค้ดของ Android จะไม่ระบุตัวตน เพื่อป้องกันเซิร์ฟเวอร์จากการใช้งานที่มากเกินไป ที่อยู่ IP แต่ละรายการจะเชื่อมโยงกับโควต้า

เมื่อแบ่งปันที่อยู่ IP กับผู้ใช้รายอื่น (เช่น เมื่อเข้าถึงที่เก็บต้นทางจากนอกไฟร์วอลล์ NAT) โควต้าสามารถทริกเกอร์ได้แม้สำหรับรูปแบบการใช้งานปกติ (เช่น หากผู้ใช้จำนวนมากซิงค์ไคลเอ็นต์ใหม่จากที่อยู่ IP เดียวกันภายใน ช่วงสั้น ๆ).

ในกรณีนั้น คุณสามารถใช้การเข้าถึงที่รับรองความถูกต้อง ซึ่งจะใช้โควต้าแยกต่างหากสำหรับผู้ใช้แต่ละราย โดยไม่คำนึงถึงที่อยู่ IP

ขั้นแรก สร้างรหัสผ่านด้วย ตัวสร้างรหัสผ่าน และทำตามคำแนะนำในหน้าตัวสร้างรหัสผ่าน

ถัดไป บังคับการเข้าถึงที่ตรวจสอบสิทธิ์โดยใช้รายการ URI https://android.googlesource.com/a/platform/manifest สังเกตว่าคำนำหน้าไดเร็กทอรี /a/ ทริกเกอร์การพิสูจน์ตัวตนที่บังคับได้อย่างไร คุณสามารถแปลงไคลเอ็นต์ที่มีอยู่เพื่อใช้การพิสูจน์ตัวตนที่บังคับได้ด้วยคำสั่งต่อไปนี้:

repo init -u https://android.googlesource.com/a/platform/manifest

การแก้ไขปัญหาเครือข่าย

เมื่อดาวน์โหลดจากด้านหลังพรอกซี (ซึ่งพบได้ทั่วไปในสภาพแวดล้อมขององค์กรบางประเภท) คุณอาจต้องระบุพร็อกซีให้ชัดเจนเพื่อให้ Repo ใช้:

export HTTP_PROXY=http://<proxy_user_id>:<proxy_password>@<proxy_server>:<proxy_port>
export HTTPS_PROXY=http://<proxy_user_id>:<proxy_password>@<proxy_server>:<proxy_port>

ไคลเอ็นต์ Linux มักประสบปัญหาการเชื่อมต่อ ติดอยู่ระหว่างการดาวน์โหลด (โดยทั่วไปมักอยู่ระหว่าง การรับวัตถุ ) การปรับการตั้งค่าของสแต็ก TCP/IP และการใช้คำสั่งที่ไม่ขนานกันสามารถปรับปรุงสถานการณ์ได้ คุณต้องมีสิทธิ์เข้าถึงรูทเพื่อแก้ไขการตั้งค่า TCP:

sudo sysctl -w net.ipv4.tcp_window_scaling=0
repo sync -j1

ใช้มิเรอร์ในพื้นที่

เมื่อใช้ไคลเอ็นต์หลายเครื่อง โดยเฉพาะอย่างยิ่งในสถานการณ์ที่แบนด์วิดท์มีน้อย จะเป็นการดีกว่าที่จะสร้างมิเรอร์ในเครื่องของเนื้อหาเซิร์ฟเวอร์ทั้งหมด และซิงค์ไคลเอ็นต์จากมิเรอร์นั้น (ซึ่งไม่จำเป็นต้องเข้าถึงเครือข่าย) การดาวน์โหลดสำหรับมิเรอร์แบบเต็มมีขนาดเล็กกว่าการดาวน์โหลดของไคลเอ็นต์สองเครื่อง และมีข้อมูลเพิ่มเติม

คำแนะนำเหล่านี้ถือว่ามิเรอร์ถูกสร้างขึ้นใน /usr/local/aosp/mirror ขั้นแรก สร้างและซิงค์มิเรอร์เอง สังเกตแฟล็ก --mirror ซึ่งคุณสามารถระบุได้เฉพาะเมื่อสร้างไคลเอ็นต์ใหม่เท่านั้น:

mkdir -p /usr/local/aosp/mirror
cd /usr/local/aosp/mirror
repo init -u https://android.googlesource.com/mirror/manifest --mirror
repo sync

เมื่อมิเรอร์ถูกซิงค์ คุณสามารถสร้างไคลเอนต์ใหม่ได้ โปรดทราบว่าคุณต้องระบุเส้นทางที่แน่นอน:

mkdir -p /usr/local/aosp/master
cd /usr/local/aosp/master
repo init -u /usr/local/aosp/mirror/platform/manifest.git
repo sync

สุดท้าย ในการซิงค์ไคลเอ็นต์กับเซิร์ฟเวอร์ ให้ซิงค์มิเรอร์กับเซิร์ฟเวอร์ จากนั้นซิงค์ไคลเอ็นต์กับมิเรอร์:

cd /usr/local/aosp/mirror
repo sync
cd /usr/local/aosp/master
repo sync

เป็นไปได้ที่จะจัดเก็บมิเรอร์บนเซิร์ฟเวอร์ LAN และเข้าถึงผ่าน NFS, SSH หรือ Git นอกจากนี้ยังสามารถจัดเก็บไว้ในไดรฟ์แบบถอดได้ และส่งผ่านไดรฟ์นั้นไปยังผู้ใช้หรือเครื่องจักรต่างๆ

กำลังตรวจสอบแท็ก Git

โหลดคีย์สาธารณะต่อไปนี้ลงในฐานข้อมูลคีย์ GnuPG ของคุณ คีย์นี้ใช้เพื่อลงนามแท็กที่มีคำอธิบายประกอบซึ่งแสดงถึงการวางจำหน่าย

gpg --import

คัดลอกและวางคีย์ด้านล่าง จากนั้นพิมพ์ EOF ( Ctrl-D ) เพื่อสิ้นสุดอินพุตและประมวลผลคีย์

-----BEGIN PGP PUBLIC KEY BLOCK-----
Version: GnuPG v1.4.2.2 (GNU/Linux)

mQGiBEnnWD4RBACt9/h4v9xnnGDou13y3dvOx6/t43LPPIxeJ8eX9WB+8LLuROSV
lFhpHawsVAcFlmi7f7jdSRF+OvtZL9ShPKdLfwBJMNkU66/TZmPewS4m782ndtw7
8tR1cXb197Ob8kOfQB3A9yk2XZ4ei4ZC3i6wVdqHLRxABdncwu5hOF9KXwCgkxMD
u4PVgChaAJzTYJ1EG+UYBIUEAJmfearb0qRAN7dEoff0FeXsEaUA6U90sEoVks0Z
wNj96SA8BL+a1OoEUUfpMhiHyLuQSftxisJxTh+2QclzDviDyaTrkANjdYY7p2cq
/HMdOY7LJlHaqtXmZxXjjtw5Uc2QG8UY8aziU3IE9nTjSwCXeJnuyvoizl9/I1S5
jU5SA/9WwIps4SC84ielIXiGWEqq6i6/sk4I9q1YemZF2XVVKnmI1F4iCMtNKsR4
MGSa1gA8s4iQbsKNWPgp7M3a51JCVCu6l/8zTpA+uUGapw4tWCp4o0dpIvDPBEa9
b/aF/ygcR8mh5hgUfpF9IpXdknOsbKCvM9lSSfRciETykZc4wrRCVGhlIEFuZHJv
aWQgT3BlbiBTb3VyY2UgUHJvamVjdCA8aW5pdGlhbC1jb250cmlidXRpb25AYW5k
cm9pZC5jb20+iGAEExECACAFAknnWD4CGwMGCwkIBwMCBBUCCAMEFgIDAQIeAQIX
gAAKCRDorT+BmrEOeNr+AJ42Xy6tEW7r3KzrJxnRX8mij9z8tgCdFfQYiHpYngkI
2t09Ed+9Bm4gmEO5Ag0ESedYRBAIAKVW1JcMBWvV/0Bo9WiByJ9WJ5swMN36/vAl
QN4mWRhfzDOk/Rosdb0csAO/l8Kz0gKQPOfObtyYjvI8JMC3rmi+LIvSUT9806Up
hisyEmmHv6U8gUb/xHLIanXGxwhYzjgeuAXVCsv+EvoPIHbY4L/KvP5x+oCJIDbk
C2b1TvVk9PryzmE4BPIQL/NtgR1oLWm/uWR9zRUFtBnE411aMAN3qnAHBBMZzKMX
LWBGWE0znfRrnczI5p49i2YZJAjyX1P2WzmScK49CV82dzLo71MnrF6fj+Udtb5+
OgTg7Cow+8PRaTkJEW5Y2JIZpnRUq0CYxAmHYX79EMKHDSThf/8AAwUIAJPWsB/M
pK+KMs/s3r6nJrnYLTfdZhtmQXimpoDMJg1zxmL8UfNUKiQZ6esoAWtDgpqt7Y7s
KZ8laHRARonte394hidZzM5nb6hQvpPjt2OlPRsyqVxw4c/KsjADtAuKW9/d8phb
N8bTyOJo856qg4oOEzKG9eeF7oaZTYBy33BTL0408sEBxiMior6b8LrZrAhkqDjA
vUXRwm/fFKgpsOysxC6xi553CxBUCH2omNV6Ka1LNMwzSp9ILz8jEGqmUtkBszwo
G1S8fXgE0Lq3cdDM/GJ4QXP/p6LiwNF99faDMTV3+2SAOGvytOX6KjKVzKOSsfJQ
hN0DlsIw8hqJc0WISQQYEQIACQUCSedYRAIbDAAKCRDorT+BmrEOeCUOAJ9qmR0l
EXzeoxcdoafxqf6gZlJZlACgkWF7wi2YLW3Oa+jv2QSTlrx4KLM=
=Wi5D
-----END PGP PUBLIC KEY BLOCK-----

หลังจากนำเข้าคีย์แล้ว คุณสามารถตรวจสอบแท็กด้วย:

git tag -v TAG_NAME

รับไบนารีที่เป็นกรรมสิทธิ์

AOSP ไม่สามารถใช้จากซอร์สโค้ดล้วนๆ เท่านั้น และต้องใช้ไลบรารีที่เป็นกรรมสิทธิ์ที่เกี่ยวข้องกับฮาร์ดแวร์เพิ่มเติมเพื่อทำงาน เช่น สำหรับการเร่งกราฟิกด้วยฮาร์ดแวร์ ดูส่วนด้านล่างสำหรับลิงค์ดาวน์โหลดและ ไบนารีของอุปกรณ์ สำหรับแหล่งข้อมูลเพิ่มเติม

ดาวน์โหลดไบนารีที่เป็นกรรมสิทธิ์

คุณสามารถดาวน์โหลดไบนารีอย่างเป็นทางการสำหรับอุปกรณ์ที่รองรับซึ่งรันสาขาที่ติดแท็ก AOSP release จาก ไดรเวอร์ของ Google ไบนารีเหล่านี้เพิ่มการเข้าถึงความสามารถด้านฮาร์ดแวร์เพิ่มเติมด้วยรหัสที่ไม่ใช่โอเพ่นซอร์ส ในการสร้างสาขาหลัก AOSP ให้ใช้ Binaries Preview แทน เมื่อสร้างสาขาหลักสำหรับอุปกรณ์ ให้ใช้ไบนารีสำหรับ หมายเลขรุ่นล่าสุด หรือวันที่ล่าสุด

แยกไบนารีที่เป็นกรรมสิทธิ์

ไบนารีแต่ละชุดมาเป็นสคริปต์แบบขยายตัวเองในไฟล์บีบอัด คลายการบีบอัดแต่ละไฟล์เก็บถาวร เรียกใช้สคริปต์ขยายตัวเองที่รวมไว้จากรูทของทรีต้นทาง จากนั้นยืนยันว่าคุณยอมรับเงื่อนไขของข้อตกลงสิทธิ์การใช้งานที่แนบมา ไบนารีและ makefile ที่ตรงกันได้รับการติดตั้งใน vendor/ ลำดับชั้นของทรีต้นทาง

ทำความสะอาด

เพื่อให้แน่ใจว่าไบนารีที่ติดตั้งใหม่ได้รับการพิจารณาอย่างเหมาะสมหลังจากแตกไฟล์แล้ว ให้ลบเอาต์พุตที่มีอยู่ของบิลด์ก่อนหน้าโดยใช้:

make clobber