BlockDevice can now specify max request length
This commit is contained in:
Submodule testchipip updated: 058e50a229...e8a16be9b7
@@ -13,6 +13,7 @@
|
|||||||
#define BLKDEV_COMPLETE (BLKDEV_BASE + 24)
|
#define BLKDEV_COMPLETE (BLKDEV_BASE + 24)
|
||||||
#define BLKDEV_NCOMPLETE (BLKDEV_BASE + 28)
|
#define BLKDEV_NCOMPLETE (BLKDEV_BASE + 28)
|
||||||
#define BLKDEV_NSECTORS (BLKDEV_BASE + 32)
|
#define BLKDEV_NSECTORS (BLKDEV_BASE + 32)
|
||||||
|
#define BLKDEV_MAX_REQUEST_LENGTH (BLKDEV_BASE + 36)
|
||||||
#define BLKDEV_SECTOR_SIZE 512
|
#define BLKDEV_SECTOR_SIZE 512
|
||||||
#define BLKDEV_SECTOR_SHIFT 9
|
#define BLKDEV_SECTOR_SHIFT 9
|
||||||
|
|
||||||
@@ -21,6 +22,11 @@ size_t blkdev_nsectors(void)
|
|||||||
return read_reg(BLKDEV_NSECTORS);
|
return read_reg(BLKDEV_NSECTORS);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
size_t blkdev_max_req_len(void)
|
||||||
|
{
|
||||||
|
return read_reg(BLKDEV_MAX_REQUEST_LENGTH);
|
||||||
|
}
|
||||||
|
|
||||||
int blkdev_read(void *addr, unsigned long offset, size_t nsectors)
|
int blkdev_read(void *addr, unsigned long offset, size_t nsectors)
|
||||||
{
|
{
|
||||||
int req_tag, resp_tag;
|
int req_tag, resp_tag;
|
||||||
@@ -56,28 +62,44 @@ int blkdev_write(unsigned long offset, void *addr, size_t nsectors)
|
|||||||
return (resp_tag == req_tag) ? 0 : -1;
|
return (resp_tag == req_tag) ? 0 : -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define NSECTORS 2
|
#define TEST_NSECTORS 2
|
||||||
#define TEST_SIZE (NSECTORS * BLKDEV_SECTOR_SIZE / sizeof(int))
|
#define TEST_SIZE (TEST_NSECTORS * BLKDEV_SECTOR_SIZE / sizeof(int))
|
||||||
|
|
||||||
unsigned int test_data[TEST_SIZE];
|
unsigned int test_data[TEST_SIZE];
|
||||||
unsigned int res_data[TEST_SIZE];
|
unsigned int res_data[TEST_SIZE];
|
||||||
|
|
||||||
int main(void)
|
int main(void)
|
||||||
{
|
{
|
||||||
|
unsigned int nsectors = blkdev_nsectors();
|
||||||
|
unsigned int max_req_len = blkdev_max_req_len();
|
||||||
|
|
||||||
|
if (nsectors < TEST_NSECTORS) {
|
||||||
|
printf("Error: blkdev nsectors not large enough: %u < %u\n",
|
||||||
|
nsectors, TEST_NSECTORS);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (max_req_len < TEST_NSECTORS) {
|
||||||
|
printf("Error: blkdev max_req_len not large enough: %u < %u\n",
|
||||||
|
max_req_len, TEST_NSECTORS);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
printf("blkdev: %u sectors %u max request length\n",
|
||||||
|
nsectors, max_req_len);
|
||||||
|
|
||||||
for (int i = 0; i < TEST_SIZE; i++) {
|
for (int i = 0; i < TEST_SIZE; i++) {
|
||||||
test_data[i] = i << 8;
|
test_data[i] = i << 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
asm volatile ("fence");
|
asm volatile ("fence");
|
||||||
|
|
||||||
printf("Block device with %ld sectors\n", blkdev_nsectors());
|
if (blkdev_write(0, (void *) test_data, TEST_NSECTORS)) {
|
||||||
|
|
||||||
if (blkdev_write(0, (void *) test_data, NSECTORS)) {
|
|
||||||
printf("write error\n");
|
printf("write error\n");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (blkdev_read((void *) res_data, 0, NSECTORS)) {
|
if (blkdev_read((void *) res_data, 0, TEST_NSECTORS)) {
|
||||||
printf("read error\n");
|
printf("read error\n");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user