Upgrade Pixel XL to LineageOS 17.1 (Android 10)

LineageOS recently pushed official 17.1 images for my phone, the Pixel XL (marlin). I’d been stalling a little bit in the upgrade as the only path is a manual and I was concerned I was going to lose all of my application state.

I finally took the plunge, in part I was keen to move to the new Android 10 features – and LineageOS has also stopped their 16.0 builds, and this means you won’t get new security patch levels.

It turns out that while you need to take some manual steps, the upgrade path was very smooth. Still, here are the steps I took:

(1) Backup

  • I already make use of SimpleSSHD to support nightly SSH based backups.
  • Export settings from various apps: k9mail, feedme, etc. that are not backed by cloud services.
  • Run SMS Backup+ to archive all my SMS to my gmail account.

Usually I run TWRP recovery, but LineageOS has moved to their own recovery. Unfortunately the LineageOS recovery doesn’t support Nandroid backups. You can however still use adb backup.

To perform an adb backup, have the phone running as normal. Enable both developer options, and then allow adb (debugging) and adb root access. To do the backup we need to let adb connect, and have root access to access the files.

On your desktop machine:

Your phone will prompt you for confirmation of the backup process. Once it starts to run, it’ll take a while (mine was 8GB over USB2).

Additionally I manually copied the backup files (exported settings) I had made.

(2) Download the ROM

Grab the 17.1 marlin ROM from LineageOS. I also run the Google stuff, so also go to OpenGApps to get that. I initially picked ‘stock’ because I though, hey the Pixel is as Google a phone as you might get. The list of stock apps is pretty close to what I have installed anyways – despite the fact that my current gapps is the nano version.

Once I upgrade my phone to a later version of the hardware, I’ll probably stick with the Pixel line. LineageOS isn’t officially supported on the more recent hardware, but the delta between LineageOS and Google stock has become pretty slim too. I may finally give up on custom firmware and run stock, we’ll have to see.

[If you read on, you’ll note that I ended up falling back to the nano pico gapps build.  Oh well]

(3) Check hashes of all downloads

Always check the hashes. I’ve personally had bad downloads. You don’t want a bad file to cause you additional grief, it’s easy to check.

(4) Upgrade

We can follow the LineageOS upgrade wiki to do the install.

My device did reboot to a blank screen, but once I started the next command – I got a visual progress display. It is possible I just didn’t wait long enough, but either way things started up just fine.

If you are as I am, intending to install the Google apps, then you want to avoid booting into normal mode.

On the phone in recovery once it has finished the sideload

  • Click Advanced
  • Reboot to Recovery
  • Once recovery start again..
  • Click Apply Update
  • Apply from ADB

Now we sideload gapps:

Note: It does appear that I got a new recovery as part of the lineage install.

Here is where I ran into trouble with the stock version of gapps. While the source file did match the md5sum, the phone install was giving me a signature verification failure – at 47%.

oh oh.. 1st try to install the (md5sum verified) gapps.. and I get a signature verification failure.. but at 47% progress.. hmm. It turns out that other people have had exactly this problem.

The 47% appears to be a side effect of the sideload process. I banged my head on this a few times, until I carefully read what was actually being reported on the phone screen when the verification failed.

Not enough system space to install the stock gapps. Sigh, how many times have I struggled with getting a computer to do something when the problem was that I didn’t carefully read the error message.

Downloading and installing the nano pico version worked fine, but my notes say that I still saw the signature verification failure (this may be due to the gapps approach to building the bundle).

(5) Reboot

And wait, and wait, and wait.. The first boot is always exciting and takes enough extra time you start to worry something is wrong.

And.. it’s alive! All my apps/data are still “ok”. This is unexpected, I had prepared myself to do a full rebuild of things, but it seems that this upgrade path allows my applications and their state to persist.

There were some minor configuration difference (launcher UI settings reset.. to 5×5 instead of 5×6 which I prefer). This was easy to fix and my layout was fully restored.

A bunch of permission checks popping up too, still overall a mostly painless upgrade to Android 10. Lots of settings persisted, like my mobile data per app preferences. Ringtones and sounds were busted, because the LineageOS sounds have been replaced by the Pixel ones.

(6) Epilogue

It’s been over a week, and no big surprises (which is good).

The whole Privacy stuff is great. I always liked Privacy Guard in LineageOS and now that similar function added to Android itself, I’m ok with letting that go. I’m a bit disappointed with the stock sounds available, I may just need to go add the old LineageOS sounds as user sounds so I can get the ones I’m used to.

2 thoughts on “Upgrade Pixel XL to LineageOS 17.1 (Android 10)”

  1. I managed to get to the July 1st, 2020 update – but attempts to let the normal update process move forwards after that ended up in a corrupted state.

    I was fortunately able to (sort of) recover by flipping to the ‘other’ fastboot partition, but many of the Google apps from the Play Store were busted (delete, re-install helped).

    Still, I bit the bullet and did the backup dance, and have done a clean install of the latest 17.1 – hopefully this will result in a stable phone. The battery life of my XL is starting to be pretty short too (I hope this is a software issue, but..) – so I may be moving off this device soon enough.

    Annoying to do a clean re-install, as some apps don’t have any sensible backup story. Oh well. I have backups of the important stuff anyways.

  2. Ugh, burned by an update again. — but I did a smarter thing and search on XDA for the right forum post https://forum.xda-developers.com/pixel-xl/development/rom-lineage-17-0-pixels-marlin-sailfish-t3971039 and skimmed through the recent posts.

    My problem was that the ROM worked fine, but the Android Navigation buttons were gone (the triangle, dot, square at the bottom of the screen). You’d think maybe those navigation buttons were not all that useful – but it’s like trying to type without a space bar. You can make it work, but it’s super painful – not the smartphone experience you want.

    The answer seemed to be here: https://forum.xda-developers.com/showpost.php?p=83175059&postcount=908 – Use the pico open_gapps, not the nano one.

    I did a “dirty flash” and installed the latest LineageOS build ontop of itself using recovery and adb sideload, then rebooted from recovery back into recovery to install the pico gapps. Yup, my navigation buttons came back — and I think I’m ok. I’ll have to look around for the missing google apps.

    From: https://github.com/opengapps/opengapps/wiki/Package-Comparison – it looks like I’m missing

    – Sounds
    – Device Health Services
    – Google Markup
    – Google App (Search)
    – Offline Speech Files
    – Google Digital Wellbeing

    Oh well, I have my navigation buttons back. I’m going to update the original post to indicate Pico is the right one.

Leave a Reply

Your email address will not be published. Required fields are marked *