Używam PIC18F26K80 i kompilatora XC8. Próbuję zainicjować kartę SD i utworzyć plik. Po prostu sformatowałem kartę SD w systemie Windows, aby mieć system plików „FAT32” i „rozmiar jednostki alokacji” 512 bajtów. Pojemność karty SD wynosi 2 GB. Korzystam z biblioteki MDD z wersji MLA Legacy. Moje główne to:
FSFILE * file;
char sendBuffer[22] = "This is test string 1";
//**************************************************
// main function
//**************************************************
int main()
{
initIO();
LATBbits.LATB0 = 0;
// Initialise SPI and SD-card
while ( !MDD_MediaDetect() );
// Initialize the device
while ( !FSInit() );
// Initialize
#ifdef ALLOW_WRITES
// Create a new file
file = FSfopenpgm ( "FILE.TXT", "w" );
if ( file == NULL )
while(1);
// Write 21 1-byte objects from sendBuffer into the file
if ( FSfwrite ( (void *) sendBuffer, 1, 21, file ) != 21 )
while(1);
// Close the file
if ( FSfclose ( file ) )
while(1);
#endif
LATBbits.LATB0 = 1; //LED
while(1) {}
return (0);
}
Program utknął w funkcji „FSInit ()”, a błąd, który otrzymuję z funkcji, to „CE_BAD_PARTITION”, co oznacza „Niepoprawny rekord rozruchowy”.
Funkcja „initIO ()” jest następująca:
//==============================================================================
// void initIO( void );
//==============================================================================
// Sets the pins on the PIC to input or output and determines the speed of the
// internal oscilaltor
// input: none
// return: none
//==============================================================================
void initIO()
{
OSCCON = 0x75; // Clock speed = 32MHz (4x8Mhz)
TRISA = 0;
TRISB = 0;
TRISC = 0;
TRISBbits.TRISB0 = 0; //LED
TRISCbits.TRISC3 = 0; // set SCL pin as output
TRISCbits.TRISC4 = 1; // set RC4 pin as input
TRISCbits.TRISC5 = 0;
TRISAbits.TRISA5 = 0;
}
Ostatnie dwa bajty sektora 0 są sygnaturą rozruchową i powinny to być 0x55 i 0xAA, a obraz, który podałem, to potwierdza. Jednak w ramach funkcji „LoadMBR” dokonuje się następującej kontroli:
if((Partition->Signature0 != FAT_GOOD_SIGN_0) || (Partition->Signature1 != FAT_GOOD_SIGN_1))
{
FSerrno = CE_BAD_PARTITION;
error = CE_BAD_PARTITION;
}
else
{
...
}
i chociaż bajty są takie same, pierwszy warunek jest spełniony i zwraca błąd „CE_BAD_PARTITION”.