Hack together open()
This commit is contained in:
@@ -43,4 +43,8 @@ int8_t fat32_get_cluster_by_name(char* name, struct fat32_directory_entry* dentr
|
|||||||
int8_t fat32_read_cluster(uint32_t cluster, void* buf);
|
int8_t fat32_read_cluster(uint32_t cluster, void* buf);
|
||||||
uint32_t fat32_next_cluster(uint32_t cluster);
|
uint32_t fat32_next_cluster(uint32_t cluster);
|
||||||
|
|
||||||
|
int8_t fat32_file_open(const int8_t* filename);
|
||||||
|
int8_t fat32_file_read(int8_t fd, const void* buf, int8_t nbytes);
|
||||||
|
int8_t fat32_file_write(int8_t fd, const void* buf, int8_t nbytes);
|
||||||
|
int8_t fat32_file_close(int8_t fd);
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
@@ -1,10 +1,67 @@
|
|||||||
#include "fat32.h"
|
|
||||||
|
|
||||||
#include <devices/sd_card.h>
|
#include <devices/sd_card.h>
|
||||||
|
#include <process/process.h>
|
||||||
#include <conio.h>
|
#include <conio.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
#include "fat32.h"
|
||||||
|
#include "fs.h"
|
||||||
|
|
||||||
|
static struct fops fat32_file_ops = {fat32_file_open, fat32_file_close, fat32_file_read, fat32_file_write};
|
||||||
|
|
||||||
|
int8_t fd_val;
|
||||||
|
|
||||||
|
|
||||||
|
//TODO
|
||||||
|
int8_t fat32_file_write(int8_t fd, const void* buf, int8_t nbytes) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
int8_t fat32_file_close(int8_t fd) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
int8_t fat32_file_open(const int8_t* filename) {
|
||||||
|
int8_t ret;
|
||||||
|
int8_t i;
|
||||||
|
int8_t fd;
|
||||||
|
|
||||||
|
struct fat32_directory_entry dentry;
|
||||||
|
|
||||||
|
struct pcb* pcb = get_pcb_ptr();
|
||||||
|
|
||||||
|
ret = fat32_get_cluster_by_name(filename, &dentry);
|
||||||
|
if (ret) {
|
||||||
|
cprintf("Error finding cluster for filename");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* try to find an empty file desciptor, fail otherwise */
|
||||||
|
//TODO We start at 3 here because 0, 1, 2 will be reserved later
|
||||||
|
for (i = 3; i < FILE_DESC_SIZE; i++) {
|
||||||
|
if (pcb->file_desc_array[i].flags == !IN_USE) {
|
||||||
|
fd = i;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (fd == -1){
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* add process */
|
||||||
|
pcb->file_desc_array[fd].f32_dentry = dentry;
|
||||||
|
pcb->file_desc_array[fd].flags = IN_USE;
|
||||||
|
pcb->file_desc_array[fd].file_pos = 0;
|
||||||
|
|
||||||
|
pcb->file_desc_array[fd].file_ops = &fat32_file_ops;
|
||||||
|
|
||||||
|
return fd;
|
||||||
|
}
|
||||||
|
|
||||||
|
int8_t fat32_file_read(int8_t fd, const void* buf, int8_t nbytes) {
|
||||||
|
struct pcb* pcb = get_pcb_ptr();
|
||||||
|
}
|
||||||
|
|
||||||
int8_t fat32_read_cluster(uint32_t cluster, void* buf) {
|
int8_t fat32_read_cluster(uint32_t cluster, void* buf) {
|
||||||
uint8_t error;
|
uint8_t error;
|
||||||
uint32_t addr = (cluster - 2) + data_start_sector;
|
uint32_t addr = (cluster - 2) + data_start_sector;
|
||||||
|
|||||||
@@ -3,16 +3,18 @@
|
|||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
|
#include <process/process.h>
|
||||||
|
|
||||||
/* syscalls for files */
|
/* syscalls for files */
|
||||||
int8_t file_read(int8_t fd, void* buf, int8_t nbytes);
|
int8_t file_read(int8_t fd, void* buf, int8_t nbytes);
|
||||||
int8_t file_write(int8_t fd, const void* buf, int8_t nbytes);
|
int8_t file_write(int8_t fd, const void* buf, int8_t nbytes);
|
||||||
int8_t file_open(const uint8_t* filename);
|
int8_t file_open(const int8_t* filename);
|
||||||
int8_t file_close(int8_t fd);
|
int8_t file_close(int8_t fd);
|
||||||
|
|
||||||
/* syscalls for directories */
|
/* syscalls for directories */
|
||||||
int8_t directory_read(int8_t fd, void* buf, int8_t nbytes);
|
int8_t directory_read(int8_t fd, void* buf, int8_t nbytes);
|
||||||
int8_t directory_write(int8_t fd, const void* buf, int8_t nbytes);
|
int8_t directory_write(int8_t fd, const void* buf, int8_t nbytes);
|
||||||
int8_t directory_open(const uint8_t* filename);
|
int8_t directory_open(const int8_t* filename);
|
||||||
int8_t directory_close(int8_t fd);
|
int8_t directory_close(int8_t fd);
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
6
sw/kernel/process/process.c
Normal file
6
sw/kernel/process/process.c
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
#include <process/process.h>
|
||||||
|
|
||||||
|
|
||||||
|
struct pcb* get_pcb_ptr() {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
46
sw/kernel/process/process.h
Normal file
46
sw/kernel/process/process.h
Normal file
@@ -0,0 +1,46 @@
|
|||||||
|
#ifndef _PROCESS_H
|
||||||
|
#define _PROCESS_H
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
#include <filesystems/fat32.h>
|
||||||
|
|
||||||
|
#define FILE_DESC_SIZE 8
|
||||||
|
|
||||||
|
|
||||||
|
#define IN_USE 1
|
||||||
|
|
||||||
|
|
||||||
|
struct fops {
|
||||||
|
int8_t (*open)(const int8_t* filename);
|
||||||
|
int8_t (*close)(int8_t fd);
|
||||||
|
int8_t (*read)(int8_t fd, void* buf, int8_t nbytes);
|
||||||
|
int8_t (*write)(int8_t fd, const void* buf, int8_t nbytes);
|
||||||
|
};
|
||||||
|
|
||||||
|
struct file_desc {
|
||||||
|
struct fops* file_ops;
|
||||||
|
uint8_t fs_type;
|
||||||
|
union {
|
||||||
|
struct fat32_directory_entry f32_dentry;
|
||||||
|
};
|
||||||
|
uint32_t file_pos;
|
||||||
|
uint32_t flags;
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Process Control Block struct */
|
||||||
|
struct pcb {
|
||||||
|
struct file_desc file_desc_array[FILE_DESC_SIZE];
|
||||||
|
int32_t is_vidmapped;
|
||||||
|
uint8_t args[128];
|
||||||
|
uint32_t execute_return;
|
||||||
|
int32_t pid;
|
||||||
|
int32_t parent_pid;
|
||||||
|
uint32_t parent_esp;
|
||||||
|
uint32_t parent_ebp;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
struct pcb* get_pcb_ptr();
|
||||||
|
|
||||||
|
#endif
|
||||||
@@ -1,9 +1,17 @@
|
|||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
#include <process/process.h>
|
||||||
|
|
||||||
#define FILE_PATH "fs.fat"
|
#define FILE_PATH "fs.fat"
|
||||||
|
|
||||||
|
struct pcb fake_pcb;
|
||||||
|
|
||||||
|
//TODO
|
||||||
|
struct pcb* get_pcb_ptr() {
|
||||||
|
return &fake_pcb;
|
||||||
|
}
|
||||||
|
|
||||||
uint32_t lmulii(uint16_t a, uint16_t b) {
|
uint32_t lmulii(uint16_t a, uint16_t b) {
|
||||||
printf("lmulii: %x * %x = %x\n", a, b, a*b);
|
printf("lmulii: %x * %x = %x\n", a, b, a*b);
|
||||||
return a * b;
|
return a * b;
|
||||||
|
|||||||
@@ -5,35 +5,11 @@
|
|||||||
void fat32_init(void);
|
void fat32_init(void);
|
||||||
|
|
||||||
int main(void) {
|
int main(void) {
|
||||||
struct fat32_directory_entry dentry;
|
int8_t fd;
|
||||||
int i;
|
|
||||||
uint32_t offset = 0;
|
|
||||||
uint32_t cluster;
|
|
||||||
uint8_t cluster_count;
|
|
||||||
fat32_init();
|
fat32_init();
|
||||||
|
|
||||||
/* This is what is going to be part of open */
|
/* This is what is going to be part of open */
|
||||||
fat32_get_cluster_by_name("VERYLA~1TXT", &dentry);
|
fd = fat32_file_open("VERYLA~1TXT");
|
||||||
cprintf("attr1: %x\n", dentry.attr1);
|
|
||||||
cprintf("cluster: %x%x\n", dentry.cluster_high, dentry.cluster_low);
|
|
||||||
cprintf("File Size: %lx\n", dentry.file_size);
|
|
||||||
|
|
||||||
|
cprintf("fd: %x\n", fd);
|
||||||
/* This will become part of read */
|
|
||||||
cluster = (dentry.cluster_high << 16) | dentry.cluster_low;
|
|
||||||
cluster++;
|
|
||||||
fat32_read_cluster(cluster + offset/512, sd_buf);
|
|
||||||
|
|
||||||
cluster_count = (dentry.file_size/512)/sectors_per_cluster;
|
|
||||||
cprintf("Cluster count: %x\n", cluster_count);
|
|
||||||
|
|
||||||
while (cluster < 0xffffff0) {
|
|
||||||
for (i = 0; i < dentry.file_size && i < 512; i++) {
|
|
||||||
cprintf("%c", sd_buf[i]);
|
|
||||||
}
|
|
||||||
cluster = fat32_next_cluster(cluster);
|
|
||||||
fat32_read_cluster(cluster + offset/512, sd_buf);
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user