ESP32-Develboard "D32 pro LiFePO4"

Die kürzlich von von Daniel (Eremit) versprochenen Akkus sind nun scheinbar lieferbar:
https://www.eremit.de/p/3-2v-4000mah-pack-mit-schutz-flach

Wer so einen Akku (4000 mAh) benötigt, der sollte sich mit der Bestellung beeilen, da es (wohl vorerst) nur eine Kleinserie ist.

1 „Gefällt mir“

Hi, ich hätte Interesse an 3 Boards sofern noch vorhanden.

Hallo,

Ich habe auch Interesse an zwei Platinen, komme aber erst in meinem Urlaub dazu das Thema intensiver zu betrachten weshalb ich mich bisher zurück gehalten habe.
Wie ist denn der derzeitige Stand?

Beste Grüße
Morik

Habe @Teian eben schon geschrieben wegen den drei Stück. Könnte aber noch zwei weitere löten. Danach brauche ich aber erstmal wieder neue Bauteile.

Dank der tollen Arbeit von Torsten bin ich schon seit einigen Wochen im Besitz eines Devel-Boards. Da sich meine Kinder weigern, ihren Espuino für den Umbau rauszugeben (sie haben wohl Angst, dass der Papa etwas kaputt macht), habe ich den Aufbau bisher nur fliegend getestet. Nach anfänglichen Schwierigkeiten funktioniert das Teil einwandfrei. Ich bin erstaunt, das so ein Board (noch) nicht serienmässig angeboten wird. Die Vorteile überwiegen doch stark: USB-C für die Zukunft und LiFePo für die Sicherheit.
Nun zum Problem (ist zwar offtopic): Ich kriegte die Meldung, dass die SD-Karte nicht initialisiert. Nach langer Suche und dann durch Zufall entdeckte ich, dass es unterschiedlich aufgebaute Reader gibt. Der eine hat nebst den Widerständen nur 1 Kondensator verbaut, der andere 2. Anhand der Lücke können sie gut unterschieden werden. Ganz nach dem Motto: „Je mehr, desto besser“ funktionierte der mit 2 Kondensatoren. Mangels zweitem 1C-Reader konnte ich den Fehler nicht reproduzieren.


Der obere Reader funktionierte nicht, der untere hingegen schon.

Kannst du mal durchmessen wo der zweite C liegt? dann könnte man den ersten vlt fixen…

Der erste hat ein anderes Layout der Leiterbahnen. Es gibt da gar keine Lötpunkte für einen Kondensator.

Das heißt ja nicht das man da nicht einen unterbringen könnte :wink: Fliegend geht alles…

Von der Idee her gefällt mir ein LiFePo4 Board ja eigentlich ganz gut, aber zwei Fragen zur aktuellen Ausführung hätte ich noch:

  • Soweit ich das sehe gibt es derzeit keinerlei Möglichkeit das Board komplett auszuschalten, außer man hat gerade USB eingesteckt und zieht den EN Pin auf 0, oder? Sobald man kein USB mehr eingesteckt hat, nützt der EN Pin nichts mehr und auch im Deepsleep werden 1,4mA gezogen. Könnte man noch irgendwie das EN Signal an den Q2 weiterleiten, so dass man auch die Batterie trennen kann?

  • Bzgl. Akkustandsmessung gibt es doch noch den Trick von hier: » Measuring the battery without draining it » JeeLabs , also Spannungsteiler mit zwei 10M und einem 0.1 uF Kondensator. Würde so ein Trick beim ESP32 nicht auch funktionieren, wenn man die Spannung nur alle paar Sekunden misst? Wird schon einen guten Grund haben, dass das auf keinem Board so verbaut ist…

Wenn sich zumindest das Ein-/Ausschalten lösen lässt, hätte ich Interesse…

Grundsätzlich hatten wir hier auch schon andere Ansätze, beispielsweise den LTC2954, um alles auszuschalten. Das Problem ist hierbei so ein bisschen, dass das Teil relativ teuer geworden und auch gar nicht so gut zu kriegen ist. Und da ich mir halt eher Konzepte überlegen muss, die für alle relativ einfach + günstig umsetzbar sind, bin ich für’s Erste bei einem einzelnen P-Mosfet gelandet. Das ist natürlich nicht perfekt, aber das Ganze muss aus meiner Sicht auch nicht auf Hocheffizienz getrimmt sein. In den ESPuinos meiner Kinder sind LiPo-Akkus mit 2500 mAh. Sagen wir, dass 90% der Energie nutzbar sind, dann dauert es gut 67 Tage, bis der Akku leer ist. Klar sind 1,4 mA im Kontext von Mikrocontrollern viel, aber „Einfachheit“ ist in Zeiten von fehlenden Bauteilen auch was wert.

Nichtsdestotrotz habe ich mir bereits Gedanken daarüber gemacht, ob sich das Ganze nicht mit einfachen Mitteln verbessern ließe. Eine Idee dazu habe ich hier (zweites Bild) mal publiziert: Espuino mit LiFePo4 Akku betreiben - #55 von biologist. Nur getestet habe ich das (bisher) nie.
EN_APUR war hier als Enable-Pin für den STBB1-APUR gemeint (Boost-Buck-Converter). Da würde ich der Einfachheit halber inzwischen eher einen stinknormalen LDO nehmen. VIN ist der kombinierte Spannungspfad aus USB oder Akkuspannung. Was man halt vermutlich bräuchte, ist einen zweiten ME6211, der den Port-Expander (PE) immer mit 3.3 V versorgt. Irgendwie so.
Zeichne mal einen Schaltplan von deinem Vorhaben, dann können wir drüber reden.

Zum Spannungsteiler: Ich verwende 2x300k, was im Endeffekt 5,5 uA bedeutet bei 3.3 V. Also das ist nicht der ausschlaggebende Punkt bei den 1,4 mA, hehe.

Auf den EN-Pin des LDOs hast du ja beim Develboard direkten Zugriff. Da bist du völlig frei, wenn du dir einen ESPuino-PCB designst :slight_smile:.

EDIT:
Für einfach umzusetzende Verbesserungen bin ich total offen. Beim Develboard ist man jedoch in der Größe auch etwas eingeschränkt.

@Olaf

Willst du per SW schalten können? (da würde ja nur AUS gehen, er kann sich ja nicht selbst anschalten)

Ich habe einfach in die Akku + Leitung einen Schalter verbaut, und schon sinkt mein „Aus“ Verbrauch auf 0 mA :smiley:

„Einfach“ ein Schalter in der Leitung heißt aber wohl, dass der ESPuino immer angeht, wenn man USB einsteckt, aber nicht immer lädt, wenn man USB einsteckt, oder?

Aber ich hab nochmal drüber nachgedacht und bin auf folgende Schaltung gekommen, die in Kombination mit entsprechender Software hoffentlich funktioniert:
image

  • Wenn eingeschaltet werden soll, muss der Schalter lange genug gedrückt werden, dass der ESP bootet. Hoffentlich sollten so ca. 3sec ausreichen? Dann wäre das für mich voll in Ordnung, und die Tochter ist es sowieso von der alten Tigerbox-ohne-touch so gewohnt.
  • Beim Booten schaut der ESP erstmal nach, ob GPIO2 auf 1 ist. Wenn ja geht er zum normalen Bootvorgang über. Wenn nein, geht er in den Modus ChargeOnly („ESP läuft, weil USB eingesteckt wurde, aber eigentlich nicht eingeschaltet wurde“)
  • Im normalen Bootvorgang wird erstmal GPIO1 auf 1 gesetzt, damit man den Knopf wieder loslassen kann, dann wird alles so gemacht wie immer und GPIO2 kann bei kurzem Drücken als Play/Pause, bei langem drücken als „Power Off“ verwendet werden.
  • In der „Power Off“ Funktion wird der aktuelle Status gespeichert, damit das Hörbuch an der richtigen Stelle weitergeht etc., es wird gewartet, bis der Knopf wieder losgelassen wurde, und am Ende wird GPIO1 auf 0 gesetzt. Wenn der ESP ausgeht ist alles gut, wenn nicht dann wird er wohl an USB hängen. Dann sollte er mit der nächsten Instruktion zu init() zurückkehren (resetFunc() oder sowas), und kommt dann voraussichtlich in den Modus ChargeOnly.
  • Im Modus ChargeOnly wird auch erstmal der GPIO1 auf 1 gesetzt, damit der Akku verbunden wird und geladen werden kann. Dann wird gewartet bis entweder der Knopf gedrückt wird (GPIO2 ist 3 sec. auf 1 oder wie man es auch mag) - in diesem Fall wird der Modus ChargeOnly verlassen, man macht ganz normal mit init() weiter. Alternativ sollte ChargeOnly verlassen werden, wenn kein USB mehr eingesteckt ist und somit nicht mehr geladen wird (CHRG Pin auf 0) - dann wird GPIO1 auch ausgeschaltet und alles ist aus. Oder, wenn es keinen CHRG Pin gibt, wird einfach alle 10-30sec oder alle paar Minuten mal probehalber GPIO1 auf 0 gesetzt - wenn der ESP dann noch nicht aus ist, muss er noch am USB hängen und sollte somit weiter laden und warten.

Dann fragt sich nur noch:

Wenn man die Idee mit den Sub-Platinen aus dem anderen Thread aufnehmen möchte, könnte man meiner Meinung nach mit einem LiPo/LiFePo4 Charger mit Load-Sharing anfangen, der dann aus dem Laderegler besteht mit Lötbrücke um zwischen LiPo und LiFePo4 zu wählen, aber auch einen Teil der „Power“-Schaltung hätte. Stelle ich mir ungefähr so vor:
image
Dadurch sollte sichergestellt sein, dass nur entweder vorzugsweise an VBUS_SW oder nachrangig an VBAT_SW eine Spannung anliegt. Je nach Lust und Laune kann man dann z.B.:

  • Für LiPo Akkus VBUS_SW und VBAT_SW zusammenführen an den Eingang eines 3.3V Reglers bzw. ein ganzes DevBoard anschließen
  • oder für LiFePo4 den VBUS_SW an einen LDO anschließen und VBAT_SW direkt an den 3.3V Pin
  • oder, wenn man mal 5V bräuchte, einen Boost an VBAT_SW anschließen und dessen Ausgang mit VBUS_SW verbinden…
  • …und natürlich Schalter verbauen, wo und wie man möchte, aber unabhängig davon immer Akkus laden.

Den meisten Ladeplatinen, die ich sonst so gefunden habe, fehlt der Load-Sharing Teil und über LiFePo4 bzw. getrennte Ausgänge braucht man gar nicht erst reden. Daher denke ich schon dass so eine Platine für sich genommen einen Wert hätte.

Ich will eigentlich, dass ich mittelfristig von den Breadboards wegkomme, damit ich nicht so viel von Hand löten muss. Insofern ist das für mich nicht zielführend, hier noch ein weiteres Breadboard wieder einzuführen. Aber das soll dich natürlich nicht davon abhalten, dir das so zu bauen, wie du das gerne hättest :slight_smile:.

Muss halt schauen, dass sich das Ganze auch erstmalig flashen lässt. Weil ganz am Anfang ist halt noch keine Firmware drauf.

Er schaltet CHRG ständig an und wieder aus, so dass eine dort angeschlossene LED dann blinkt. Als Leerlaufspannung zum Laden des FePo-Akkus kann man dann etwa 3,6 V messen. Ist ein Akku angeschlossen und er wird geladen, so wird CHRG auf LOW gezogen (Open Drain). Ist ein Akku angeschlossen und er wird nicht geladen, so wird CHRG auf HI gezogen.

Was man bestimmt machen könnte, ist einen Schalter, wie von @JHB zu integrieren, den man auf der einen Seite auf GND anlötet und auf der anderen Seite an EN. Damit zieht man den Enable-Pin des ME6211 auf GND und damit kommt hinten nix raus. Die Ladeschaltung würde davon nicht beeinflusst.

Aber die LiFePo Akkus umgehen doch den Laderegler und gehen direkt an den ESP, oder nicht? Dann nützt EN auch nichts mehr.

Oh stimmt, da hast du Recht. Verpeilt.

…und bzgl. MOSFETs: grundsätzlich verstehe ich ja schon, wie die funktionieren, aber dann einen mit niedrigen Rds(on) zu finden und einem passenden V_GS(thresh) und ein passendes N-MOSFET zum Schalten des P dazusetzen oder auch nicht und noch die richtigen R’s hierhin und dorthin zu zaubern… naja, wenn es dann eine anschlussfertige Platine gibt mit einem „combined on resistance (max)“ von 26 mΩ @ 1.8 V, dann siegt die Bequemlichkeit.

Ich hätte nur gedacht, anstatt eines P-MOSFET als Schalter, eines P-MOSFET als Verpolschutz und eines dritten P-MOSFET auf dem Develboard für das Load-Sharing müsste es doch auch möglich sein, genau den besagten EN-Pin irgendwie an einen einzigen MOSFET weiterzuleiten, der sowieso schon das Load-Sharing sicherstellt.

Naja, aber eigentlich gefällt mir die Lösung mit dem externen Schalter in der Batterieleitung auch ganz gut, weil man damit auch gleichzeitig den Spannungsteiler abschaltet, der den Batteriestand misst. Wenn nicht doch noch jemandem ein Denkfehler auffällt werd ich das vielleicht einfach mal so probieren.

Bzgl. Flash ganz am Anfang: Wenn USB angesteckt ist, wird der ESP ja allemal versorgt, und dass der Akku getrennt ist und nicht aufgeladen wird, ist in dem Moment auch nicht so wichtig.

Das ebenfalls von mir entwickelte LiPo-Develboard hat übrigens einen Verpolschutz, der per MOSFET realisiert ist. Das werde ich für das FePo-Board noch nachholen. Das FePo-Board ist auch etwas länger und hat seinen Reset-Button oben. Wobei ich das gar nicht schlecht finde, weil dann kann ich die optisch direkt unterscheiden.

Wie auch immer: Viel Spaß beim Basteln :grin:.

Moin, eine Frage zu den LFP-Akkus und welchen am besten. Bei Li-Ion war ja standard, dass man, bis auf wenige ausnahmen, immer zu einer protected-Zelle greifen sollte. Ist das bei LFP nicht so? Die einzige protected-Zelle, die mir untergekommen ist ist die fette von Eremit: EREMIT 3.2V 6Ah LiFePo4 Akku Pack
Die 18650er und die 26650er sind offensichtlich nicht protected. Auch sonst findet man eher wenig. Sonst noch gefunden:

Wie seht ihr das?

Edit: Gerade eine von Soshine gefunden die protected ist. Gibt es aber nur bei Alibaba :confused: Soshine Lifepo4 26650 3.2v 3200mah Lithium Iron Phosphate Rechargeable Battery With Pcb (1 Pair) - Buy 26650 3.2v 3200mah Battery,26650 Lithium Iron Phosphate Rechargeable Battery,26650 Lithium Iron Phosphate Battery Product on Alibaba.com

Imho ist das bei LiFePo nicht so gefährlich wie bei Lipo, daher könnte man darauf verzichten…

aber haben ist besser wie brauchen :smiley: