2019-10-13 03:17:29 +02:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <inttypes.h>
|
|
|
|
#include "kolibri.h"
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
FILE *file;
|
2019-10-21 04:51:56 +02:00
|
|
|
uint64_t sect_cnt;
|
2019-10-13 03:17:29 +02:00
|
|
|
uint32_t sect_size;
|
|
|
|
} vdisk_t;
|
|
|
|
|
|
|
|
void *cio_disk_init(const char *fname) {
|
|
|
|
FILE *f = fopen(fname, "r+");
|
|
|
|
fseeko(f, 0, SEEK_END);
|
|
|
|
off_t fsize = ftello(f);
|
|
|
|
fseeko(f, 0, SEEK_SET);
|
|
|
|
size_t sect_size = 512;
|
|
|
|
if (strstr(fname, "s4096") != NULL || strstr(fname, "s4k") != NULL) {
|
|
|
|
sect_size = 4096;
|
|
|
|
}
|
|
|
|
vdisk_t *vdisk = (vdisk_t*)malloc(sizeof(vdisk_t));
|
2019-10-22 04:24:44 +02:00
|
|
|
*vdisk = (vdisk_t){f, (uint64_t)fsize / sect_size, sect_size};
|
2019-10-13 03:17:29 +02:00
|
|
|
return vdisk;
|
|
|
|
}
|
|
|
|
|
|
|
|
void cio_disk_free(vdisk_t *vdisk) {
|
|
|
|
fclose(vdisk->file);
|
|
|
|
free(vdisk);
|
|
|
|
}
|
|
|
|
|
|
|
|
f70status cio_disk_read(vdisk_t *vdisk, uint8_t *buffer, off_t startsector, uint32_t *numsectors) {
|
|
|
|
fseeko(vdisk->file, startsector * vdisk->sect_size, SEEK_SET);
|
|
|
|
fread(buffer, *numsectors * vdisk->sect_size, 1, vdisk->file);
|
2019-10-25 03:48:13 +02:00
|
|
|
return F70_ERROR_SUCCESS;
|
2019-10-13 03:17:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
f70status cio_disk_write(vdisk_t *vdisk, uint8_t *buffer, off_t startsector, uint32_t *numsectors) {
|
|
|
|
fseeko(vdisk->file, startsector * vdisk->sect_size, SEEK_SET);
|
|
|
|
fwrite(buffer, *numsectors * vdisk->sect_size, 1, vdisk->file);
|
2019-10-25 03:48:13 +02:00
|
|
|
return F70_ERROR_SUCCESS;
|
2019-10-13 03:17:29 +02:00
|
|
|
}
|