fs: implement basic write
This commit is contained in:
parent
3026bfe2f1
commit
632824e437
|
@ -38,7 +38,8 @@ ARDIX_SOURCES += \
|
||||||
|
|
||||||
ARDIX_ASM_SOURCES += \
|
ARDIX_ASM_SOURCES += \
|
||||||
$(ARDIX_ARCH_PWD)/irq_pend_sv.S \
|
$(ARDIX_ARCH_PWD)/irq_pend_sv.S \
|
||||||
$(ARDIX_ARCH_PWD)/irq_svc.S
|
$(ARDIX_ARCH_PWD)/irq_svc.S \
|
||||||
|
$(ARDIX_ARCH_PWD)/syscall.S
|
||||||
|
|
||||||
CFLAGS += \
|
CFLAGS += \
|
||||||
-DARCH_AT91SAM3X8E
|
-DARCH_AT91SAM3X8E
|
||||||
|
|
|
@ -0,0 +1,48 @@
|
||||||
|
/* SPDX-License-Identifier: BSD-3-Clause */
|
||||||
|
/* See the end of this file for copyright, licensing, and warranty information. */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This is a collection of system calls that are exported to userspace.
|
||||||
|
* The Ardix syscall ABI for parameter passing is aligned with the AAPCS, making
|
||||||
|
* these wrappers extremely simple because all parameters are already in the
|
||||||
|
* correct registers.
|
||||||
|
*/
|
||||||
|
|
||||||
|
.syntax unified
|
||||||
|
.thumb
|
||||||
|
|
||||||
|
/* these syscalls are only there to be exported to userspace */
|
||||||
|
.section .text.shared
|
||||||
|
|
||||||
|
.thumb_func
|
||||||
|
.global pwrite
|
||||||
|
.type pwrite, %function
|
||||||
|
pwrite:
|
||||||
|
svc #1
|
||||||
|
bx lr
|
||||||
|
.size pwrite, .-pwrite
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2020 Felix Kopp <sandtler@sandtler.club>
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without modification, are permitted
|
||||||
|
* provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice, this list of
|
||||||
|
* conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice, this list of
|
||||||
|
* conditions and the following disclaimer in the documentation and/or other materials
|
||||||
|
* provided with the distribution.
|
||||||
|
* 3. Neither the name of the copyright holder nor the names of its contributors may be
|
||||||
|
* used to endorse or promote products derived from this software without specific prior
|
||||||
|
* written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR
|
||||||
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
|
||||||
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
||||||
|
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY
|
||||||
|
* WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
|
@ -0,0 +1,32 @@
|
||||||
|
/* SPDX-License-Identifier: BSD-3-Clause */
|
||||||
|
/* See the end of this file for copyright, licensing, and warranty information. */
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#define ARCH_SYSCALL_READ 0
|
||||||
|
#define ARCH_SYSCALL_WRITE 1
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2020 Felix Kopp <sandtler@sandtler.club>
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without modification, are permitted
|
||||||
|
* provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice, this list of
|
||||||
|
* conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice, this list of
|
||||||
|
* conditions and the following disclaimer in the documentation and/or other materials
|
||||||
|
* provided with the distribution.
|
||||||
|
* 3. Neither the name of the copyright holder nor the names of its contributors may be
|
||||||
|
* used to endorse or promote products derived from this software without specific prior
|
||||||
|
* written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR
|
||||||
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
|
||||||
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
||||||
|
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY
|
||||||
|
* WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
|
@ -3,14 +3,16 @@
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include <arch/syscall.h>
|
||||||
|
|
||||||
#include <ardix/types.h>
|
#include <ardix/types.h>
|
||||||
|
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <toolchain.h>
|
#include <toolchain.h>
|
||||||
|
|
||||||
enum syscall {
|
enum syscall {
|
||||||
SYSCALL_READ = 0,
|
SYSCALL_READ = ARCH_SYSCALL_READ,
|
||||||
SYSCALL_WRITE = 1,
|
SYSCALL_WRITE = ARCH_SYSCALL_WRITE,
|
||||||
NSYSCALLS
|
NSYSCALLS
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -25,6 +25,11 @@ typedef struct {
|
||||||
int count;
|
int count;
|
||||||
} atom_t;
|
} atom_t;
|
||||||
|
|
||||||
|
#include <arch/hardware.h>
|
||||||
|
|
||||||
|
/* Syscall argument */
|
||||||
|
typedef word_t sysarg_t;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2020 Felix Kopp <sandtler@sandtler.club>
|
* Copyright (c) 2020 Felix Kopp <sandtler@sandtler.club>
|
||||||
*
|
*
|
||||||
|
|
|
@ -0,0 +1,29 @@
|
||||||
|
#
|
||||||
|
# Copyright (c) 2020 Felix Kopp <sandtler@sandtler.club>
|
||||||
|
#
|
||||||
|
# Redistribution and use in source and binary forms, with or without modification, are permitted
|
||||||
|
# provided that the following conditions are met:
|
||||||
|
#
|
||||||
|
# 1. Redistributions of source code must retain the above copyright notice, this list of
|
||||||
|
# conditions and the following disclaimer.
|
||||||
|
# 2. Redistributions in binary form must reproduce the above copyright notice, this list of
|
||||||
|
# conditions and the following disclaimer in the documentation and/or other materials
|
||||||
|
# provided with the distribution.
|
||||||
|
# 3. Neither the name of the copyright holder nor the names of its contributors may be
|
||||||
|
# used to endorse or promote products derived from this software without specific prior
|
||||||
|
# written permission.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR
|
||||||
|
# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
||||||
|
# FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
|
||||||
|
# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
||||||
|
# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY
|
||||||
|
# WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
#
|
||||||
|
|
||||||
|
ARDIX_KERNEL_FS_PWD = $(ARDIX_KERNEL_PWD)/fs
|
||||||
|
|
||||||
|
ARDIX_SOURCES += \
|
||||||
|
$(ARDIX_KERNEL_FS_PWD)/write.c
|
|
@ -0,0 +1,57 @@
|
||||||
|
/* SPDX-License-Identifier: BSD-3-Clause */
|
||||||
|
/* See the end of this file for copyright, licensing, and warranty information. */
|
||||||
|
|
||||||
|
#include <ardix/malloc.h>
|
||||||
|
#include <ardix/serial.h>
|
||||||
|
#include <ardix/syscall.h>
|
||||||
|
#include <ardix/userspace.h>
|
||||||
|
|
||||||
|
#include <errno.h>
|
||||||
|
#include <stddef.h>
|
||||||
|
#include <toolchain.h>
|
||||||
|
|
||||||
|
int sys_write(int fd, __user const void *buf, size_t len, size_t off)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
void *copy;
|
||||||
|
|
||||||
|
if (fd != 1) /* we only support stdout (serial console) right now ... */
|
||||||
|
return -ENOTSUP;
|
||||||
|
if (off != 0) /* ... and the serial console doesn't support seeking */
|
||||||
|
return -ESPIPE;
|
||||||
|
|
||||||
|
copy = malloc(len);
|
||||||
|
if (copy == NULL)
|
||||||
|
return -ENOMEM;
|
||||||
|
ret = (int)copy_from_user(copy, buf, len);
|
||||||
|
|
||||||
|
/* TODO: reschedule if blocking */
|
||||||
|
ret = serial_write(serial_default_interface, copy, ret);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2020 Felix Kopp <sandtler@sandtler.club>
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without modification, are permitted
|
||||||
|
* provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice, this list of
|
||||||
|
* conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice, this list of
|
||||||
|
* conditions and the following disclaimer in the documentation and/or other materials
|
||||||
|
* provided with the distribution.
|
||||||
|
* 3. Neither the name of the copyright holder nor the names of its contributors may be
|
||||||
|
* used to endorse or promote products derived from this software without specific prior
|
||||||
|
* written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR
|
||||||
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
|
||||||
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
||||||
|
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY
|
||||||
|
* WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
Loading…
Reference in New Issue