Commit Graph

4799 Commits

Author SHA1 Message Date
android-build-team Robot
c9de9c4dae Snap for 7020202 from 14d2f62358 to sc-release
Change-Id: Ifa3858114fa40b6f633d9cad2b377b13626edf8e
2020-12-09 02:10:44 +00:00
Rahul Frias
14d2f62358 Merge "Reprovision on error 10085" 2020-12-08 20:29:48 +00:00
Alex Dale
6311f130c4 Merge "Restrict reserved Client ID fields." 2020-12-08 04:31:28 +00:00
android-build-team Robot
b2e9ac5c66 Snap for 7017853 from 99938c3a36 to sc-release
Change-Id: Ia7b80dc0f594d7d492d65844869a6909069aba43
2020-12-08 02:10:49 +00:00
Alex Dale
78f4bca3a9 Restrict reserved Client ID fields.
[ Merge of http://go/wvgerrit/108904 ]

Client ID name-value fields in the license request share the same
namespace with app parameters and WV standard device information.  As
a result, it was possible for applications to provide parameters that
could potentially fool the license server with spoof values.

This CL restricts the use of the fields that are common across both the
Android CDM and CE CDM.  Currently, Android specific fields are
restricted by the MediaDrmPlugin layer, and there are no CE CDM
specific fields currently defined.

The non-HIDL DRM plugin does not restrict these fields; however, it
will be removed in S.

Bug: 171723566
Test: Android integration test
Change-Id: I5ad9ead73c5aff712dff8133953de5ddc3296452
2020-12-04 12:34:01 -08:00
Rahul Frias
c034e1f8d2 Reprovision on error 10085
[ Merge of http://go/wvgerrit/110603 ]

Qualcomm SoC may report 10085 (RSASSA-PSS signature error) when
OEMCrypto_PrepareAndSignLicenseRequest is called. The app needs to
reprovision (or the user needs to factory reset their device) in order
to recover.

If the 10085 error is returned, the app currently will get a
MediaDrmStateException. The app has no way to be able to tell
whether this is due to the 10085 error or some other error.

This change returns a NEED_PROVISIONING error at the CDM level, which
will result in the app receiving a NotProvisionedException when
MediaDrm.getKeyRequest is called.

Bug: 174375589
Test: WV unit/integration tests
Change-Id: I4f2884c8a5fd88ab2e9bfbc0731a20e58cec0f36
2020-12-03 03:10:52 -08:00
Rahul Frias
99938c3a36 Fix Format String Signedness
[ Merge of http://go/wvgerrit/110165 ]

The conditional compilation for flagging the CDM and ODKiTEE logging
functions as printf-like was guarded by a check on "__gnuc__" or
"__clang__". However, GCC doesn't actually define "__gnuc__", it
defines "__GNUC__", all caps. Fixing this causes GCC to find a slew
of format-string errors that Clang was accepting. This patch fixes the
capitalization and the uncovered errors, most of which fall into one of
a few categories:

1) The format string and variable had different signedness. For these,
   the format strings are updated to match the variables.
2) The variable was an array index that was not of size_t. For these,
   the variables have been updated to be size_t and the format strings
   have been updated to use %zu. A few index variables that weren't
   actually used in format strings are also fixed to be size_t.
3) The code assumed the signedness of the internal representation of an
   integer literal, enum constant, or enum variable. For these, I either
   cast the input to a known type so that the format string is valid
   regardless of internal representation or I switched to a hexadecimal
   format string. The latter case is more useful on ODKiTEE enums where
   the literal value is in the code as a 32-bit hexadecimal value
   anyway.

This patch also adds missing integer casts to the enum literals in the
ODKiTEE logging header. (These are required for pedantic C99
compatibility when using literal values that do not fit into a 16-bit
integer.)

Bug: 173460694
Test: jenkins/odkitee_ta
Test: build.py x86-64
Change-Id: I244972639a5a6ea0de157eb67e1e0dfa9787ec32
2020-11-27 03:50:40 -08:00
android-build-team Robot
422527bffc Snap for 6981746 from c2df654ecc to sc-release
Change-Id: I1687b2d0b4d6d527d4ba1d34e705539f5d6ec803
2020-11-19 02:02:11 +00:00
Alex Dale
c2df654ecc Merge "Updated usage table capacity property string." 2020-11-18 07:23:49 +00:00
android-build-team Robot
d5c1ef32a8 Snap for 6978977 from e7bac6e6a1 to sc-release
Change-Id: I7a915968e1c89d216aefae132478b7406987376b
2020-11-18 02:17:30 +00:00
Cong Lin
f28ced6886 Merge "Upgrade L3 to v16 and update Android.bp files" 2020-11-18 00:16:23 +00:00
Cong Lin
0f32446ee7 Upgrade L3 to v16 and update Android.bp files
Merging CL:
* http://go/wvgerrit/108203
* http://go/wvgerrit/103904 (changes to L3 source files excluded)

Also added ODK dependency which is required by L3 v16.
Do not replace constant sizeof() with a hard-coded value in L3 library because it is target-specific.

Test: Unit tests on gLinux
    jenkins/linux_unit_tests
    jenkins/ce_cdm_tests
Test: Unit tests on Pixel 4(flame-userdebug, rvc-qpr-dev)
    vendor/widevine/libwvdrmengine/build_and_run_all_unit_tests.sh
Test: Manual ExoPlayer L1/L3 playback tests (flame-userdebug)
    WV: Secure HD/SD (cenc,MP4,H264)
    WV: Secure HD/SD (cbc1,MP4,H264)
    WV: Secure HD/SD (cbcs,MP4,H264)
Test: Widevine GTS tests(bramble-userdebug, master)
    http://ab/I23800006571451275
Bug: 136317881
Bug: 139814713
Bug: 173331251
Change-Id: I1656e83a74a0eaf650f55f5e2388819bf5020c0d
2020-11-17 23:28:51 +00:00
Robert Shih
e7bac6e6a1 [automerger skipped] x86 L3: use correct struct size [ DO NOT MERGE ] am: 44aea963d0 am: 4e94dce40b -s ours
am skip reason: subject contains skip directive

Original change: https://googleplex-android-review.googlesource.com/c/platform/vendor/widevine/+/13061527

Change-Id: Ia99f6ff49bb481870af1bd2a373f7d38b37f92ce
2020-11-17 03:32:14 +00:00
Robert Shih
4e94dce40b x86 L3: use correct struct size [ DO NOT MERGE ] am: 44aea963d0
Original change: https://googleplex-android-review.googlesource.com/c/platform/vendor/widevine/+/13061527

Change-Id: I5556d22cebfb8f67ba5953444e712f4283c47aff
2020-11-17 03:15:10 +00:00
Robert Shih
44aea963d0 x86 L3: use correct struct size [ DO NOT MERGE ]
Bug: 139814713
Bug: 173331251
Test: GtsMediaTestCases
Change-Id: Ia2db4c1bd4e080a5c0ee4c7be742401494f251b9
2020-11-16 01:34:53 +00:00
android-build-team Robot
52241faa5c Snap for 6959988 from a8524e9199 to sc-release
Change-Id: I4cb96c89c75ac6841059901be1240cb90fa4aad7
2020-11-09 00:17:12 +00:00
android-build-team Robot
ecf140d5cd Snap for 6959183 from bbb3677d3c to sc-release
Change-Id: I1e3f2a36ae3b12eea777f2a55741244387a45f0b
2020-11-08 00:02:24 +00:00
Bill Rassieur
a8524e9199 Merge sc-d1-dev 6958804 into master.
Change-Id: Iee3e24dd0df718b2d6d25e42ab948662057fd80a
BUG:171916167
2020-11-07 19:14:17 +00:00
Edwin Wong
bbb3677d3c Merge "Build metrics_dump tool in Android." 2020-11-07 07:21:50 +00:00
android-build-team Robot
eaca6c49a3 Snap for 6955520 from 1a57d8179f to sc-release
Change-Id: I4d844529cd522d7c93cdcc7a43a37b1007921e45
2020-11-06 02:13:37 +00:00
Cong Lin
878495fd24 [automerger skipped] Upgrade L3 to v16 and update android makefiles [DO NOT MERGE] am: 2f08c48e94 am: 739ae08bb3 -s ours am: 1a57d8179f
Original change: https://googleplex-android-review.googlesource.com/c/platform/vendor/widevine/+/12868368

Change-Id: I3b75c7e34e8342bfd0a20abd88c6279152a8afe4
2020-11-05 02:51:25 +00:00
Cong Lin
1a57d8179f [automerger skipped] Upgrade L3 to v16 and update android makefiles [DO NOT MERGE] am: 2f08c48e94 am: 739ae08bb3 -s ours
am skip reason: subject contains skip directive

Original change: https://googleplex-android-review.googlesource.com/c/platform/vendor/widevine/+/12868368

Change-Id: Iaec55ceec6785e1f3282b0b877ef22f71e6135cf
2020-11-05 02:17:15 +00:00
Cong Lin
739ae08bb3 Upgrade L3 to v16 and update android makefiles [DO NOT MERGE] am: 2f08c48e94
Original change: https://googleplex-android-review.googlesource.com/c/platform/vendor/widevine/+/12868368

Change-Id: Iacd880e4efcb8bb15247407714b1f6f832b67e1a
2020-11-05 01:47:34 +00:00
Cong Lin
2f08c48e94 Upgrade L3 to v16 and update android makefiles [DO NOT MERGE]
Merging CL:
https://widevine-internal-review.googlesource.com/c/cdm/+/108203
and
https://widevine-internal-review.git.corp.google.com/c/cdm/+/103904 (changes to the L3 source files are excluded)

Generated L3 v16 for Android and added ODK dependency required by L3 v16.

Test: Unit tests on gLinux
    jenkins/linux_unit_tests
    jenkins/ce_cdm_tests
Test: Unit tests on Pixel 4(flame-userdebug, rvc-qpr-dev)
    vendor/widevine/libwvdrmengine/build_and_run_all_unit_tests.sh
Test: Manual ExoPlayer playback tests on Pixel 4(flame-userdebug) for L1 and L3
    WV: Secure HD/SD (cenc,MP4,H264)
    WV: Secure HD/SD (cbc1,MP4,H264)
    WV: Secure HD/SD (cbcs,MP4,H264)
Test: Widevine GTS tests(bramble-userdebug, rvc-qpr-dev)
    https://android-build.googleplex.com/builds/tests/view?invocationId=I35000006266076664&testResultId=TR45714199883476235
    (Note: the two failures are due to GTS/http issue and not related/specific to L3 and the change)
Bug: 136317881
Bug: 139814713
Change-Id: If3d4999ca3b725eab76c41588f202beec3873928
2020-11-04 18:53:04 +00:00
Alex Dale
d46eed4bb4 Updated usage table capacity property string.
[ Merge of http://go/wvgerrit/108143 ]

The CDM property string and MediaDrm property string for the usage
table capacity did not follow the same pattern used for matching all
other property strings.  This changes the CDM's version of the string
to match the MediaDRM version.  The property string mapper will
automatically be updated when the CDM is updated on Android.

The change in property string was tested on Android R using the
license request integration test.

Bug: 164493147
Test: Android integration test
Change-Id: I84d2e55a192b79738559cc6f71e54f3b1cd964fd
2020-11-04 10:32:54 -08:00
android-build-team Robot
d7da720884 Snap for 6950159 from ea2b3d3178 to sc-release
Change-Id: Ib669a04d1adaf3009ec7d2c34d531d474e061bac
2020-11-04 02:09:10 +00:00
Rahul Frias
63dfc73ea0 Sign fake license request if usage tables are not supported am: ea2b3d3178
Original change: https://googleplex-android-review.googlesource.com/c/platform/vendor/widevine/+/12967007

Change-Id: I9224c53533b83ac64904eaf8fd60e773a8864675
2020-11-03 21:01:47 +00:00
Rahul Frias
4a90728e38 Skip LicenseRenewalSpecifiedServer for local license server am: 95ff0f14fd
Original change: https://googleplex-android-review.googlesource.com/c/platform/vendor/widevine/+/12967004

Change-Id: I2d14047d74d13b118777f415c3ca0137a1cac559
2020-11-03 21:01:46 +00:00
Rahul Frias
9c36513f98 Merge changes I7cd424ae,I20f5d6a9 am: eee7a4edd7
Original change: https://googleplex-android-review.googlesource.com/c/platform/vendor/widevine/+/12967146

Change-Id: I0c31082a67f25478f85a5a495da8205c7084b6aa
2020-11-03 21:01:36 +00:00
Rahul Frias
ea2b3d3178 Sign fake license request if usage tables are not supported
Merge of http://go/wvgerrit/106823

Previously, we worked around a problem by signing a fake license
request when a license did not have a usage entry. However, this was
inside a conditional that the device did support usage tables. This CL
moves that code outside the conditional so that a fake license is
signed whenever the license does not have an entry.

Bug: 169591716
Test: unit and integration tests
Change-Id: Ic4d1a91af63503722b088a136c0a8dca9746a962
2020-11-03 20:12:34 +00:00
Rahul Frias
95ff0f14fd Skip LicenseRenewalSpecifiedServer for local license server
Merge of http://go/wvgerrit/105063

When running the local license server, the license does not contain a
URL for the renewal, or it is mangled. We only need to run this test
if we are running against UAT or UAT Nightly.

Bug: only found when debugging
Test: Ran tests with local license server
Change-Id: Ic84fcf9033b945a176119639a21104e4d42258a9
2020-11-03 20:12:17 +00:00
Rahul Frias
eee7a4edd7 Merge changes I7cd424ae,I20f5d6a9
* changes:
  Add Duration Use Case integration tests
  Add some policy integration tests
2020-11-03 20:11:23 +00:00
Edwin Wong
d5d0652d4f Build metrics_dump tool in Android.
Replace Makefile with Android.bp.
Remove duplication of protos in proto directory.

Since we are now building the metrics_dump tool
under Android, use frameworks metrics.proto
directly. Also, reference cdm's wv_metrics.proto
from the cdm directory instead of creating a
subset in proto directory.

bug: 161783052
bug: 170607430

Test: build
  m -j128 metrics_dump
Test: metrics_dump [bugreport from adt-3-r.zip]
Test: metrics_dump [bugreport from sabrina-q.gz]
Test: metrics_dump --widevine [adb shell dumpsys media.metrics output]
Change-Id: I82c7e723453ac2a6335cb2bb732a376d535b9ea3
2020-11-03 10:19:32 -08:00
Alex Dale
c23f6ac08c Merge "Include "origin" in license request client ID" am: cbb1d11a72
Original change: https://googleplex-android-review.googlesource.com/c/platform/vendor/widevine/+/12969258

Change-Id: I466e31c2a19e6d2e0da84154039360a70e418671
2020-11-03 01:42:39 +00:00
Rahul Frias
27a41b9ff1 Merge "Address test failures" am: 37be367712
Original change: https://googleplex-android-review.googlesource.com/c/platform/vendor/widevine/+/12403057

Change-Id: Idf87988d39055b9147114ad13adc578972e49c9b
2020-11-03 01:42:10 +00:00
TreeHugger Robot
74d0322a5d Merge "Avoid setting OEMCrypto_Algorithm enum vars with invalid values" am: 4447748573
Original change: https://googleplex-android-review.googlesource.com/c/platform/vendor/widevine/+/12626650

Change-Id: I2a59d90719110e979da24c067ee25d80c70c6190
2020-11-03 01:40:47 +00:00
Alex Dale
cbb1d11a72 Merge "Include "origin" in license request client ID" 2020-11-03 00:52:45 +00:00
Rahul Frias
37be367712 Merge "Address test failures" 2020-11-03 00:52:05 +00:00
TreeHugger Robot
4447748573 Merge "Avoid setting OEMCrypto_Algorithm enum vars with invalid values" 2020-11-03 00:49:11 +00:00
Rahul Frias
b1f54bbba8 Add Duration Use Case integration tests
Cherry pick from http://go/wvgerrit/102986, rvc-dev branch of
http://go/wvgerrit/105825, rvc-widevine-release of http://go/ag/12561661

This CL adds several integration tests that match the duration use
cases. The test classes are designed for the core cdm, but the test
cases match those found in oemcrypto/odk/test/odk_timer_test.cpp.

See this document for a list of use cases:
libwvdrmengine/docs/License_Duration_and_Renewal.pdf

Test: Ran the tests against v16 OEMCrypto. Some fail against v15.
Bug: 161463952
Change-Id: I7cd424ae241d3897fbd06956e87dd9da0752cb6d
2020-11-02 23:10:41 +00:00
Rahul Frias
d1dff772d3 Add some policy integration tests
Cherry-pick from branch rvc-dev of http://go/wvgerrit/105824 and
rvc-widevine-release http://go/ag/12561660

This adds two policy integration tests to verify that we are handling offline
licenses correctly.

Bug: 161023174
Bug: 129301787
Test: WV unit/integration tests
Change-Id: I20f5d6a9fbfd2ff8cff361e1005e45b46c700704
2020-11-02 00:44:02 -08:00
android-build-team Robot
13e660dacc Snap for 6940725 from 712784055b to sc-release
Change-Id: I97e3e589b79c72ed675cf80d5fff087d300fb869
2020-10-30 01:01:36 +00:00
TreeHugger Robot
440fa8e164 Merge "Fix OpenSSL Builds" am: 712784055b
Original change: https://googleplex-android-review.googlesource.com/c/platform/vendor/widevine/+/12905382

Change-Id: Ie4bcf32c77bf2963edee97d375fcde28e46f460f
2020-10-29 01:23:34 +00:00
Alex Dale
4028784836 Include "origin" in license request client ID
[ Merge of http://go/wvgerrit/108823 ]

Android CDM will include the session origin in the client info
component of the client ID of a license request.

The "origin" is only to be included on Android CDM, and not the CE
CDM.  The origin is provided to the license request via the app
parameters in the WVDrmPlugin.

A separate GTS test is in development and will be submitted to the
Android media GTS test set.

Bug: 164549928
Test: Manual test and GTS test
Change-Id: I67f8b064b2aefdc08328ea14551d4aa4cb57023d
2020-10-28 17:29:18 -07:00
TreeHugger Robot
712784055b Merge "Fix OpenSSL Builds" 2020-10-28 21:47:37 +00:00
android-build-team Robot
4d51a7fea1 Snap for 6935143 from 43f6d79ffa to sc-release
Change-Id: I898728e23de7c603fe337264995e1e914eb8c927
2020-10-28 01:03:58 +00:00
Rahul Frias
42ecc6404b Address test failures
[ Merge of http://go/wvgerrit/104584 ]

This corrects failures in
* WVDrmPluginTest.ReturnsL3SpoidsWhenL3ProvisionedUsingL3Spoid
* WVDrmPluginTest.ReturnsL3SpoidsWhenL3Unprovisioned
* WVDrmPluginTest.ReturnsL1SpoidsWhenL3ProvisionedUsingL1Spoid

and a warning in
* PolicyEngineTest.PlaybackOk_RentalAndLicense0_WithPlaybackBeforeLicense_V15

Bug: 163542905
Test: WVDrmPluginTest and PolicyEngineTest
Change-Id: I3e7799175b7b289fafd2caf88bd5df4123b88973
2020-10-27 02:23:59 -07:00
android-build-team Robot
d3ca5cb17d Snap for 6931861 from fa9ce28dd3 to sc-release
Change-Id: Ie051e346472d5e66b4c24237c3c6c82db711d915
2020-10-27 01:15:30 +00:00
Baligh Uddin
9415e9a70c [automerger skipped] Cleanup references to system/core/base -> system/libbase am: 673ca3c689 am: 2ccfaeac56 -s ours am: 43f6d79ffa -s ours
am skip reason: Change-Id I3412348b28b56b13702af14ce77238fac506efdd with SHA-1 fa9ce28dd3 is in history

Original change: https://googleplex-android-review.googlesource.com/c/platform/vendor/widevine/+/12917865

Change-Id: I2bd2b7440b227903e685cd3ecef17ed9a5c94a14
2020-10-26 23:42:34 +00:00
Baligh Uddin
43f6d79ffa [automerger skipped] Cleanup references to system/core/base -> system/libbase am: 673ca3c689 am: 2ccfaeac56 -s ours
am skip reason: Change-Id I3412348b28b56b13702af14ce77238fac506efdd with SHA-1 fa9ce28dd3 is in history

Original change: https://googleplex-android-review.googlesource.com/c/platform/vendor/widevine/+/12917865

Change-Id: Iada7de0093fff3dd77571fd6029a1c6de9e58be9
2020-10-26 23:25:27 +00:00