Estou usando um PIC18F26K80 e um compilador XC8. Estou tentando inicializar um cartão SD e criar um arquivo. Simplesmente formatei o cartão SD no Windows para ter um sistema de arquivos "FAT32" e um "tamanho da unidade de alocação" de 512 bytes. A capacidade do cartão SD é de 2 GB. Estou usando a biblioteca MDD da versão MLA Legacy. Meu principal é o seguinte:
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);
}
O programa fica preso dentro da função "FSInit ()" e o erro que recebo da função é "CE_BAD_PARTITION", o que significa "O registro de inicialização está ruim".
A função "initIO ()" é a seguinte:
//==============================================================================
// 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;
}
Os últimos dois bytes do setor 0 são a assinatura de inicialização e devem ser 0x55 e 0xAA, e a imagem que incluí confirma isso. No entanto, dentro da função "LoadMBR", é feita a seguinte verificação:
if((Partition->Signature0 != FAT_GOOD_SIGN_0) || (Partition->Signature1 != FAT_GOOD_SIGN_1))
{
FSerrno = CE_BAD_PARTITION;
error = CE_BAD_PARTITION;
}
else
{
...
}
e, embora os bytes sejam os mesmos, a primeira condição é atendida e retorna com o erro "CE_BAD_PARTITION".