หน้านี้แสดงวิธีสร้างแพ็กเกจบริการ SDV บรรจุลงในรูปแบบไฟล์ APEX และเรียกใช้ในอุปกรณ์ Cuttlefish เสมือน หน่วยหลักของการดำเนินการโค้ดในระบบ SDV คือชุดบริการ Service Bundle มีเมธอดวงจรที่ระบบจะเรียกใช้เมื่อสถานะของระบบเปลี่ยนแปลง
ตั้งค่าสภาพแวดล้อมของบิลด์
จากภายในไดเรกทอรีการทำงาน ให้เรียกใช้สคริปต์
envsetup.shเพื่อตั้งค่าสภาพแวดล้อมของบิลด์ ตั้งค่า Cuttlefish เป็นเป้าหมายการสร้าง และสร้างเครื่องมือสร้างโค้ดvsidlcsource build/envsetup.sh lunch sdv_core_cf-trunk_staging-userdebug m vsidlcกำหนดสถาปัตยกรรมโดยสร้างโฟลเดอร์ชื่อ
my_catalogที่มีไฟล์ต่อไปนี้tire.proto: กำหนดโครงสร้างข้อมูลที่คุณส่ง
syntax = "proto3"; package com.android.sdv.sample.quickstart; import "google/protobuf/empty.proto"; import "sdv/vsidl/v1/annotations.proto"; message TirePressure { uint32 pressure = 1; } message TireInfoResponse { string serial_number = 1; uint32 max_pressure = 2; } service TireService { rpc GetTireInfo(google.protobuf.Empty) returns (TireInfoResponse); }architecture.vsidl: กำหนดแพ็กเกจบริการและการสื่อสารของแพ็กเกจบริการ
package: "com.android.sdv.sample.quickstart" service_bundle { name: "Manager" publisher { message: "TirePressure" topic: "pressure" capacity: 8 } server { service: "TireService" channel: "tire-service" } } service_bundle { name: "Monitor" subscriber { message: "TirePressure" topic: "pressure" } client { service: "TireService" channel: "tire-service" } }Android.bp: กำหนดกระบวนการบิลด์
rust_protobuf { name: "libquickstart_sample_tire_proto", crate_name: "quickstart_sample_tire_proto", protos: [ "tire.proto", ], source_stem: "quickstart_sample_tire_proto_source", rustlibs: [ "libvsidl_v1_stdlib_proto_rs", ], proto_flags: [ "-I external/protobuf/src", ], vendor_available: true, product_available: true, apex_available: [ "//apex_available:platform", "//apex_available:anyapex", ], min_sdk_version: "35", } filegroup { name: "vsidl_quickstart_catalog", srcs: ["**/*"], }
สร้างไฟล์การกำหนดค่าและการติดตั้งใช้งานโครงร่างโดยเรียกใช้คำสั่งต่อไปนี้
vsidlc -c /path/to/catalog -o /path/to/output --services --apexสำหรับแต่ละแพ็กเกจบริการ ให้ค้นหาการใช้งาน Rust ใน
/path/to/output/services/ServiceBundleName/src/main.rsโดยค่าเริ่มต้น การติดตั้งใช้งานที่สร้างขึ้นจะสร้างข้อความที่มี ค่าเริ่มต้นและส่งข้อความระหว่างผู้เผยแพร่โฆษณาและผู้ติดตาม หรือไคลเอ็นต์และเซิร์ฟเวอร์ RPC หากต้องการแก้ไขลักษณะการทำงานนี้ ให้ค้นหา
TODOความคิดเห็นในmain.rsแล้วปรับตามค่ากำหนด เช่นasync fn handle_tire_pressure_front_left_publisher(publisher: sdv::mw::Publisher<TirePressure>) { loop { // TODO: Modify the frequency of publishing messages here. sleep(Duration::from_secs(1)).await; // TODO: Modify the message content here. let message = TirePressure::default(); info!("Publishing on TirePressure#FRONT_LEFT"); publisher.publish(&message).unwrap(); } }หากต้องการรวมแพ็กเกจไว้ในอิมเมจระบบ ให้เพิ่มโมดูล APEX ที่สร้างขึ้น ชื่อลงในไฟล์ Makefile ของผลิตภัณฑ์
เปิดไฟล์ Makefile ของผลิตภัณฑ์ (เช่น
/device/google/sdv/sdv_core_base/sdv_samples_core_services.mk)เพิ่มโมดูลไปยัง
PRODUCT_PACKAGESโดยเพิ่มข้อมูลต่อไปนี้PRODUCT_PACKAGES += com.android.sdv.sample.quickstart PRODUCT_PACKAGES += com_android_sdv_sample_quickstart_orchestration_configurations
สร้างอิมเมจโดยใช้คำสั่งต่อไปนี้
mเรียกใช้และยืนยันการดำเนินการในแพ็กเกจบริการ
เริ่มอุปกรณ์ Cuttlefish เสมือน
sdv-cf create --instance_name=instance1เรียกใช้แพ็กเกจบริการเมื่อระบบบูต
ด้วยตนเอง
adb wait-for-device adb root adb shell sdv_service_bundle start local-vm:com.android.sdv.sample.quickstart.Manager/instance adb shell sdv_service_bundle start local-vm:com.android.sdv.sample.quickstart.Monitor/instanceผู้ประพันธ์ดนตรี
adb wait-for-device adb root # Apply global orchestration configuration by setting system property adb shell setprop persist.sdv.orchestrator_config_path "etc/orch/vm_quickstart_orch_config.textproto" adb rebootยืนยันการดำเนินการของแพ็กเกจบริการ
adb logcat *:F com_android_sdv_sample_quickstart_Manager_instance:* com_android_sdv_sample_quickstart_Monitor_instance:*คำสั่งนี้จะแสดงบันทึกที่แสดงการแลกเปลี่ยนข้อความของแพ็กเกจบริการ
03-30 13:41:31.505 967 976 I com_android_sdv_sample_quickstart_Manager_instance: sdv_lm_manager: Publishing on TirePressure#PRESSURE 03-30 13:41:31.505 983 991 I com_android_sdv_sample_quickstart_Monitor_instance: sdv_lm_monitor: Received message on TirePressure#PRESSURE: [TirePressure { pressure: 0, special_fields: SpecialFields { unknown_fields: UnknownFields { fields: None }, cached_size: CachedSize { size: 0 } } }] 03-30 13:41:31.626 983 991 I com_android_sdv_sample_quickstart_Monitor_instance: sdv_lm_monitor: Sending request on Monitor/TireService 03-30 13:41:31.627 967 976 I com_android_sdv_sample_quickstart_Manager_instance: sdv_lm_manager: Received request on Manager/TireService: Empty { special_fields: SpecialFields { unknown_fields: UnknownFields { fields: None }, cached_size: CachedSize { size: 0 } } } 03-30 13:41:31.627 983 991 I com_android_sdv_sample_quickstart_Monitor_instance: sdv_lm_monitor: Received response on Monitor/TireService: TireInfoResponse { serial_number: "", max_pressure: 0, special_fields: SpecialFields { unknown_fields: UnknownFields { fields: None }, cached_size: CachedSize { size: 0 } } }
ขั้นตอนถัดไป
ดูข้อมูลเพิ่มเติมเกี่ยวกับภาษาคำจำกัดความของอินเทอร์เฟซบริการยานพาหนะ (VSIDL) และวิธีกำหนดแพ็กเกจบริการของคุณเองตั้งแต่ต้น