Minor cleanup, embed a DNS request
This commit is contained in:
parent
e79f36900c
commit
6b8c425000
@ -3,6 +3,7 @@
|
|||||||
#include <printf.h>
|
#include <printf.h>
|
||||||
#include <pci.h>
|
#include <pci.h>
|
||||||
#include <mem.h>
|
#include <mem.h>
|
||||||
|
#include <list.h>
|
||||||
#include <ipv4.h>
|
#include <ipv4.h>
|
||||||
#include <mod/shell.h>
|
#include <mod/shell.h>
|
||||||
|
|
||||||
@ -34,12 +35,16 @@ static uint32_t rtl_iobase = 0;
|
|||||||
static uint8_t * rtl_rx_buffer;
|
static uint8_t * rtl_rx_buffer;
|
||||||
static uint8_t * rtl_tx_buffer[5];
|
static uint8_t * rtl_tx_buffer[5];
|
||||||
|
|
||||||
|
static uint8_t * last_packet = NULL;
|
||||||
|
|
||||||
static uintptr_t rtl_rx_phys;
|
static uintptr_t rtl_rx_phys;
|
||||||
static uintptr_t rtl_tx_phys[5];
|
static uintptr_t rtl_tx_phys[5];
|
||||||
|
|
||||||
static uint32_t cur_rx = 0;
|
static uint32_t cur_rx = 0;
|
||||||
static int dirty_tx = 0;
|
static int dirty_tx = 0;
|
||||||
|
|
||||||
|
static list_t * rx_wait;
|
||||||
|
|
||||||
static uint8_t _dhcp_packet[] = {
|
static uint8_t _dhcp_packet[] = {
|
||||||
0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xF0, 0xF0, 0xF0, 0xF0, 0xF0, 0xF0, 0x08, 0x00, 0x45, 0x00,
|
0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xF0, 0xF0, 0xF0, 0xF0, 0xF0, 0xF0, 0x08, 0x00, 0x45, 0x00,
|
||||||
0x01, 0x10, 0x00, 0x01, 0x00, 0x00, 0x40, 0x11, 0x79, 0xDD, 0x00, 0x00, 0x00, 0x00, 0xFF, 0xFF,
|
0x01, 0x10, 0x00, 0x01, 0x00, 0x00, 0x40, 0x11, 0x79, 0xDD, 0x00, 0x00, 0x00, 0x00, 0xFF, 0xFF,
|
||||||
@ -61,6 +66,14 @@ static uint8_t _dhcp_packet[] = {
|
|||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x63, 0x82, 0x53, 0x63, 0x35, 0x01, 0x01, 0xFF
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x63, 0x82, 0x53, 0x63, 0x35, 0x01, 0x01, 0xFF
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static uint8_t _dns_packet[] = {
|
||||||
|
0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x52, 0x54, 0x00, 0x12, 0x34, 0x56, 0x08, 0x00, 0x45, 0x00,
|
||||||
|
0x00, 0x36, 0x00, 0x01, 0x00, 0x00, 0x40, 0x11, 0x62, 0xA5, 0x0A, 0x00, 0x02, 0x0F, 0x0A, 0x00,
|
||||||
|
0x02, 0x03, 0x00, 0x35, 0x00, 0x35, 0x00, 0x22, 0x9E, 0x77, 0x00, 0x00, 0x01, 0x00, 0x00, 0x01,
|
||||||
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x05, 0x64, 0x61, 0x6B, 0x6B, 0x6F, 0x02, 0x75, 0x73, 0x00,
|
||||||
|
0x00, 0x01, 0x00, 0x01
|
||||||
|
};
|
||||||
|
|
||||||
static void rtl_irq_handler(struct regs *r) {
|
static void rtl_irq_handler(struct regs *r) {
|
||||||
uint16_t status = inports(rtl_iobase + RTL_PORT_ISR);
|
uint16_t status = inports(rtl_iobase + RTL_PORT_ISR);
|
||||||
outports(rtl_iobase + RTL_PORT_ISR, status);
|
outports(rtl_iobase + RTL_PORT_ISR, status);
|
||||||
@ -89,6 +102,7 @@ static void rtl_irq_handler(struct regs *r) {
|
|||||||
debug_print(WARNING, "rx error :(");
|
debug_print(WARNING, "rx error :(");
|
||||||
} else {
|
} else {
|
||||||
uint8_t * buf_8 = (uint8_t *)&(buf_start[1]);
|
uint8_t * buf_8 = (uint8_t *)&(buf_start[1]);
|
||||||
|
last_packet = buf_8;
|
||||||
|
|
||||||
|
|
||||||
debug_print(NOTICE, "Some bytes from this packet: %2x%2x%2x%2x",
|
debug_print(NOTICE, "Some bytes from this packet: %2x%2x%2x%2x",
|
||||||
@ -103,6 +117,7 @@ static void rtl_irq_handler(struct regs *r) {
|
|||||||
outports(rtl_iobase + RTL_PORT_RXPTR, cur_rx - 16);
|
outports(rtl_iobase + RTL_PORT_RXPTR, cur_rx - 16);
|
||||||
}
|
}
|
||||||
debug_print(NOTICE, "done processing receive");
|
debug_print(NOTICE, "done processing receive");
|
||||||
|
wakeup_queue(rx_wait);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (status & 0x08 || status & 0x04) {
|
if (status & 0x08 || status & 0x04) {
|
||||||
@ -152,6 +167,8 @@ DEFINE_SHELL_FUNCTION(rtl, "rtl8139 experiments") {
|
|||||||
|
|
||||||
fprintf(tty, "RTL iobase: 0x%x\n", rtl_iobase);
|
fprintf(tty, "RTL iobase: 0x%x\n", rtl_iobase);
|
||||||
|
|
||||||
|
rx_wait = list_create();
|
||||||
|
|
||||||
fprintf(tty, "Determining mac address...\n");
|
fprintf(tty, "Determining mac address...\n");
|
||||||
|
|
||||||
uint8_t mac[6];
|
uint8_t mac[6];
|
||||||
@ -227,37 +244,34 @@ DEFINE_SHELL_FUNCTION(rtl, "rtl8139 experiments") {
|
|||||||
outportl(rtl_iobase + RTL_PORT_TXBUF, rtl_tx_phys[0]);
|
outportl(rtl_iobase + RTL_PORT_TXBUF, rtl_tx_phys[0]);
|
||||||
outportl(rtl_iobase + RTL_PORT_TXSTAT, sizeof(_dhcp_packet));
|
outportl(rtl_iobase + RTL_PORT_TXSTAT, sizeof(_dhcp_packet));
|
||||||
|
|
||||||
{
|
sleep_on(rx_wait);
|
||||||
unsigned long s, ss;
|
|
||||||
relative_time(0, 100, &s, &ss);
|
|
||||||
sleep_until((process_t *)current_process, s, ss);
|
|
||||||
switch_task(0);
|
|
||||||
|
|
||||||
fprintf(tty, "Awoken from sleep, checking receive buffer: 0x%x\n", &rtl_rx_buffer[0]);
|
fprintf(tty, "Awoken from sleep, checking receive buffer: %2x %2x %2x %2x\n",
|
||||||
}
|
last_packet[0], last_packet[1], last_packet[2], last_packet[3]);
|
||||||
|
|
||||||
/* Okay, going to evaluate some things */
|
/* Okay, going to evaluate some things */
|
||||||
fprintf(tty, "If I'm right, DHCP wants to assign us %d.%d.%d.%d\n",
|
fprintf(tty, "DHCP Offer: %d.%d.%d.%d\n",
|
||||||
rtl_rx_buffer[0x3A+4],
|
last_packet[0x3A],
|
||||||
rtl_rx_buffer[0x3B+4],
|
last_packet[0x3B],
|
||||||
rtl_rx_buffer[0x3C+4],
|
last_packet[0x3C],
|
||||||
rtl_rx_buffer[0x3D+4]);
|
last_packet[0x3D]);
|
||||||
|
|
||||||
fprintf(tty, "Resending DHCP discover (todo: replace this with a DHCP request)\n");
|
fprintf(tty, "Sending DNS query...\n");
|
||||||
memcpy(rtl_tx_buffer[1], _dhcp_packet, sizeof(_dhcp_packet));
|
memcpy(rtl_tx_buffer[1], _dns_packet, sizeof(_dns_packet));
|
||||||
|
|
||||||
outportl(rtl_iobase + RTL_PORT_TXBUF+4, rtl_tx_phys[1]);
|
outportl(rtl_iobase + RTL_PORT_TXBUF+4, rtl_tx_phys[1]);
|
||||||
outportl(rtl_iobase + RTL_PORT_TXSTAT+4, sizeof(_dhcp_packet));
|
outportl(rtl_iobase + RTL_PORT_TXSTAT+4, sizeof(_dns_packet));
|
||||||
|
|
||||||
{
|
sleep_on(rx_wait);
|
||||||
unsigned long s, ss;
|
|
||||||
relative_time(0, 100, &s, &ss);
|
|
||||||
sleep_until((process_t *)current_process, s, ss);
|
|
||||||
switch_task(0);
|
|
||||||
|
|
||||||
fprintf(tty, "Awoken from sleep, checking receive buffer: 0x%x\n", &rtl_rx_buffer[0]);
|
fprintf(tty, "Awoken from sleep, checking receive buffer: %2x %2x %2x %2x\n",
|
||||||
}
|
last_packet[0], last_packet[1], last_packet[2], last_packet[3]);
|
||||||
|
|
||||||
|
fprintf(tty, "dakko.us. = %d.%d.%d.%d\n",
|
||||||
|
last_packet[0x50],
|
||||||
|
last_packet[0x51],
|
||||||
|
last_packet[0x52],
|
||||||
|
last_packet[0x53]);
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
fprintf(tty, "Going to try to force-send a UDP packet...\n");
|
fprintf(tty, "Going to try to force-send a UDP packet...\n");
|
||||||
|
Loading…
Reference in New Issue
Block a user