6

A script that fetches a ChromeOS image for ARM32 and extracts the Widevine binar...

 2 years ago
source link: https://gist.github.com/ruario/19a28d98d29d34ec9b184c42e5f8bf29
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.
neoserver,ios ssh client

A script that fetches a ChromeOS image for ARM32 and extracts the Widevine binary, saving it in a compressed archive for use with Vivaldi · GitHub

Instantly share code, notes, and snippets.

A script that fetches a ChromeOS image for ARM32 and extracts the Widevine binary, saving it in a compressed archive for use with Vivaldi

The included script 'widevine-flash_armhf.sh' fetches a ChromeOS image for ARM and extracts the Widevine binary, saving it in a compressed archive. Since it downloads a fairly large file (2Gb+ on disk after download) it is recommended that you run the script on a machine that has plenty of disk space.

To install the resultant archive, issue the following on your ARM machine–after copying over the archive if needed:

sudo tar Cfx / widevine-flash-20200124_armhf.tgz

(Where 'widevine-flash-20200124_armhf.tgz' is updated to reflect the actual name of the created archive)

After install of these libraries, issue the following two commands and restart Vivaldi–assumes bash as your shell:

mkdir -p ~/.config/vivaldi{,-snapshot}/WidevineCdm
echo '{"Path":"/opt/WidevineCdm"}' | tee ~/.config/vivaldi/WidevineCdm/latest-component-updated-widevine-cdm > ~/.config/vivaldi-snapshot/WidevineCdm/latest-component-updated-widevine-cdm

(Triple click to select each complete line above)


This created package is designed to work on Vivaldi 2.10 (not pure Chromium 79+, which would require patches to detect Widevine on ARM).

I tried to run it and got this: gzip: stdout: No space left on device

Thanks for the hard work!

The above works with AT&T now, on a raspberry pi 3b+ with minor stuttering at some time, probably just need tta few tweaks.

Thanks for this.

I registered just to say thank you for the work you put into this. Thanks to you I am now able to listen to Spotify on a Raspberry Pi using the Vivaldi browser. I appreciate your time and effort!

what does this statement mean : " not pure Chromium 79+, which would require patches to detect Widevine on ARM "
What are those patches ?

I am trying to get it to work within an arm32 docker container with chromium version 85+ and it does not detect the libwidevincdm

I've just tested this successfully with the latest Raspberry Pi OS (2020-08-20) and latest Vivaldi (3.3). Thank you very much! +1

Edit:

Actually you don't need Vivaldi and can use Chromium. You just have to copy the libwidevinecdm.so file from the TGZ to the following folder on your Pi: /usr/lib/chromium-browser/

cmon, the script runs, but it uses the WRONG partition/folder which is §$&§$&§$& too small for that ~ 1 GiB... on my emmc card not much space left.
i have enough external drives which fit that download thousand times but the heck just aims for the real wrong turn. stdout folder plz noot

Is there a way to add some lines to force to use my favourite work folder (not using root dir) especially on an external drive /media/usr/whateverilike)?
-Not STDOUT

Thanks guys and girls.

I've just tested this successfully in Vivaldi with the latest Raspberry Pi OS (2020-11-05) and latest Vivaldi (3.4). I run the script, but got errors related to loop devices, and it opened them in folders, but when I run it the second time it worked but then stopped, but when I closed the folders it finished.

I could not get it to work in Chromium by hard linking libwidevinecdm.so to /usr/lib/chromium-browser/.

I tested as well today with Vivaldi 3.4.2066.94 and Widevine 4.10.1679.0 on a Rpi 4. Lib is loaded and DRM passes the test but Netflix deny the access with this stupid error.
As mentioned above, it's cause by the User Agent. The User Agent Switcher extension in Chrome Store are not working properly (they must be very badly coded, this is just a HTTP header facepalm)
Switching the user agent from the CLI is simpler and working fine :

vivaldi-stable %U --user-agent="Mozilla/5.0 (X11; CrOS armv7l 12371.89.0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.120 Safari/537.36"

Hi, thanks for the script!
Unfortunatly it does not work with Vivaldi 3.4.2066.106 and Widevine 4.10.1679.0 on my OPi+ with Armbian 20.08.17 Buster.
I used widevine-flash_armhf.sh script to extract libwidevinecdm.so.
Bitmovin DRM test is not passing and vivaldi://components says Version 0.0.0.0.
Is there any chance to fix this for my system?

iisti

commented

Apr 4, 2021

edited

Thank you very much for the script! I bought Raspberry for creating a silent media center, but was disappointed when Netflix didn't work. With the script I got it working. I did some work to get the script working with the newest versions.

  • Using:
    • Raspberry Pi 4B, 8GB
    • OS image: 2021-03-04-raspios-buster-armhf-full.zip
    • Vivaldi version: vivaldi-stable_3.7.2218.52-1_armhf.deb

Flash player is obsolete

  • Running the script gives error about Flash player:
    pi@raspberrypi:~/widevinecdm $ ./widevine-flash_armhf.sh
    --2021-04-03 18:42:38--  https://dl.google.com/dl/edgedl/chromeos/recovery/chromeos_13729.56.0_elm_recovery_stable-channel_mp-v2.bin.zip
    Resolving dl.google.com (dl.google.com)... 172.217.23.206, 2a00:1450:4014:80c::200e
    Connecting to dl.google.com (dl.google.com)|172.217.23.206|:443... connected.
    HTTP request sent, awaiting response... 200 OK
    Length: 1039156004 (991M) [application/zip]
    Saving to: ‘STDOUT’
    
    -                             100%[==============================================>] 991.02M  2.62MB/s    in 7m 14s
    
    2021-04-03 18:49:52 (2.28 MB/s) - written to stdout [1039156004/1039156004]
    
    Mapped file /tmp/ChromeOS-IMG.q2VV12/chromeos_13729.56.0_elm_recovery_stable-channel_mp-v2.bin as /dev/loop0.
    install: cannot stat '/media/pi/ROOT-A/opt/google/chrome/pepper/libpepflashplayer.so': No such file or directory
    
  • I think the Flash player has been removed completely from ChromeOS, so the error is not a surprise. Source: https://www.chromium.org/flash-roadmap
  • Fixed the script by:
    # Remove line
    install -Dm644 "$MNTPNT"/opt/google/chrome/pepper/libpepflashplayer.so "$CHRFILES"/opt/google/chrome/PepperFlash/libpepflashplayer.so
    
    # Remove Flash file from line:
    tar -C"$CHRFILES" -caf "$ARCHIVE_NAME" opt/WidevineCdm/manifest.json opt/WidevineCdm/_platform_specific/linux_arm/libwidevinecdm.so opt/google/chrome/PepperFlash/libpepflashplayer.so --format ustar --owner 0 --group 0
    # Line after modification
    tar -C"$CHRFILES" -caf "$ARCHIVE_NAME" opt/WidevineCdm/manifest.json opt/WidevineCdm/_platform_specific/linux_arm/libwidevinecdm.so --format ustar --owner 0 --group 0
    

Links are not pointing to correct places

  • The Vivaldi 3.7 is pointing to /opt/google/chrome/WidevineCdm, but the script puts the files into /opt/WidevineCdm.
    • Fixed broken links by:
      cd /opt/vivaldi
      sudo rm WidevineCdm
      sudo ln -s /opt/WidevineCdm WidevineCdm
      
      • After restart Vivaldi should show in vivaldi://components
        Widevine Content Decryption Module - Version: 4.10.1679.0
        Status - Up-to-date
        

Netflix

Chromium

  • The Widewine files work also with Chromium, and the Netflix videos seem to run smoother (better hardware acceleration?).
    cd /usr/lib/chromium-browser
    sudo ln -s /opt/WidevineCdm WidevineCdm
    

@iisti I'm glad someone came up behind the original man and cleaned up the script. I was coming down here to do the same thing you did. But you beat by a month or 2. Thanks for posting this. I guess it would be wise to actually inform Vivaldi of this so they can do something about it.

Author

@iisti Thanks! Sorry I meant to updater this long ago and in my mind I kind of thought I had but it seems not. Anyway, it is fixed now.

Like a comment above I tried this on a pinebook pro and got (gzip: stdout: No space left on device)

Author

@waddon1 Because you have no space left on disk. The ChromeOS image is 2Gb+ unpacked. That is what I stated above

Since it downloads a fairly large file (2Gb+ on disk after download) it is recommended that you run the script on a machine that has plenty of disk space.

I you can create the archive on another machine and then copy it over.

@ruario I have around 45Gb free

Author

@waddon1 On your /tmp partition?

@ruario Sorry I'm a noob at Linux didn't realise /tmp used separate storage to the rest of the filesystem

Author

@waddon1 it may or may not. It depends on how you are setup. I am largely guessing that this might be issue given the error message you received and knowing that /tmp could be mounted separately.

@ruario Apparently it does on my system, as it says /tmp has 0 free storage space even though the /tmp folder is in the same partition as root which has 45gb free. I'll leave you alone now and fix it myself.

Author

Define the variable TMPDIR to another location e.g. TMPDIR=$HOME/Downloads before running the script (or add that to the second line of the script itself) and you should be OK.

Author

@waddon1 the above was to you

First of all, I'd like to thank all of you who are contributing to this thread. It's been very promising so far.

@iisti I've been following the instructions here with your big update, but Vivaldi seems to crash every time with that Widevine configuration. I've tried both 5.0 and 3.4. And they both don't seem to work. Also, the symbolic link for chromium don't seem to do anything neither. Because I simply don't see Widevine under chrome://component. My best guess is that they might have changed something in that libwinevine.so, but I could be wrong.

@shinkou just a thought... Have you tried using Microsoft Edge? I'm not sure if it has widevine support or not. But I will say that widevine is definitely supported on armhf and arm64. The lineage os builds for the rpis have them built in.

Exceen

commented

Apr 6, 2022

edited

How can I remove this? Especially the big files? I installed it on accident on a wrong Raspberry Pi of mine. I only find files that take a few megabytes, those aren't the issue. But the README states something about 2Gb+ files and I can't find these.

/widevine-flash_armhf.sh 23:32:58
--2022-10-19 23:33:05-- https://dl.google.com/dl/edgedl/chromeos/recovery/chromeos_14989.107.0_elm_recovery_stable-channel_mp-v2.bin.zip
CA certificate ("/etc/ssl/certs/ca-certificates.crt") loaded
Unlocking dl.google.com (dl.google.com)… 2a00:1450:400d:80a::200e, 142.250.201.206
Connecting to dl.google.com (dl.google.com)[2a00:1450:400d:80a::200e]:443… connected.
HTTP request sent, waiting for response... 200 OK
Length: 1290184868 (1.2G) [application/zip]
Save to "STDOUT"

  • 100%[============================================== ========>] 1.20G 13.5MB/s time 65s

2022-10-19 23:34:11 (18.9 MB/s) -- written to stdout [1290184868/1290184868]

Mapped file /tmp/ChromeOS-IMG.1mWSXd/chromeos_14989.107.0_elm_recovery_stable-channel_mp-v2.bin as /dev/loop2.
Mounted /dev/loop2p3 at /run/media/gyurmo/ROOT-A
install: stat '/run/media/gyurmo/ROOT-A/opt/google/chrome/libwidevinecdm.so' failed: No such file or directory

Yup, it appears that this file has moved.

I could get it to work by changing :

install -Dm644 "$MNTPNT"/opt/google/chrome/libwidevinecdm.so "$CHRFILES"/opt/WidevineCdm/_platform_specific/linux_arm/libwidevinecdm.so
install -Dm644 "$MNTPNT"/opt/google/chrome/WidevineCdm/_platform_specific/cros_arm/libwidevinecdm.so "$CHRFILES"/opt/WidevineCdm/_platform_specific/linux_arm/libwidevinecdm.so

You will also want to adjust the links as discussed by @iisti above.

on line ~56.

Anyone would have a suggestion for flash?

I am trying to get tidal's web player to work and, now that Widevine is working, I think it's flash that is preventing this site from working properly.

ChromeOS ARM64 userspace has hit the beta channel for some boards
https://groups.google.com/a/chromium.org/g/chromium-os-dev/c/GdZ0mebutXw

I am posting this here for greater visibility. If anyone has a trogdor based chromebook, the beta for chromeOS should be using an ARM64 userspace RIGHT NOW.

Recovery images are not available for this and probably won't be for a few more months until it hits stable. If anyone here sees this and has a trogdor based chromebook please use the beta channel and check for an arm64 widevine module.

trogdor may not be the only device with ARM64 userspace on the beta. cherry, corsola, jacuzzi, and kevin also have ARM64 userspace preparred in the CI but its not be confirmed whether or not these devices are using ARM64 userspace now or not.

The Image contains arm64 widevine, it can be extracted using the ota unpacker.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment


Recommend

About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK