mirror of
https://github.com/Rockbox/rockbox.git
synced 2025-12-06 21:25:03 -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
|
|
@ -134,8 +134,8 @@ static int show_legal(void)
|
|||
struct info_data
|
||||
|
||||
{
|
||||
unsigned long size[NUM_VOLUMES];
|
||||
unsigned long free[NUM_VOLUMES];
|
||||
sector_t size[NUM_VOLUMES];
|
||||
sector_t free[NUM_VOLUMES];
|
||||
unsigned long name[NUM_VOLUMES];
|
||||
bool new_data;
|
||||
};
|
||||
|
|
@ -162,16 +162,19 @@ enum infoscreenorder
|
|||
*/
|
||||
static int refresh_data(struct info_data *info)
|
||||
{
|
||||
int i = 0;
|
||||
#ifdef HAVE_MULTIVOLUME
|
||||
#ifdef HAVE_MULTIDRIVE
|
||||
int drive;
|
||||
int max = -1;
|
||||
|
||||
#endif
|
||||
int drive = 0;
|
||||
int i = 0;
|
||||
for (i = 0 ; CHECK_VOL(i) ; i++) {
|
||||
#endif
|
||||
volume_size(IF_MV(i,) &info->size[i], &info->free[i]);
|
||||
#ifdef HAVE_MULTIVOLUME
|
||||
#ifdef HAVE_MULTIDRIVE
|
||||
drive = volume_drive(i);
|
||||
#endif
|
||||
if (drive > 0 || info->size[i] == 0)
|
||||
info->name[i] = LANG_DISK_NAME_MMC;
|
||||
else
|
||||
|
|
@ -182,9 +185,12 @@ static int refresh_data(struct info_data *info)
|
|||
max = drive;
|
||||
else if (drive < max)
|
||||
break;
|
||||
#elif defined(HAVE_MULTIVOLUME)
|
||||
if (volume_partition(i) == -1)
|
||||
break;
|
||||
#endif
|
||||
#ifdef HAVE_MULTIVOLUME
|
||||
}
|
||||
#else
|
||||
i++;
|
||||
#endif
|
||||
|
||||
info->new_data = false;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue