เอกสารนี้มีไว้เพื่อช่วยผู้ผลิตอุปกรณ์ดั้งเดิม (OEM) ในการรองรับเครื่องมือจัดการทรัพยากรสื่อของ Android และ API ที่เกี่ยวข้องอย่างเหมาะสม
อินสแตนซ์ตัวแปลงรหัสพร้อมกันสูงสุด
อินเทอร์เฟซ CodecCapabilities.getMaxSupportedInstances
จะแสดงจํานวนอินสแตนซ์ตัวแปลงรหัสพร้อมกันสูงสุดที่รองรับ
การทดสอบ CTS
testGetMaxSupportedInstances(android.media.cts.MediaCodecCapabilitiesTest)
มีไว้เพื่อบังคับให้ตั้งค่าสูงสุดที่เหมาะสมใน
/etc/media_codecs.xml
มีตัวอย่างดังต่อไปนี้
... <MediaCodecs> ... <Encoders> <MediaCodec name="OMX.<vendor>.video.encoder.avc" type="video/avc" > ... <Limit name="concurrent-instances" max="13" /> </MediaCodec> ... </Encoders> ... </MediaCodecs>
OEM สามารถใช้การทดสอบนี้เพื่อสร้างขีดจํากัดการเรียกใช้พร้อมกันที่ผ่านการทดสอบ โดยทำดังนี้
- เรียกใช้การทดสอบก่อนโดยใช้ cts-tradefed
- ประเมินข้อความแสดงข้อผิดพลาดที่เกิดขึ้น มีตัวอย่างดังต่อไปนี้
There was 1 failure: 1) testGetMaxSupportedInstances(android.media.cts.MediaCodecCapabilitiesTest) junit.framework.AssertionFailedError: In order to pass the test, please publish following codecs' concurrent instances limit in /etc/media_codecs.xml: <MediaCodec name="OMX.<vendor>.video.encoder.mpeg4" type="video/mp4v-es" > <Limit name="concurrent-instances" max="13" /> </MediaCodec> <MediaCodec name="OMX.<vendor>.video.encoder.h263" type="video/3gpp" > <Limit name="concurrent-instances" max="13" /> </MediaCodec> <MediaCodec name="OMX.<vendor>.video.encoder.avc" type="video/avc" > <Limit name="concurrent-instances" max="13" /> </MediaCodec> <MediaCodec name="OMX.<vendor>.video.encoder.vp8" type="video/x-vnd.on2.vp8" > <Limit name="concurrent-instances" max="13" /> </MediaCodec> <MediaCodec name="OMX.<vendor>.video.decoder.avc" type="video/avc" > <Limit name="concurrent-instances" max="13" /> </MediaCodec> <MediaCodec name="OMX.<vendor>.video.decoder.avc.secure" type="video/avc" > <Limit name="concurrent-instances" max="4" /> </MediaCodec> <MediaCodec name="OMX.<vendor>.video.decoder.mpeg4" type="video/mp4v-es" > <Limit name="concurrent-instances" max="12" /> </MediaCodec> <MediaCodec name="OMX.<vendor>.video.decoder.h263" type="video/3gpp" > <Limit name="concurrent-instances" max="12" /> </MediaCodec> <MediaCodec name="OMX.<vendor>.video.decoder.vp8" type="video/x-vnd.on2.vp8" > <Limit name="concurrent-instances" max="12" /> </MediaCodec>
- เพิ่มบรรทัด
concurrent-instances
ที่แนะนําในข้อความการทดสอบที่ดำเนินการไม่สําเร็จลงในไฟล์/etc/media_codecs.xml
- เรียกใช้การทดสอบอีกครั้งเพื่อยืนยันว่าการทดสอบสําเร็จ
อัตราเฟรมที่ทำได้สำหรับตัวแปลงรหัสวิดีโอ
อินเทอร์เฟซ VideoCapabilities.getAchievableFrameRatesFor
จะแสดงผลช่วงอัตราเฟรมวิดีโอที่ทำได้สำหรับขนาดวิดีโอ OEM จะต้องระบุข้อมูลนี้สำหรับอุปกรณ์แต่ละเครื่องผ่านไฟล์ XML ที่วางไว้ที่ /etc/media_codecs_performance.xml
การตั้งค่าเหล่านี้ผ่านการทดสอบ com.android.cts.videoperf.VideoEncoderDecoderTest
และ android.media.cts.VideoDecoderPerfTest
CTS
OEM สามารถใช้การทดสอบ CTS เพื่อสร้างไฟล์ XML ที่ผ่านการทดสอบ โดยทำดังนี้
- เรียกใช้การทดสอบก่อนโดยใช้ cts-tradefed เนื่องจากประสิทธิภาพของ Android มีความผันผวน เราจึงขอแนะนำให้ทำการทดสอบหลายครั้งเพื่อให้ได้ค่าต่ำสุดและสูงสุดที่แม่นยำยิ่งขึ้น
- ใช้สคริปต์ get_achievable_rates.py ที่ให้มาเพื่อสร้างไฟล์ XML
- วางไฟล์ XML ที่
/etc/media_codecs_performance.xml
โดยปกติแล้วจะทำได้โดยวางไฟล์ XML ในโปรเจ็กต์อุปกรณ์ (device/<vendor>/<product>) และเพิ่มบรรทัดPRODUCT_COPY_FILES
ไปยังdevice.mk
ดังนี้PRODUCT_COPY_FILES += \ ... device/moto/shamu/media_codecs.xml:system/etc/media_codecs.xml \ + device/moto/shamu/media_codecs_performance.xml:system/etc/media_codecs_performance.xml
- เรียกใช้การทดสอบประสิทธิภาพอีกครั้งเพื่อยืนยันประสิทธิภาพ
การใช้โค้ดที่ปลอดภัยและโค้ดที่ไม่ปลอดภัยร่วมกัน
- supports-secure-with-non-secure-codec — หากอินสแตนซ์ของตัวแปลงรหัสที่ปลอดภัยและอินสแตนซ์ของตัวแปลงรหัสที่ไม่ปลอดภัยไม่สามารถอยู่ร่วมกันได้ในเวลาเดียวกัน ก็ควรระบุเป็นการตั้งค่าส่วนกลางในไฟล์
media_codecs.xml
<MediaCodecs> <Settings> <Setting name="supports-secure-with-non-secure-codec" value="false" /> </Settings> <Encoders> …
- supports-multiple-secure-codecs —
หากระบบไม่รองรับอินสแตนซ์โค้ดที่ปลอดภัยหลายรายการที่ทำงานร่วมกัน คุณควรระบุเป็นการตั้งค่าส่วนกลางในไฟล์
media_codecs.xml
<MediaCodecs> <Settings> <Setting name="supports-multiple-secure-codecs" value="false" /> </Settings> <Encoders> …
- โปรดทราบว่าการตั้งค่าทั้ง 2 รายการจะเป็น "จริง" โดยค่าเริ่มต้น ซึ่งหมายความว่าหากระบบรองรับการตั้งค่าเหล่านี้ คุณก็ไม่จําเป็นต้องเพิ่มบรรทัดการตั้งค่าลงใน
media_codecs.xml
- การทดสอบ
ResourceManagerTest
CTS อาจไม่สำเร็จหากไม่ได้ตั้งค่า 2 รายการนี้อย่างถูกต้อง