Dependency ของ OEM สำหรับเครื่องมือจัดการทรัพยากรสื่อ

เอกสารนี้มีไว้เพื่อช่วยผู้ผลิตอุปกรณ์ดั้งเดิม (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 สามารถใช้การทดสอบนี้เพื่อสร้างขีดจํากัดการเรียกใช้พร้อมกันที่ผ่านการทดสอบ โดยทำดังนี้

  1. เรียกใช้การทดสอบก่อนโดยใช้ cts-tradefed
  2. ประเมินข้อความแสดงข้อผิดพลาดที่เกิดขึ้น มีตัวอย่างดังต่อไปนี้
    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>
    
  3. เพิ่มบรรทัด concurrent-instances ที่แนะนําในข้อความการทดสอบที่ดำเนินการไม่สําเร็จลงในไฟล์ /etc/media_codecs.xml
  4. เรียกใช้การทดสอบอีกครั้งเพื่อยืนยันว่าการทดสอบสําเร็จ

อัตราเฟรมที่ทำได้สำหรับตัวแปลงรหัสวิดีโอ

อินเทอร์เฟซ VideoCapabilities.getAchievableFrameRatesFor จะแสดงผลช่วงอัตราเฟรมวิดีโอที่ทำได้สำหรับขนาดวิดีโอ OEM จะต้องระบุข้อมูลนี้สำหรับอุปกรณ์แต่ละเครื่องผ่านไฟล์ XML ที่วางไว้ที่ /etc/media_codecs_performance.xml การตั้งค่าเหล่านี้ผ่านการทดสอบ com.android.cts.videoperf.VideoEncoderDecoderTest และ android.media.cts.VideoDecoderPerfTest CTS

OEM สามารถใช้การทดสอบ CTS เพื่อสร้างไฟล์ XML ที่ผ่านการทดสอบ โดยทำดังนี้

  1. เรียกใช้การทดสอบก่อนโดยใช้ cts-tradefed เนื่องจากประสิทธิภาพของ Android มีความผันผวน เราจึงขอแนะนำให้ทำการทดสอบหลายครั้งเพื่อให้ได้ค่าต่ำสุดและสูงสุดที่แม่นยำยิ่งขึ้น
  2. ใช้สคริปต์ get_achievable_rates.py ที่ให้มาเพื่อสร้างไฟล์ XML
  3. วางไฟล์ 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
    
  4. เรียกใช้การทดสอบประสิทธิภาพอีกครั้งเพื่อยืนยันประสิทธิภาพ

การใช้โค้ดที่ปลอดภัยและโค้ดที่ไม่ปลอดภัยร่วมกัน

  • 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 รายการนี้อย่างถูกต้อง