mirror of
https://github.com/Rockbox/rockbox.git
synced 2025-11-09 13:12:37 -05:00
storage: 64-bit sector offsets
* Create new 'sector_t' type alias:
* uint64_t for all targets with HAVE_LBA48 or HAVE_SDUC
* unsigned long for the everything else
* Alter all storage APIs to use sector_t instead of 'unsigned long'
* Alter Volume/Partition/storage info structures to use sector_t
* Disk cache converted to sector_t
* ATA Core:
* convert to using sector_t for sector addresses and drive sizes
* Always fill out upper 16 bits of LBA48 addresses
* IDENTIFY INFO is fixed at 512 bytes, not SECTOR_SIZE
* USB mass storage:
* convert to using sector_t for sector addesses and drive sizes
* Implement READ_16/WRITE_16 for LBA48 addresses
* Convert FAT code to use sector_t for all sector references
* output_dyn_value() now accepts int64_t instead of 'int'
* Corrected "rockbox info" to work for (MULTIVOLUME & !MULTIDRIVE)
* Better reporting of disk and (logical+physical) sector sizes in debug info
* Detect SDUC cards and report on storage debug_info screen
To-do: SDUC
* Refactor SD core to remove duplicate code in every driver
* Card probe and init state machine
* Implement core SDUC support
* SD2.0 needs to be 2.0+ (fixed for jz47xx and x1000)
* Host and Card ID (ACMD41)
* 32-bit addressing for all read/write/erase operations (CMD22)
* ADD SDUC to target device drivers, defining HAVE_SDUC as appropriate
Change-Id: Ib0138781a0081664d11511037685503df1b93608
This commit is contained in:
parent
9ff308a589
commit
15e5237469
49 changed files with 629 additions and 435 deletions
|
|
@ -172,6 +172,8 @@ bool disk_init(IF_MD_NONVOID(int drive))
|
|||
}
|
||||
}
|
||||
|
||||
// XXX backup GPT header at final LBA of drive...
|
||||
|
||||
while (is_gpt) {
|
||||
/* Re-start partition parsing using GPT */
|
||||
uint64_t part_lba;
|
||||
|
|
@ -243,20 +245,24 @@ reload:
|
|||
goto skip; /* Any flag makes us ignore this */
|
||||
}
|
||||
tmp = BYTES2INT64(pptr, 32); /* FIRST LBA */
|
||||
if (tmp > UINT32_MAX) { // XXX revisit when we resize struct partinfo!
|
||||
DEBUGF("GPT: partition starts after 2GiB mark\n");
|
||||
#ifndef STORAGE_64BIT_SECTOR
|
||||
if (tmp > UINT32_MAX) {
|
||||
DEBUGF("GPT: partition starts after 2TiB mark\n");
|
||||
goto skip;
|
||||
}
|
||||
#endif
|
||||
if (tmp < 34) {
|
||||
DEBUGF("GPT: Invalid start LBA\n");
|
||||
goto skip;
|
||||
}
|
||||
pinfo[part].start = tmp;
|
||||
tmp = BYTES2INT64(pptr, 40); /* LAST LBA */
|
||||
if (tmp > UINT32_MAX) { // XXX revisit when we resize struct partinfo!
|
||||
DEBUGF("GPT: partition ends after 2GiB mark\n");
|
||||
#ifndef STORAGE_64BIT_SECTOR
|
||||
if (tmp > UINT32_MAX) {
|
||||
DEBUGF("GPT: partition ends after 2TiB mark\n");
|
||||
goto skip;
|
||||
}
|
||||
#endif
|
||||
if (tmp <= pinfo[part].start) {
|
||||
DEBUGF("GPT: Invalid end LBA\n");
|
||||
goto skip;
|
||||
|
|
@ -264,7 +270,7 @@ reload:
|
|||
pinfo[part].size = tmp - pinfo[part].start + 1;
|
||||
pinfo[part].type = PARTITION_TYPE_FAT32_LBA;
|
||||
|
||||
DEBUGF("GPart%d: start: %08lx size: %08lx\n",
|
||||
DEBUGF("GPart%d: start: %016lx size: %016lx\n",
|
||||
part,pinfo[part].start,pinfo[part].size);
|
||||
part++;
|
||||
|
||||
|
|
@ -499,13 +505,13 @@ unsigned int volume_get_cluster_size(IF_MV_NONVOID(int volume))
|
|||
return clustersize;
|
||||
}
|
||||
|
||||
void volume_size(IF_MV(int volume,) unsigned long *sizep, unsigned long *freep)
|
||||
void volume_size(IF_MV(int volume,) sector_t *sizep, sector_t *freep)
|
||||
{
|
||||
disk_reader_lock();
|
||||
|
||||
if (!CHECK_VOL(volume) || !fat_size(IF_MV(volume,) sizep, freep))
|
||||
{
|
||||
if (freep) *sizep = 0;
|
||||
if (sizep) *sizep = 0;
|
||||
if (freep) *freep = 0;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -71,12 +71,12 @@ struct disk_cache_entry
|
|||
#ifdef HAVE_MULTIVOLUME
|
||||
unsigned char volume; /* volume of sector */
|
||||
#endif
|
||||
unsigned long sector; /* cached disk sector number */
|
||||
sector_t sector; /* cached disk sector number */
|
||||
};
|
||||
|
||||
BITARRAY_TYPE_DECLARE(cache_map_entry_t, cache_map, DC_NUM_ENTRIES)
|
||||
|
||||
static inline unsigned int map_sector(unsigned long sector)
|
||||
static inline unsigned int map_sector(sector_t sector)
|
||||
{
|
||||
/* keep sector hash simple for now */
|
||||
return sector % DC_MAP_NUM_ENTRIES;
|
||||
|
|
@ -172,7 +172,7 @@ static inline void cache_discard_entry(struct disk_cache_entry *dce,
|
|||
/* search the cache for the specified sector, returning a buffer, either
|
||||
to the specified sector, if it exists, or a new/evicted entry that must
|
||||
be filled */
|
||||
void * dc_cache_probe(IF_MV(int volume,) unsigned long sector,
|
||||
void * dc_cache_probe(IF_MV(int volume,) sector_t sector,
|
||||
unsigned int *flagsp)
|
||||
{
|
||||
unsigned int mapnum = map_sector(sector);
|
||||
|
|
@ -200,7 +200,7 @@ void * dc_cache_probe(IF_MV(int volume,) unsigned long sector,
|
|||
if (old_flags)
|
||||
{
|
||||
int old_volume = IF_MV_VOL(dce->volume);
|
||||
unsigned long sector = dce->sector;
|
||||
sector_t sector = dce->sector;
|
||||
unsigned int old_mapnum = map_sector(sector);
|
||||
|
||||
if (old_flags & DCE_DIRTY)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue