Skip to content

Custom BLE firmware for Hanshow E-Paper Shelf Labels / Price Tags

Notifications You must be signed in to change notification settings

rakyat-game/ATC_TLSR_Paper

 
 

Repository files navigation

ATC_TLSR_Paper

Custom BLE firmware for Hanshow E-Paper Shelf Labels / Price Tags using the TLSR8359 ARM SOC

Please notice that this firmware ONLY works on Price Tags with the TLSR Microcontroller!

You can support my work via PayPal: https://paypal.me/hoverboard1 this keeps projects like this coming.

As BLE can be enabled on the Telink TLSR8359 so i decided to make a custom firmware instead of reversing the stock firmware and its 2.4Ghz RF Protocol

This repo is made together with this explanation video:(click on it)

YoutubeVideo

WebSerial Firmware flasher Tool: https://atc1441.github.io/ATC_TLSR_Paper_UART_Flasher.html

WebBluetooth Image Uploader: https://atc1441.github.io/ATC_TLSR_Paper_Image_Upload.html

WebBluetooth Firmware OTA Flashing: https://atc1441.github.io/ATC_TLSR_Paper_OTA_writing.html

Compiling:

Python needs to be installed

Windows:

To compile under windows navigate with a command prompt to the "Firmware" folder

Enter "makeit.exe" and wait till the Compiling is done.

Linux:

Navigate with a Terminal into the "Firmware" Folder

Enter "make" and wait till the Compiling is done.

Flashing:

Open the Compiled .bin firmware with the WebSerial Flasher and write it to Flash.

On first Connection it is needed to Unlock the flash of the TLSR8359

About the display:

The e-ink panel used in this ESL is 250 by 122 pixels, black and white (no gray levels...yet).

Larry Bank added his OneBitDisplay (https://github.com/bitbank2/OneBitDisplay) and TIFF_G4 (https://github.com/bitbank2/TIFF_G4) libraries to make it easy to generate text and graphics. For anyone wanting to write directly to the display buffer, the memory is laid out like a typical 1-bpp bitmap except that it is rotated 90 degrees clockwise. In other words, the display is really 122 wide by 250 tall, but laying on its side. Each byte contains 8 pixels with the most significant bit on the left. Black is 0 and white is 1. Each row of 122 pixels uses 16 bytes. Here is an example function to set a pixel given the x,y of the orientation (portrait) that the display is used:

void SetPixel(int x, int y, uint8_t *pDisplayBuffer)
{
   uint8_t *d = &pDisplayBuffer[(y >> 3) + (249-x)*16];
   *d &= ~(0x80 >> (y & 7)); // set pixel to black
}

The following hardware is currently supported, most displays are detected automatically if that fails you can select the correct one in the OTA flashing tool. The graphical layout is not edited for each screen size and will not fit nicely on all especially the 1.54" Version.

Compatible Hanshow models:

Name Display Case front Case back
Stellar-MFN@ E31A 2,13" 212x104
Stellar-M3N@ E31HA 2,13" 250x122
Stellar-MN@ E31H 2,13" 250x122
Stellar-S3TN@ E31HA 1,54" 200x200

About

Custom BLE firmware for Hanshow E-Paper Shelf Labels / Price Tags

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 59.4%
  • Roff 19.3%
  • Perl 8.9%
  • Shell 3.5%
  • Tcl 2.9%
  • C++ 2.4%
  • Other 3.6%