Sto usando un PIC18F26K80 e un compilatore XC8. Sto cercando di inizializzare una scheda SD e creare un file. Ho semplicemente formattato la scheda SD su Windows per avere un file system "FAT32" e una "Dimensione unità di allocazione" di 512 byte. La capacità della scheda SD è di 2 GB. Sto usando la libreria MDD dalla versione MLA Legacy. Il mio principale è il seguente:
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);
}
Il programma si blocca all'interno della funzione "FSInit ()" e l'errore che ottengo dalla funzione è "CE_BAD_PARTITION", che significa "Il record di avvio è errato".
La funzione "initIO ()" è la seguente:
//==============================================================================
// 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;
}
Gli ultimi due byte del settore 0 sono la firma di avvio e devono essere 0x55 e 0xAA e l'immagine che ho incluso lo conferma. Tuttavia, all'interno della funzione "LoadMBR" viene effettuato il seguente controllo:
if((Partition->Signature0 != FAT_GOOD_SIGN_0) || (Partition->Signature1 != FAT_GOOD_SIGN_1))
{
FSerrno = CE_BAD_PARTITION;
error = CE_BAD_PARTITION;
}
else
{
...
}
e sebbene i byte siano uguali, viene soddisfatta la prima condizione e restituisce l'errore "CE_BAD_PARTITION".