2010-09-16 19:59:41 +00:00
|
|
|
/*
|
|
|
|
disc.h
|
|
|
|
Interface to the low level disc functions. Used by the higher level
|
|
|
|
file system code.
|
2010-09-18 23:16:05 +00:00
|
|
|
|
2010-09-16 19:59:41 +00:00
|
|
|
Copyright (c) 2006 Michael "Chishm" Chisholm
|
2010-09-18 23:16:05 +00:00
|
|
|
|
2010-09-16 19:59:41 +00:00
|
|
|
Redistribution and use in source and binary forms, with or without modification,
|
|
|
|
are permitted provided that the following conditions are met:
|
|
|
|
|
2010-09-24 00:48:03 +00:00
|
|
|
1. Redistributions of source code must retain the above copyright notice,
|
|
|
|
this list of conditions and the following disclaimer.
|
|
|
|
2. Redistributions in binary form must reproduce the above copyright notice,
|
|
|
|
this list of conditions and the following disclaimer in the documentation and/or
|
|
|
|
other materials provided with the distribution.
|
|
|
|
3. The name of the author may not be used to endorse or promote products derived
|
|
|
|
from this software without specific prior written permission.
|
2010-09-16 19:59:41 +00:00
|
|
|
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
|
|
|
WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
|
|
|
|
AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE
|
|
|
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
|
|
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
|
|
|
|
EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
2010-09-24 00:48:03 +00:00
|
|
|
*/
|
2010-09-16 19:59:41 +00:00
|
|
|
#ifndef _DISC_H
|
|
|
|
#define _DISC_H
|
|
|
|
|
|
|
|
#include "common.h"
|
|
|
|
|
|
|
|
/*
|
2010-09-24 00:48:03 +00:00
|
|
|
A list of all default devices to try at startup,
|
|
|
|
terminated by a {NULL,NULL} entry.
|
|
|
|
*/
|
2010-09-18 23:16:05 +00:00
|
|
|
typedef struct
|
|
|
|
{
|
2010-09-24 00:48:03 +00:00
|
|
|
const char* name;
|
|
|
|
const DISC_INTERFACE* (*getInterface)(void);
|
2010-09-16 19:59:41 +00:00
|
|
|
} INTERFACE_ID;
|
|
|
|
extern const INTERFACE_ID _FAT_disc_interfaces[];
|
|
|
|
|
|
|
|
/*
|
2010-09-24 00:48:03 +00:00
|
|
|
Check if a disc is inserted
|
|
|
|
Return true if a disc is inserted and ready, false otherwise
|
|
|
|
*/
|
|
|
|
static inline bool _FAT_disc_isInserted(const DISC_INTERFACE* disc)
|
2010-09-18 23:16:05 +00:00
|
|
|
{
|
|
|
|
return disc->isInserted();
|
2010-09-16 19:59:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
2010-09-24 00:48:03 +00:00
|
|
|
Read numSectors sectors from a disc, starting at sector.
|
|
|
|
numSectors is between 1 and LIMIT_SECTORS if LIMIT_SECTORS is defined,
|
|
|
|
else it is at least 1
|
|
|
|
sector is 0 or greater
|
|
|
|
buffer is a pointer to the memory to fill
|
|
|
|
*/
|
|
|
|
static inline bool _FAT_disc_readSectors(const DISC_INTERFACE* disc, sec_t sector, sec_t numSectors, void* buffer)
|
2010-09-18 23:16:05 +00:00
|
|
|
{
|
2010-09-24 00:48:03 +00:00
|
|
|
return disc->readSectors(sector, numSectors, buffer);
|
2010-09-16 19:59:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
2010-09-24 00:48:03 +00:00
|
|
|
Write numSectors sectors to a disc, starting at sector.
|
|
|
|
numSectors is between 1 and LIMIT_SECTORS if LIMIT_SECTORS is defined,
|
|
|
|
else it is at least 1
|
|
|
|
sector is 0 or greater
|
|
|
|
buffer is a pointer to the memory to read from
|
|
|
|
*/
|
|
|
|
static inline bool _FAT_disc_writeSectors(const DISC_INTERFACE* disc, sec_t sector, sec_t numSectors,
|
|
|
|
const void* buffer)
|
2010-09-18 23:16:05 +00:00
|
|
|
{
|
2010-09-24 00:48:03 +00:00
|
|
|
return disc->writeSectors(sector, numSectors, buffer);
|
2010-09-16 19:59:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
2010-09-24 00:48:03 +00:00
|
|
|
Reset the card back to a ready state
|
|
|
|
*/
|
|
|
|
static inline bool _FAT_disc_clearStatus(const DISC_INTERFACE* disc)
|
2010-09-18 23:16:05 +00:00
|
|
|
{
|
|
|
|
return disc->clearStatus();
|
2010-09-16 19:59:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
2010-09-24 00:48:03 +00:00
|
|
|
Initialise the disc to a state ready for data reading or writing
|
|
|
|
*/
|
|
|
|
static inline bool _FAT_disc_startup(const DISC_INTERFACE* disc)
|
2010-09-18 23:16:05 +00:00
|
|
|
{
|
|
|
|
return disc->startup();
|
2010-09-16 19:59:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
2010-09-24 00:48:03 +00:00
|
|
|
Put the disc in a state ready for power down.
|
|
|
|
Complete any pending writes and disable the disc if necessary
|
|
|
|
*/
|
|
|
|
static inline bool _FAT_disc_shutdown(const DISC_INTERFACE* disc)
|
2010-09-18 23:16:05 +00:00
|
|
|
{
|
|
|
|
return disc->shutdown();
|
2010-09-16 19:59:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
2010-09-24 00:48:03 +00:00
|
|
|
Return a 32 bit value unique to each type of interface
|
|
|
|
*/
|
|
|
|
static inline uint32_t _FAT_disc_hostType(const DISC_INTERFACE* disc)
|
2010-09-18 23:16:05 +00:00
|
|
|
{
|
|
|
|
return disc->ioType;
|
2010-09-16 19:59:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
2010-09-24 00:48:03 +00:00
|
|
|
Return a 32 bit value that specifies the capabilities of the disc
|
|
|
|
*/
|
|
|
|
static inline uint32_t _FAT_disc_features(const DISC_INTERFACE* disc)
|
2010-09-18 23:16:05 +00:00
|
|
|
{
|
|
|
|
return disc->features;
|
2010-09-16 19:59:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif // _DISC_H
|