So, Iā€™ve dug up my corebooted t440p and decided to check if itā€™ll work with the battery from my t480, and it did! Well, sort of.

Since coreboot also replaces the embedded controller firmware (mb sometimes they keep blobs of it, idk, but certainly not in case of t440p), we wonā€™t get those nasty ā€œbattery not supported, pay meā€ messages even if theyā€™ve changed the verification since then.

However, I suspect some batteries may be unprepared for the power draw of earlier models. Iā€™ve tested it on 2 batteries, one was a 22wh ā†’ 72wh conversion with BMS built on top of a cheap controller with rather unpleasant feedback from battery repair people; the other one was a more trustworthy 72wh clone powered by bq8050. The latter one worked ootb, while the former somewhat worked: fine in uefi, fine in grub, drop voltage to 0 as soon as the os starts loading ā†’ poweroff. If the power supply is plugged in during boot, the battery works fine (may drop voltage again under load, havenā€™t tested it myself).

Soo, basically the use case is that you can try to retrofit the guts of a newer battery into older thinkpads if those run core/libreboot.

You are viewing a single thread.
View all comments
2 points

Iā€™m curious, how did you build the BMS with a cheap controller? I wonā€™t judge. Iā€™ve always wanted to build my own battery pack that reports percentage back to the machine, without worrying about killing the BMS if it loses power.

permalink
report
reply
2 points

I didnā€™t build it, although Iā€™ve been entertaining the idea for quite a while. I just happened to have 2 dead batteries, one 72wh with a locked controller (2 parallel cells simply fell off due to bad spot welding) that I later bricked while trying to unlock, and a 22wh with one of the packs dead. So, after fixing the welding (tbh Iā€™ve just soldered those cells since I didnā€™t have a spot welder myself at the time) I just swapped out the working controller with the locked one. T480 doesnā€™t seem to mind, so whatever. Although I eventually decided to set the charge threshold at ~90% since it seemed to me the BMS overcharges the batteries

As for building, thereā€™s this beauty (also thereā€™s a hackaday article about it; includes a link to the blog post outlining how it was done) for t420 which seems to include a PoC-ish smbus implementation for an attiny, as weā€™ll as a prototype based on bq3060. Verification may be a problem, tho, if the board runs on EC firmware from lenovo (also, Iā€™ve been looking at coreboot docs for x230 today, and yap, they sometimes do keep blobs with EC firmware, although there were tutorials on patching it to remove the verification). Also, if you happen to have a battery based on bq8030 ic, this blogpost has a disassembler for its firmware, which makes it possible to more or less see how the battery side of verification is done and implement it some other way. Dumping the firmware is also quite simple using theese scripts (tested on the second battery mentioned in the post)

permalink
report
parent
reply

ThinkPad

!thinkpad@lemmy.ml

Create post

IBM and Lenovo ThinkPad laptop enthusiasts!

Community stats

  • 3

    Monthly active users

  • 59

    Posts

  • 75

    Comments

Community moderators