summaryrefslogtreecommitdiff
path: root/kernel/drivers/rtl8139.c
diff options
context:
space:
mode:
authorAnton Kling <anton@kling.gg>2023-11-22 21:58:30 +0100
committerAnton Kling <anton@kling.gg>2023-11-22 21:58:30 +0100
commitec91e81a4fcfd7ee6bc4150f06d8740e82f808da (patch)
tree6cad6ef6dc775d56758bc4da4a2bddd13cdec35f /kernel/drivers/rtl8139.c
parent90e4da9473ee2fc6419b7821274ec102219551f9 (diff)
Networking: Split network packets if they are too large
Diffstat (limited to 'kernel/drivers/rtl8139.c')
-rw-r--r--kernel/drivers/rtl8139.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/kernel/drivers/rtl8139.c b/kernel/drivers/rtl8139.c
index 4b53ef4..dd81533 100644
--- a/kernel/drivers/rtl8139.c
+++ b/kernel/drivers/rtl8139.c
@@ -103,12 +103,16 @@ __attribute__((interrupt)) void rtl8139_handler(void *regs) {
EOI(0xB);
}
-int rtl8139_send_data(u8 *data, u16 data_size) {
+void rtl8139_send_data(u8 *data, u16 data_size) {
const struct PCI_DEVICE *device = &rtl8139;
// FIXME: It should block or fail if there is too little space for the
// buffer
- if (data_size > 0x1000)
- return 0;
+ if (data_size > 0x1000) {
+ rtl8139_send_data(data, 0x1000);
+ data += 0x1000;
+ data_size -= 0x1000;
+ return rtl8139_send_data(data, data_size);
+ }
if (send_buffers_loop > 3) {
send_buffers_loop = 0;
}
@@ -117,7 +121,6 @@ int rtl8139_send_data(u8 *data, u16 data_size) {
(u32)virtual_to_physical(send_buffers[send_buffers_loop], NULL));
outl(device->gen.base_mem_io + 0x10 + send_buffers_loop * 4, data_size);
send_buffers_loop += 1;
- return 1;
}
void get_mac_address(u8 mac[6]) {