summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIan Moffett <ian@osmora.org>2025-10-07 15:35:53 -0400
committerIan Moffett <ian@osmora.org>2025-10-07 15:36:36 -0400
commit732d6c11f39cb3d9646f8077a1df2b453659ddaa (patch)
tree7c932712060376e8f8ce3d19d55aab988e24d53c
parent83ccba4afb141c236c0aeaf3e1ddaeb9e9b07d73 (diff)
kern: vfs: Add write vop to vnodes
Signed-off-by: Ian Moffett <ian@osmora.org>
-rw-r--r--src/sys/include/os/vnode.h27
-rw-r--r--src/sys/os/vfs_subr.c25
2 files changed, 52 insertions, 0 deletions
diff --git a/src/sys/include/os/vnode.h b/src/sys/include/os/vnode.h
index 354c73c..77459a1 100644
--- a/src/sys/include/os/vnode.h
+++ b/src/sys/include/os/vnode.h
@@ -67,11 +67,26 @@ struct vop_lookup_args {
};
/*
+ * Represents VOP data that can be used to read
+ * or write a file, etc
+ *
+ * @data: Buffer containing I/O data
+ * @len: Length of buffer
+ * @vp: Current vnode
+ */
+struct vop_rw_data {
+ void *data;
+ size_t len;
+ struct vnode *vp;
+};
+
+/*
* Represents operations that can be performed on
* a specific vnode. These are implemented as callbacks
*/
struct vop {
int(*lookup)(struct vop_lookup_args *args);
+ ssize_t(*write)(struct vop_rw_data *data);
};
/*
@@ -120,4 +135,16 @@ int vfs_valloc(struct vnode **resp, vtype_t type, int flags);
*/
int vfs_vrel(struct vnode *vp, int flags);
+/*
+ * Wrapper for the vnode write callback
+ *
+ * @vp: Vnode to write to
+ * @data: Data to write
+ * @len: Length of bytes to write
+ *
+ * Returns the number of bytes written on success, otherwise
+ * a less than zero value on failure.
+ */
+ssize_t vop_write(struct vnode *vp, char *data, size_t len);
+
#endif /* !_OS_VNODE_H_ */
diff --git a/src/sys/os/vfs_subr.c b/src/sys/os/vfs_subr.c
index 64c7492..b82b683 100644
--- a/src/sys/os/vfs_subr.c
+++ b/src/sys/os/vfs_subr.c
@@ -143,3 +143,28 @@ vfs_cmp_cnt(const char *path)
return cnt + 1;
}
+
+ssize_t
+vop_write(struct vnode *vp, char *data, size_t len)
+{
+ struct vop_rw_data rwdata;
+ struct vop *vops;
+
+ if (vp == NULL || data == NULL) {
+ return -EINVAL;
+ }
+
+ if (len == 0) {
+ return -EINVAL;
+ }
+
+ /* Grab the virtual operations */
+ if ((vops = vp->vops) == NULL) {
+ return -EIO;
+ }
+
+ rwdata.data = data;
+ rwdata.len = len;
+ rwdata.vp = vp;
+ return vops->write(&rwdata);
+}