summaryrefslogtreecommitdiff
path: root/minecproxy/uring.h
diff options
context:
space:
mode:
authorDavid Härdeman <david@hardeman.nu>2020-06-23 20:56:22 +0200
committerDavid Härdeman <david@hardeman.nu>2020-06-23 20:56:22 +0200
commitea053d96f7e89e053d4af8d39b04c5428760345f (patch)
tree8182ca73675ad3933b0f38cb48a99c69101309b4 /minecproxy/uring.h
parent8c27290245b7bcc7cd2f72f3b4a7562294b43bbe (diff)
Big renaming, move some more functionality to shared lib
Diffstat (limited to 'minecproxy/uring.h')
-rw-r--r--minecproxy/uring.h73
1 files changed, 73 insertions, 0 deletions
diff --git a/minecproxy/uring.h b/minecproxy/uring.h
new file mode 100644
index 0000000..9c33104
--- /dev/null
+++ b/minecproxy/uring.h
@@ -0,0 +1,73 @@
+#ifndef foouringhfoo
+#define foouringhfoo
+
+extern uint64_t sqe_count;
+extern uint64_t cqe_count;
+
+void uring_task_refdump(struct uring_task *task);
+
+void uring_task_destroy(struct uring_task *task);
+
+void uring_task_put(struct uring_task *task);
+
+void uring_task_get(struct uring_task *task);
+
+void uring_task_set_buf(struct uring_task *task, struct uring_task_buf *tbuf);
+
+void uring_task_set_fd(struct uring_task *task, int fd);
+
+void uring_task_close_fd(struct uring_task *task);
+
+struct uring_task *uring_parent();
+
+void uring_task_init(struct uring_task *task, const char *name,
+ struct uring_task *parent,
+ void (*free)(struct uring_task *));
+
+void uring_close(struct uring_task *task, int fd);
+
+void uring_tbuf_write(struct uring_task *task, utask_cb_t final_cb);
+
+void uring_write(struct uring_task *task, void *buf, size_t len, utask_cb_t cb);
+
+void uring_tbuf_read_until(struct uring_task *task,
+ rutask_cb_t is_complete_cb, utask_cb_t final_cb);
+
+void uring_tbuf_read_until_eof(struct uring_task *task, utask_cb_t final_cb);
+
+void uring_tbuf_read(struct uring_task *task, utask_cb_t final_cb);
+
+void uring_read_offset(struct uring_task *task, void *buf,
+ size_t len, off_t offset, utask_cb_t cb);
+
+static inline void
+uring_read(struct uring_task *task, void *buf, size_t len, utask_cb_t cb)
+{
+ uring_read_offset(task, buf, len, 0, cb);
+}
+
+void uring_openat(struct uring_task *task, const char *path, utask_cb_t cb);
+
+void uring_tbuf_recvmsg(struct uring_task *task, utask_cb_t cb);
+
+void uring_tbuf_sendmsg(struct uring_task *task, utask_cb_t cb);
+
+void uring_connect(struct uring_task *task, struct saddr *saddr, utask_cb_t cb);
+
+void uring_accept(struct uring_task *task, struct saddr *saddr, utask_cb_t cb);
+
+void uring_splice(struct uring_task *task, int fd_in, int fd_out, utask_cb_t cb);
+
+void uring_poll(struct uring_task *task, short poll_mask, utask_cb_t cb);
+
+void uring_poll_cancel(struct uring_task *task);
+
+void uring_delete();
+
+void uring_refdump();
+
+void uring_init();
+
+void uring_event_loop();
+
+#endif