toaruos/kernel/fs/serialdev.c
2013-04-15 01:26:03 -07:00

90 lines
2.2 KiB
C

/* vim: tabstop=4 shiftwidth=4 noexpandtab
*
* Serial communication device
*
*/
#include <system.h>
#include <fs.h>
#include <logging.h>
uint32_t read_serial(fs_node_t *node, uint32_t offset, uint32_t size, uint8_t *buffer);
uint32_t write_serial(fs_node_t *node, uint32_t offset, uint32_t size, uint8_t *buffer);
void open_serial(fs_node_t *node, uint8_t read, uint8_t write);
void close_serial(fs_node_t *node);
uint32_t read_serial(fs_node_t *node, uint32_t offset, uint32_t size, uint8_t *buffer) {
if (size < 1) {
return 0;
}
memset(buffer, 0x00, 1);
uint32_t collected = 0;
while (collected < size) {
while (!serial_rcvd((int)node->device)) {
switch_task(1);
}
#if 0
debug_print(NOTICE, "Data received from TTY, have %d, need %d", collected+1, size);
#endif
buffer[collected] = serial_recv((int)node->device);
collected++;
}
return collected;
}
uint32_t write_serial(fs_node_t *node, uint32_t offset, uint32_t size, uint8_t *buffer) {
uint32_t sent = 0;
while (sent < size) {
serial_send((int)node->device, buffer[sent]);
sent++;
}
return size;
}
void open_serial(fs_node_t * node, uint8_t read, uint8_t write) {
return;
}
void close_serial(fs_node_t * node) {
return;
}
fs_node_t * serial_device_create(int device) {
fs_node_t * fnode = malloc(sizeof(fs_node_t));
memset(fnode, 0x00, sizeof(fs_node_t));
fnode->device= (void *)device;
strcpy(fnode->name, "serial");
fnode->uid = 0;
fnode->gid = 0;
fnode->flags = FS_CHARDEVICE;
fnode->read = read_serial;
fnode->write = write_serial;
fnode->open = open_serial;
fnode->close = close_serial;
fnode->readdir = NULL;
fnode->finddir = NULL;
fnode->ioctl = NULL; /* TODO ioctls for raw serial devices */
fnode->atime = now();
fnode->mtime = fnode->atime;
fnode->ctime = fnode->atime;
return fnode;
}
void serial_mount_devices() {
fs_node_t * ttyS0 = serial_device_create(SERIAL_PORT_A);
vfs_mount("/dev/ttyS0", ttyS0);
fs_node_t * ttyS1 = serial_device_create(SERIAL_PORT_B);
vfs_mount("/dev/ttyS1", ttyS1);
fs_node_t * ttyS2 = serial_device_create(SERIAL_PORT_C);
vfs_mount("/dev/ttyS2", ttyS2);
fs_node_t * ttyS3 = serial_device_create(SERIAL_PORT_D);
vfs_mount("/dev/ttyS3", ttyS3);
}