As someone who worked on kindle power consumption many years ago: One of the (by far) biggest consumers of power is the WiFi connection. It has to wake up and respond to the AP in order to not get disconnected every x seconds.<p>Off the top of my head, I think 'on' average power consumption was ~700uA without wifi, and about 1.5mA+/- with Wifi. This is from over a decade ago, so my memory is fuzzy though...<p>Obviously, page changes used relatively large amounts of power. I don't recall the exact amounts, but it was 100s of mA for seconds.<p>There is also an "every x pages, do a full screen refresh (black to white)" to fix up the ghosting issue that the article writer saw.
I removed the battery on mine, kept the battery chip and fed 5V into the battery terminals, from Kindle's USB connector, through a diode (so 4.4V-ish). Without a battery it needs something that can deliver at least 1.5A, for short bursts. An older powered usb hub seems to work fine, hub is connected to my raspberry pi, and I use ssh through usb networking, no wifi, no battery, worked fine for months now.
Awesome tips. I'll try increasing the refresh interval to 2 minutes and turning off the wifi in between refreshes to see if helps with battery life.<p>Side note this also finally explains to me why battery life on the Kindle is SO good in airplane mode.
Yeah you'll probably want to turn on airplane mode between the refreshes. That's at least what KUAL "Online screensaver extension" from Mobiread forums does, with it I'm getting several weeks of battery life with refreshes every couple of hours.
Could you adjust the refresh frequency based on your usage patterns? So refreshing less frequently outside your main transit times. An extension of your current pause at night.
wonder if small amorphous silicon photovoltaic cells glued around the kindle would provide enough power to not charge every 5 days
I took an even simpler route. After jailbreak and ssh I just made two scripts on the Kindle, one is triggered every minute, the other every half hour. Both draw the same image from the same location, the 30 minute one just adds a full refresh. This way the display is not fully refreshed every minute, but in time image is degrading so full refresh once every 30 minutes seems work out fine.<p>This way Kindle has a very simple job, no apps installed no anything, just two extra cronjobs to run the oneliner bash scripts that draw the image. And I use rsync from a raspberry pi to push a new image every minute. That image is assembled with a python script, rpi side, with air quality data. Connects to local mysql server, pulls the values and then assembles it.
> <i>even simpler route</i> ... <i>rsync from a raspberry pi</i> ... <i>python script</i> ... <i>air quality data</i> ... <i>local mysql server</i><p>I smiled
I took an even simpler route.<p>I Jailbroke my Kindle so I can read epubs on the bus and I just ask Siri when the next bus is comming.
There's something very satisfying about solving the whole problem with a couple of scripts instead of building a full framework around it
A pretty dumb eInk display that could do one thing, that is, receive and blit a bitmap at a given location, would suffice for great many uses. It only needs a way to connect to wifi or zigbee securely, e.g. using TLS.
This is sort of related to a revelation I had once I got into Home Assistant.<p>The usual idea is a that a smart home becomes filled with smart devices and yet what worked really well for me was having <i>dumb</i> devices with a very smart brain in the middle.<p>Buttons, switches, lamps, and sensors are commodify Zigbee devices and the entirety of the logic and programming is done on the Home Assistant server. The downside is latency.
Usually you can bind ZigBee devices together. I have multiple IKEA "rodret" switches bound to generic ZigBee smart plugs from Aliexpress. Works great, with minimal latency.<p>With zha, you can bind them together from the Home Assistant device page.<p>I usually favor an architecture that can work without Home Assistant, such as standalone ZigBee dimmers, or contactors that can work with existing wiring. Home Assistant brings automation on top, but it doesn't matter much if it breaks (I mostly notice the shutters not opening with sunrise). Then Internet connectivity can bring additional features, but most things still work if it's down.<p>I'd say it has been pretty solid for years, and I don't stress too much when I have server issues.
Such devices exist are are expensive, more so than e-readers.
Everybody seems to do stuff like this nowadays. Myslef included. I did have old K4NT lying around and started playing with it. With a little bit of help of AI (not for jailbreaking though! - lots of nonsense) I was able to put up little server, which now serves family calnedar agenda, but it is designed to be modular and I will put more stuff to it later. I've even designed and 3D printed insert into Ikea 12x18 frame and put a small "blade" powerbank with MagSafe to the back, so now I need to push powerbank button every 5 days. Internal battery is in a bad shape now, but I saw I can still buy an replacement. Wired version was not an option in my case.
Kindles are fun devices to hack and play with. I can grab an old kindle for €15-20 on eBay.<p>I did the same last year and had lots of fun in the process.<p><a href="https://samkhawase.com/blog/hacking-kindle/" rel="nofollow">https://samkhawase.com/blog/hacking-kindle/</a>
There is also the Xteink4[0] that can be purchased on Aliexpress. It's just an ESP32 with an e-ink screen.<p>It costs more and is smaller but when you are done playing around with it you can flash it with Crosspoint[1], carry it in your pocket and read books on an e-ink display wherever you are.<p>[0] - <a href="https://www.youtube.com/watch?v=yMoq17-1pJA" rel="nofollow">https://www.youtube.com/watch?v=yMoq17-1pJA</a>
[1] - <a href="https://github.com/crosspoint-reader/crosspoint-reader" rel="nofollow">https://github.com/crosspoint-reader/crosspoint-reader</a>
For the less reverse-engineering prone among us, there are also similarly sized e-ink displays that plug into Raspberry Pi DSI ports for maybe $5 more on Aliexpress. They might actually be salvaged kindle screens.
I love it! Always fun to see the route somebody else took to get to the same end product.<p>Your post is making me want to try more Cloudflare Developer Platform stuff like Cloudflare Workers.
Can you start jailbreaking straight away, or does it require an internet connection and Amazon account first during setup?
I don't believe you need internet connection - IRRC jailbreaking steps were plug in the Kindle, drop the jailbreak folder into the root directory, then choose `Update` from the Settings screen.<p>The hardest part was finding the `Update` menu item. It's only visible if you go to Settings, then press the menu button again while on the Settings page.<p>Not sure if registering the Kindle was required.
Depends on the firmware of the device. Latest firmware (anything after version 5.18.5.01 - which released in October 2025) is currently not jailbreakable.<p>Jailbreak of any firmware after version 5.16.2.1.1 (June 2023) requires the Kindle to be connected and registered.<p>Anything prior to, and including this version, can be jailbroken with no registration.
Don’t connect it. I bought one for this purpose and it updated to a version that didn’t have a known jailbreak
Real nice! Shutting down networking between refreshes definitely helps with the battery life. I also prevent mine [1] from updating between 10PM and 6AM. Nobody is looking at it anyway. If you search around on Github for Kindle dashboards, there's a lot of scripts out there with a bunch of battery life improvements (shutting down daemons, wifi etc.).<p>I built GTFS based public transit display on top of a Raspberry Pi Zero and a 2" e-ink display ~10 years ago [2].<p>[1] <a href="https://franz.hamburg/writing/kindling-e-ink-dashboard.html" rel="nofollow">https://franz.hamburg/writing/kindling-e-ink-dashboard.html</a><p>[2] <a href="https://github.com/Scarysize/transit-pi" rel="nofollow">https://github.com/Scarysize/transit-pi</a>
These days digital shelf labels look like a really cheap option; lots of them look like they require a proprietary base station, but there are some out there with BLE/NFC - have been meaning to get one to try.<p>Of course, if you have an old kindle about, reusing it is a great way to avoid waste.
For some reason, this project reminds me of this one:<p><a href="https://engineersneedart.com/systemsix/systemsix.html" rel="nofollow">https://engineersneedart.com/systemsix/systemsix.html</a>
Old kindles are a lot of fun. I've turned a couple of them into AI generated paintings that refresh their contents every few hours or so. I can control the prompts via web-ui, through template functions they can include things like weather conditions, random animals, countries, current date & time and even titles of random news articles. Prompt handling and image generation is done completely locally on my home server, using ollama and stable-diffusion-webui.<p>The only problem I've had is that most news articles from mainstream media are damn depressing, so generating paintings directly from them gets gloomy quick. I had to instruct ollama to try put a positive spin on negative articles. I do love my weather-forecast painting though. Whenever it's raining outside, the painting has rain in it too (or now during winter it's all snowy).<p>Battery life is really good too, lasts several weeks. I used existing "Online Screensaver extension" from MobileRead forums, with some customizations. It automatically turns on airplane mode after fetching the image and keeps it on until next fetch, which probably explains the improved battery life.
In Queensland, Australia we have solar powered e-paper displays [1][2] at some bus stops that are very similar to this (much bigger than a kindle screen, though).<p>[1] <a href="https://translink.com.au/about-translink/projects-and-initiatives#1650391" rel="nofollow">https://translink.com.au/about-translink/projects-and-initia...</a><p>[2] <a href="https://www.facebook.com/TranslinkQLD/videos/e-paper-trial-hits-the-network/358000585318364/" rel="nofollow">https://www.facebook.com/TranslinkQLD/videos/e-paper-trial-h...</a>
I love using Kindle's as single purpose tablet/interfaces/displays. I'm the weirdo who actually prefers the LCD displays vs eInk and it's incredibly easy to set Kindle Fire's into dev mode which lets you display a webpage, never turn off while connected to power and never show ads.<p>You can regularly find the Kindle Fire HD10s for ~$40
A while ago I've rewritten TRMNL's Kindle-client from Bash into Lua, optimised it a bit and when doing a refresh every 5 minutes, my Kindle Paperwhite 10th gen now lasts about 5-6 days on a charge.<p><a href="https://github.com/mbirth/trmnl-kindle/tree/lua-rewrite" rel="nofollow">https://github.com/mbirth/trmnl-kindle/tree/lua-rewrite</a>
Makes me wonder why there isn't a whole category of "public display-friendly" e-ink devices with first-class APIs...
I was glad to see the note about battery life down at the bottom. My biggest challenge with the old Kindles I have laying around is that most of them won't hold a charge!
I haven't developed on the Kindle ecosystem, but with old Nook devices I am able to set a screensaver, alarm, and put the device into deep sleep between refreshes. This changed my battery life from ~48 hours into 30+ days of battery life even with some old devices.<p>The "electric sign" app does this, which is where I referenced the code.<p>With trmnl, the image only refreshes every 10 mins so the device will set a ~9 minute alarm to wake the device right before it needs to load the next update.<p>The refresh period is also configurable so a slower refresh interval (e.g. every hour for less time-sensitive screens) yields larger battery savings
I removed the battery but kept the I2C chip/pcb, and fed 5V from USB port via a diode, on the PCB battery connections, seems to work fine. I actually installed a single wire from USB VCC to diode then + battery terminal. But you need to power the Kindle from something that can deliver at least 1.5A for startup peaks. A USB hub does the job fine in my case, and also connects it to a raspberry pi for ssh through USB networking, so no wifi either. Use a good USB cable for power.
Yeah that was definitely a worry of mine before I booted it up. Luckily it's still got decent battery life. We'll see how it holds up in 6 months...<p>Dyson vacuums and Kindles are not the same whatsoever, but I wonder how easily it'd be to swap out the battery on an older Kindle. For our vacuum, all I needed was a 20 dollar replacement battery and the will unscrew 3 mini screws.
One thing that's disappointed me is that despite all the excitement over better and cheaper battery technology, you can't buy a cheapish drop in replacement battery for e.g. an old kindle that has more storage capacity than the OEM version.<p>I understand there's like all sorts of complexities in standards, form factors, voltage, wattage, etc, but I really wish I could upgrade my old devices like that.
This is the kind of project that makes me want to raid the drawer of old electronics. The power consumption breakdown from hex4def6 is really valuable context too - wifi being the dominant power draw explains why so many of these e-ink dashboard projects end up with a Pi doing the heavy lifting over USB.<p>I've been thinking about similar setups for kitchen recipe displays. E-ink is perfect for anything you glance at - no backlight burning your eyes at 6am, and the always-on nature means you don't have to wake up a screen. The trade-off of slow refresh is actually a feature when your data only changes every few minutes.
This is great! I love seeing e-ink/Kindle related displays. I thought I saw a HN article about it 'awhile ago', turns out, time flies, that was back in 2024!<p>This is the link: <a href="https://lilymara.xyz/posts/2024/01/transit-kindle/" rel="nofollow">https://lilymara.xyz/posts/2024/01/transit-kindle/</a> from <a href="https://news.ycombinator.com/item?id=41923753">https://news.ycombinator.com/item?id=41923753</a><p>The author went from rendering a pixel-perfect image on Kindle to building a separate HTTP server to do it in rust!<p>Related: <a href="https://news.ycombinator.com/item?id=37661387">https://news.ycombinator.com/item?id=37661387</a>
I took an even simpler route:<p>I rebuilt the OneBusAway iOS app from scratch as a pair of Swift frameworks that will work anywhere, including tvOS[1].<p>Then, I started a new project to rebuild the OneBusAway server in Golang from scratch[2].<p>Then, I got an intern to build a suite of fantastic SDKs on top of Stainless[3].<p>Finally, I got Google to pay for an intern last summer to build a sign mode UI in SvelteKit that will work in any browser[4].<p>Easy!<p>But seriously though, if your transit agency isn't so cool that they provide GraphQL endpoints to query transit information, I think you'll find that the OneBusAway Maglev server is an incredibly easy way to consume your transit agency's scheduled and realtime data, and that our SDKs and apps are a fantastic way to visualize all of that information.<p>We're always looking for software developers to help out with our projects, as well as folks in disciplines ranging from user experience and product management, to biz dev and marketing, to volunteer some time to help our underfunded open source projects succeed. Feel free to reach out to me at aaron@onebusaway.org if that sounds interesting to you. Our software is used by millions of people every day in cities all around the world, including Seattle and New York City.<p>----<p>[1] <a href="https://github.com/oneBusAway/onebusaway-ios/" rel="nofollow">https://github.com/oneBusAway/onebusaway-ios/</a><p>[2] <a href="https://github.com/OneBusAway/maglev" rel="nofollow">https://github.com/OneBusAway/maglev</a><p>[3] <a href="https://developer.onebusaway.org/api/sdk" rel="nofollow">https://developer.onebusaway.org/api/sdk</a> and Stainless (which is a really terrific product) is at <a href="https://www.stainless.com" rel="nofollow">https://www.stainless.com</a><p>[4] <a href="https://github.com/oneBusAway/waystation" rel="nofollow">https://github.com/oneBusAway/waystation</a>
would a barebones html page showing the bus timings and refreshing automatically every couple of minutes work?<p>Or is there a javascript restriction on kindle?
I made something like this! Except I have it plugged into an outlet in the kitchen, so no battery to deal with. It's a little hacky but it works for me.<p><a href="https://github.com/jonmon6691/arduino_busstop" rel="nofollow">https://github.com/jonmon6691/arduino_busstop</a>
I don’t use public transportation but don’t the bus stops have these signs already? I remember seeing them.
I built a hardware display, with an LCD and a WeMos Mini D1, so that I can see the upcoming tram departure times outside my house. I could use the website, or a phone app, but having the departure times always present right by my front door is a real game-changer.<p>The actual tram-stop does indeed have a display, but here in Finland it might be -20°C in the winter time so I don't want to walk to the stop earlier than necessary.<p>Sure waiting ten minutes won't kill me, but I'd much rather wait 1-2 minutes instead. Keep myself toasty-warm indoors.
Not all of them do. It's also nice to have one closer to you, so you don't have to walk to the bus stop to find out when it's time to leave house for the bus...<p>You could check on the phone, but I could certainly see the appeal of a fixed display in a convenient location.
I don't really understand, don't you just go out of your house, go to a bus-stop and wait for the next one? Isn't the bus arrival display more of a convenience to know how long to wait? For the bus stop in my neighborhood I see busses every couple of minutes.
You're very lucky to have high frequency transit. I've lived in several places (in cities) where the bus routes ran every 20-30 minutes. So if you don't feel like waiting at a bus stop for 20 minutes, often these days one without any seats, it's nice to be able to check the ETA.
If they ever reboot that Twilight Zone where Burgess Meredith breaks his glasses they should do someone who did this to their kindle.
In case anyone wants Todoist + Gcal events on the kindle, I coded a simple web app for that some years ago:<p><a href="https://github.com/rga5321/productivity-dashboard" rel="nofollow">https://github.com/rga5321/productivity-dashboard</a><p>I am not using it anymore as I bought a TRMNL display and set up a simple template to do the same, but it worked well for me.
Regardless of anything else, I thought we were done messing with the cursor on websites.
Why Jailbreak the Kindle when you can just open its browser and visit a website that shows the arrival times?<p>The Kindle browser is surprisingly decent, I made Claude Code generate an RSS feed reader compatible with the Kindle browser, with the ability to read full articles (for those feeds that require you to visit the website), and download articles. It also supports Reddit and Google News RSS feed. This is my new favorite way of browsing the internet.<p><a href="https://github.com/adhamsalama/simple-rss-reader" rel="nofollow">https://github.com/adhamsalama/simple-rss-reader</a>
It's easier to load up a page in the Kindle browser, but more fun to jailbreak :D<p>I also didn't want the browser bar at the top.
it will be much less power-efficient, when jailbreak you could schedule the kindle to wake up once per 15/30/60 minutes to fetch the new data, set it as screensaver and then go back to sleep.
Did you hammer nails straight into a wall like a barbarian?!
Very cool
A little bit of a hijack, but it's hard to find a more relevant time to post this.<p>For a defunct startup, I built this exact thing as a product for coffee shops:<p>cafetren.com.ar<p><a href="https://cafetren-com-ar.translate.goog/?_x_tr_sl=auto&_x_tr_tl=en&_x_tr_hl=es-419&_x_tr_pto=wapp" rel="nofollow">https://cafetren-com-ar.translate.goog/?_x_tr_sl=auto&_x_tr_...</a> (translated from spanish):
[dead]
Right now I'm doing a partial refresh, and it manages to last for a couple days but would be cool if it could be unplugged for 2 weeks.<p>A small solar battery is a VERY interesting idea. If I don't end up being able to hit that number by adjusting the code itself, will look into it.
> for a bus schedule that updates every 60 seconds<p>Bus stops in Shanghai have e-ink displays that are kept up to date with the current estimated arrival time of each bus. (I don't know what the time resolution is; it could be 60 seconds, but not much longer than that.)