-
Data: 2016-01-01 21:40:22
Temat: Re: Karta SD - dziwne zachowanie zasilania
Od: Atlantis <m...@w...pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]W dniu 2016-01-01 o 19:01, Marek pisze:
> Ale tak na marginesie.nie stosowałem kluczowania Vcc kart sd i nie
> kojarzę abym napotkał przy kartach sd opisywany przez Ciebie problem.
> Podejrzewam, ze być może jednak driver spi jaki używasz nieprawidłowo
> inicjuje kartę np. brak spi lowbitrate przy inicjalizacji (przyspieszyć
> spi można dopiero po inicjalizacji).
Hmm... Masz może działającą wersję mmc.c?
Bo siedzę na tym już kolejną godzinę i za nic nie mogę zmusić ukłdu do
stabilnej pracy. W kółko wywala albo bład 3, albo 13. Jeśli już ruszy,
to od wielkiego święta i nie ma żadnej pewności, że stan taki utrzyma
się po kolejnym resecie.
Obecna konfiguracja wygląda następująco:
1) Osoba linia zasilania dla karty, kluczowana tranzystorem i filtrowana LC.
2) Wszystkie linie karty podciągnięte do tej linii rezystorami 4,7k. To
znaczy wszystkie z wyjątkiem DC - ta jest podłączona do ogólnego VCC.
3) w funkcji power_on() konfiguruję wyjścia i ustawiam PPS. W
power_off() wyłączam funkcję PPS dla MOSI i z powrotem przestawiam
wszystkie wyjścia na wejścia.
Generalnie wygląda to następująco:
static
void power_on (void)
{
PWR_SETOUT();
PWR_ON();
for (Timer1 = 150; Timer1; ); /* Wait for 150ms */
/* Setup SPI2 */
// Setup CS as output
CS_SETOUT();
MISO_SETIN();
MISO_SETPPS();
MOSI_SETOUT();
MOSI_SETPPS();
// configured for ~400 kHz operation - reset later to 20 MHz
SpiChnOpen(SPI_CHANNEL2,SPI_OPEN_MSTEN|SPI_OPEN_CKP_
HIGH|SPI_OPEN_SMP_END|SPI_OPEN_MODE8,64);
SPI2CONbits.ON = 1;
}
static
void power_off (void)
{
select(); /* Wait for card ready */
deselect();
SPI2CONbits.ON = 0; /* Disable SPI2 */
Stat |= STA_NOINIT; /* Set STA_NOINIT */
PWR_OFF();
CS_SETIN();
MOSI_RESTOREPPS();
MOSI_SETIN();
for (Timer1 = 150; Timer1; ); /* Wait for 40ms */
}
Jak widzisz SPI startuje na małej prędkości.
Zresztą w disk_initialize są wywoływane jeszcze dwie makrodefinicje:
#define FCLK_SLOW() SPI2BRG = 64 /* Set slow clock (100k-400k) */
#define FCLK_FAST() SPI2BRG = 2 /* Set fast clock (depends on the CSD) */
Następne wpisy z tego wątku
- 01.01.16 22:57 Marek
Najnowsze wątki z tej grupy
- Dzisiaj Bentlejem czyli przybieżeli sześciu Króli do Rysia na kasie
- ciekawy układ magnetofonu
- Mikroskop 3D
- Jak być bezpiecznym z Li-Ion?
- Szukam monitora HDMI ok. 4"
- Obcinaczki z łapaczem
- termostat do lodowki
- SEP 1 kV E
- Aku LiPo źródło dostaw - ktoś poleci ?
- starość nie radość
- Ataki hakerskie
- Akumulatorki Ni-MH AA i AAA Green Cell
- Dławik CM
- JDG i utylizacja sprzetu
- Identyfikacja układ SO8 w sterowniku migających światełek choinkowych
Najnowsze wątki
- 2024-12-25 Wrocław => Architekt rozwiązań (doświadczenie w obszarze Java, AWS
- 2024-12-25 Warszawa => Sales Assistant <=
- 2024-12-25 Kraków => Inżynier bezpieczeństwa aplikacji <=
- 2024-12-25 Lublin => System Architect (Java background) <=
- 2024-12-25 Szczecin => Specjalista ds. public relations <=
- 2024-12-25 Wrocław => Key Account Manager <=
- 2024-12-25 Kraków => Full Stack .Net Engineer <=
- 2024-12-25 Kraków => Programista Full Stack .Net <=
- 2024-12-25 Bieruń => Regionalny Kierownik Sprzedaży (OZE) <=
- 2024-12-25 Białystok => Inżynier Serwisu Sprzętu Medycznego <=
- 2024-12-25 Białystok => Delphi Programmer <=
- 2024-12-25 Chrzanów => Team Lead / Tribe Lead FrontEnd <=
- 2024-12-25 Kraków => Ekspert IT (obszar systemów sieciowych) <=
- 2024-12-25 Mińsk Mazowiecki => Spedytor Międzynarodowy <=
- 2024-12-24 Dzisiaj Bentlejem czyli przybieżeli sześciu Króli do Rysia na kasie