Tolerancja 5 V na wejściu czujnikowym VBUS

8

Projektuję urządzenie wokół STM32L476. Moje urządzenie jest zasilane przede wszystkim z baterii, ale ma port USB, który po podłączeniu chcę użyć jako alternatywnego źródła zasilania (poprzez regulator 3,3 V) w celu ograniczenia zużycia energii. Możliwe jest również, że użytkownik podłącza port USB, gdy nie ma baterii.

Chcę być w stanie wyczuć, kiedy port USB jest podłączony, więc używam PA9 jako OTF_FS_VBUS.

Dobra wiadomość : arkusz danych mówi, że pin PA9 jest tolerancyjny dla 5 V.

Zła wiadomość : piny tolerujące 5 V wydają się być tak naprawdę tolerowane na 5 V tylko przy podłączonym zasilaniu. Arkusz danych §6.2 tabela 18 mówi:

Maksymalne napięcie wejściowe na pinach FT_xxx: min (VDD, VDDA, VDDIO2, VDDUSB, VLCD) + 4,0 V

W moim przypadku, jeśli nie ma baterii, a użytkownik podłącza port USB, upłynie trochę czasu, zanim regulator zacznie działać, podczas którego napięcie na PA9 wyniesie 5V, podczas gdy zasilanie nie zostanie w ogóle podłączone do pinów zasilania procesora.

Jeszcze więcej złych wiadomości : aktualny zastrzyk jest niedozwolony: arkusz danych §6.2, tabela 19 mówi:

Prąd wtryskiwany na FT_xxx: -5 / + 0 (patrz uwaga 4)

Uwaga 4: Wstrzyknięcie dodatnie jest wywołane przez VIN> VDDIOx, natomiast wstrzyknięcie ujemne jest wywołane przez VIN <VSS. IINJ (PIN) nie może być nigdy przekroczony.

Wygląda więc na to, że nie mogę użyć prostego rezystora do ograniczenia nadmiaru prądu na PA9 podczas uruchamiania regulatora. Jakakolwiek ilość prądu przepływającego z VBUS do PA9 przed wzrostem VDD jest najwyraźniej zabroniona.

Co zrobili inni?

Przyjrzałem się licznym projektom wokół układów STM32, patrząc na ich połączenia VBUS i wydaje się, że ich to nie obchodzi. Łączą VBUS bezpośrednio z PA9 lub ostatecznie przez rezystor, ale nigdy nie widziałem nic bardziej skomplikowanego. Ale w większości są to płyty programistyczne, więc chyba wytrzymałość (czy to słowo?) Nie jest bardzo ważna. I zwykle nie są zasilane przez port USB, a na pewno zakładamy, że użytkownik nie podłączy portu USB przed zasileniem płyty.

Jaki jest mój plan?

Umieszczenie tego między VBUS na porcie USB a pinem PA9 MCU:

Ochrona VBUS

Naprawdę starałem się to uprościć. Zasadniczo zapewnia, że ​​VUSB_CPU (który jest pinem PA9) nigdy nie może przekroczyć VCPU + 4 V (Vz + Vbe), bez zużywania energii, jeśli jest OK.

Moje główne pytania to : Czy mam rację w mojej analizie? Czy ten obwód jest dobrym rozwiązaniem? Czy martwię się o rzeczy, które nie mają znaczenia? Dlaczego nikt nie wydaje się przejmować tym potencjalnym problemem?

Dodatkowe pytanie : Planuję używać USB OTG. Czy to problem, jeśli między złączem a stykiem PA9 znajduje się rezystor 4,7 k? Myślę, że byłoby tak, gdybym musiał użyć pulsowania VBUS podczas SRP, ale ta metoda jest najwyraźniej przestarzała. Czy jestem dobry, niezależnie od roli (urządzenia / hosta) mojego urządzenia?

Ostatni : jaki jest maksymalny prąd pobierany przez pin zasilania VDDUSB? Arkusz danych określa, dla urządzeń peryferyjnych USB: 16,4µA / MHz dla domeny zegarowej AHB + 23,2µA / MHz dla niezależnej domeny zegarowej, ale nie wiemy, skąd jest pobierany (VDD lub VDDUSB).

ciemny
źródło
Inną opcją ochrony PA9 byłoby umieszczenie przełącznika mos między USB + 5 V a PA9, a następnie napędzanie bramki przełącznika za pomocą wyjścia regulatora.
Mark
dlaczego nie użyć dzielnika rezystora? 430k i 630k dadzą ci 3,3 V na pinie.
b degnan
Ale dzielnik rezystora nie rozwiąże problemu wtrysku. Dzielnik wstrzykuje 3,3 wolta do kołka, zanim część zostanie zasilona.
Mark
Rozumiem z arkusza danych, że pin może wytrzymać napięcie 4 V, nawet gdy jest wyłączony (czy to prawda?). Więc dzielnik rezystorowy byłby dobrym rozwiązaniem, ale pobierałby moc na stałe. Zapomniałem wspomnieć, że mam na to ścisłe ograniczenia.
dim

Odpowiedzi:

4

Idź z dzielnikiem rezystorów (430k / 620k) na Vbusie - to utrzyma mikrokontroler w specyfikacji, a pobór prądu pasożytniczego nie będzie problemem, ponieważ będzie pochodził wyłącznie z Vbus, a nie z baterii (co jest tym, co Zakładam, że chcesz zachować).

ThreePhaseEel
źródło
Głupie mnie ... Wykluczałem dzielnik rezystora z powodu zużycia prądu, ale moje rozumowanie było oczywiście niekompletne. Rzeczywiście, nie jest problemem czerpanie mocy z vbus. Dlaczego nikt nawet tego nie robi na swoich tablicach? Sam ST (tablica odkryć), olimex, ...? Nadal nie rozumiem tego.
dim
0

Prawdopodobnie najprostsza metoda, użyj rezystora o wysokiej wartości (10-100 kB) zasilającego duży kondensator (kilka UF lub więcej), aby napięcie wzrosło, nie martwiłbym się o ułamek wolta, który gromadzi się na kondensatorze podczas uruchamiania regulatora, jeśli mikro ma ochronę ESD, wówczas wejścia mogą obsłużyć 5-10 V przez kilka dziesiątek US

Sam
źródło
Brzmi świetnie ... ale tylko do momentu, gdy pomyślisz o tym, co stanie się po odłączeniu zasilania. Kondensator może w rzeczywistości pogorszyć sytuację, niż tylko posiadanie rezystora o dużej wartości - rezystor nie może dostarczyć dużego prądu, ale naładowany kondensator może.
Chris Stratton,
czy mógłbyś przeprowadzić go przez mały zener? W tej sekcji arkusza danych podano VDD + 4V, prawda? Gdybyś miał Zenera, który zrzucił szynę na mniej niż VDD + 4V, czy byłoby w porządku?
Sam
Nie wyobrażam sobie dobrze twojej sugestii Zenera bez schematu. Ale jeśli rozwiązanie ma taką samą złożoność jak moje (3 tanie dyskretne komponenty), nie zyskam wiele.
dim
Zasadniczo: Input-> zener-> PA9, zener szeregowo z wejściem w przeciwieństwie do rezystora szeregowego, zener spada wolt lub dwa, więc napięcie na PA9 jest zawsze nieco niższe. Jeśli płyty deweloperów po prostu je powiążą, to prawdopodobnie jest w porządku, myślę, że ostrzeżenia mogą się pojawić po włączeniu MCU, sprawdź, czy jest jakaś sekcja na temat sekwencjonowania mocy lub zachowania podczas uruchamiania.
Sam
1
@ Tom, to właściwie mój główny problem. Sprawdziłem, nic nie robią. PA9 jest podłączony bezpośrednio do VBUS na porcie USB (nawet przez rezystor) na płycie demo Discovery. Tak więc, chyba że coś przeoczyłem, jest to całkowicie sprzeczne z arkuszem danych. Moim problemem nie jest sam obwód ochronny. Myślę, że moje rozwiązanie, nawet jeśli można je z pewnością ulepszyć, może zadziałać. Szczerze mówiąc, moim głównym problemem jest po prostu: czy to wszystko jest naprawdę konieczne?
dim