Date: Tue, 7 Aug 2007 16:17:00 GMT From: Alexey Tarasov <taleks@FreeBSD.org> To: Perforce Change Reviews <perforce@FreeBSD.org> Subject: PERFORCE change 124834 for review Message-ID: <200708071617.l77GH0or086686@repoman.freebsd.org>
next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=124834 Change 124834 by taleks@taleks_th on 2007/08/07 16:16:08 all: most of all ip4 related uint32_t replaced by PXE_IPADDR. May be usefuil n future. pxe_dhcp: updated pxe_dhcp_query() in case of bootp() call. pxe_core: removed unused functions, updated pxe_core_init(), returned static buffers support. loader.rc: added as example of .rc-script, used during testing of RAM drive loading. Affected files ... .. //depot/projects/soc2007/taleks-pxe_http/Makefile#13 edit .. //depot/projects/soc2007/taleks-pxe_http/httpfs.c#6 edit .. //depot/projects/soc2007/taleks-pxe_http/libi386_mod/Makefile#1 add .. //depot/projects/soc2007/taleks-pxe_http/libi386_mod/pxe.c#3 edit .. //depot/projects/soc2007/taleks-pxe_http/loader_mod/loader.rc#1 add .. //depot/projects/soc2007/taleks-pxe_http/pxe_arp.c#15 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_arp.h#10 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_await.c#4 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_connection.c#12 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_connection.h#9 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_core.c#25 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_core.h#21 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_dhcp.c#8 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_dhcp.h#8 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_dns.c#7 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_dns.h#6 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_filter.c#8 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_filter.h#6 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_http.c#10 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_http.h#7 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_icmp.c#14 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_icmp.h#9 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_ip.c#15 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_ip.h#10 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_segment.c#10 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_sock.c#18 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_sock.h#16 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_tcp.c#13 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_udp.c#10 edit .. //depot/projects/soc2007/taleks-pxe_http/pxe_udp.h#7 edit Differences ... ==== //depot/projects/soc2007/taleks-pxe_http/Makefile#13 (text+ko) ==== @@ -34,4 +34,7 @@ #CFLAGS+= -DPXE_HTTP_DEBUG #CFLAGS+= -DPXE_HTTP_DEBUG_HELL +# define to get more PXE related code and testing functions +CFLAGS+= -DPXE_MORE + .include <bsd.lib.mk> ==== //depot/projects/soc2007/taleks-pxe_http/httpfs.c#6 (text+ko) ==== @@ -87,7 +87,7 @@ pxe_memset(httpfile, 0, sizeof(PXE_HTTP_HANDLE)); - httpfile->ip = pxe_get_ip32(PXE_IP_WWW); + pxe_memcpy(pxe_get_ip(PXE_IP_WWW), &httpfile->addr, sizeof(PXE_IPADDR)); httpfile->offset = 0; httpfile->socket = -1; @@ -100,10 +100,7 @@ /* TODO: may be implement getting name by PTR resource records */ - PXE_IPADDR server; - server.ip = httpfile->ip; - - httpfile->servername = strdup(inet_ntoa(server.ip)); + httpfile->servername = strdup(inet_ntoa(httpfile->addr.ip)); if (httpfile->servername == NULL) { handle_cleanup(httpfile); ==== //depot/projects/soc2007/taleks-pxe_http/libi386_mod/pxe.c#3 (text+ko) ==== @@ -201,13 +201,17 @@ } - if (pxe_get_ip32(PXE_IP_ROOT) == 0) { + const PXE_IPADDR *addr = pxe_get_ip(PXE_IP_ROOT); + + if (addr->ip == 0) { #ifdef PXE_BOOTP_USE_LIBSTAND pxe_dhcp_query(0); - if (pxe_get_ip32(PXE_IP_ROOT) == 0) - pxe_set_ip32(PXE_IP_ROOT, - pxe_get_ip32(PXE_IP_SERVER)); + addr = pxe_get_ip(PXE_IP_ROOT); + + if (addr->ip == 0) + pxe_set_ip(PXE_IP_ROOT, + pxe_get_ip(PXE_IP_SERVER)); #endif if (!rootpath[1]) @@ -220,9 +224,12 @@ if (i && i != FNAME_SIZE && rootpath[i] == ':') { rootpath[i++] = '\0'; - if (inet_addr(&rootpath[0]) != INADDR_NONE) - pxe_set_ip32(PXE_IP_ROOT, - inet_addr(&rootpath[0])); + if (inet_addr(&rootpath[0]) != INADDR_NONE) { + + PXE_IPADDR root_addr; + root_addr.ip = inet_addr(&rootpath[0]); + pxe_set_ip(PXE_IP_ROOT, &root_addr); + } pxe_memcpy(&rootpath[i], &temp[0], strlen(&rootpath[i])+1); @@ -233,7 +240,7 @@ struct in_addr tmp_in; - tmp_in.s_addr = pxe_get_ip32(PXE_IP_ROOT); + tmp_in.s_addr = pxe_get_ip(PXE_IP_ROOT)->ip; #ifdef PXE_DEBUG printf("pxe_open: server addr: %s\n", inet_ntoa(tmp_in)); @@ -241,17 +248,17 @@ setenv("boot.nfsroot.server", inet_ntoa(tmp_in), 1); - tmp_in.s_addr = pxe_get_ip32(PXE_IP_GATEWAY); + tmp_in.s_addr = pxe_get_ip(PXE_IP_GATEWAY)->ip; setenv("boot.netif.gateway", inet_ntoa(tmp_in), 1); #ifdef PXE_DEBUG printf("pxe_open: server path: %s\n", rootpath); printf("pxe_open: gateway ip: %s\n", inet_ntoa(tmp_in)); #endif - tmp_in.s_addr = pxe_get_ip32(PXE_IP_MY); + tmp_in.s_addr = pxe_get_ip(PXE_IP_MY)->ip; setenv("boot.netif.ip", inet_ntoa(tmp_in), 1); - tmp_in.s_addr = pxe_get_ip32(PXE_IP_NETMASK); + tmp_in.s_addr = pxe_get_ip(PXE_IP_NETMASK)->ip; setenv("boot.netif.netmask", inet_ntoa(tmp_in), 1); sprintf(temp, "%6D", pxe_get_mymac(), ":"); @@ -260,11 +267,11 @@ setenv("boot.nfsroot.path", rootpath, 1); #ifdef PXEHTTP_UDP_FOR_LIBSTAND - gateip.s_addr = pxe_get_ip32(PXE_IP_GATEWAY); - rootip.s_addr = pxe_get_ip32(PXE_IP_ROOT); - netmask = pxe_get_ip32(PXE_IP_NETMASK); - myip.s_addr = pxe_get_ip32(PXE_IP_MY); - nameip.s_addr = pxe_get_ip32(PXE_IP_NAMESERVER); + gateip.s_addr = pxe_get_ip(PXE_IP_GATEWAY)->ip; + rootip.s_addr = pxe_get_ip(PXE_IP_ROOT)->ip; + netmask = pxe_get_ip(PXE_IP_NETMASK)->ip; + myip.s_addr = pxe_get_ip(PXE_IP_MY)->ip; + nameip.s_addr = pxe_get_ip(PXE_IP_NAMESERVER)->ip; #endif } } @@ -328,7 +335,10 @@ t_PXENV_UDP_OPEN *udpopen_p = (t_PXENV_UDP_OPEN *)scratch_buffer; bzero(udpopen_p, sizeof(*udpopen_p)); - udpopen_p->src_ip = pxe_get_ip32(PXE_IP_MY); + + const PXE_IPADDR *my = pxe_get_ip(PXE_IP_MY); + udpopen_p->src_ip = my->ip; + pxe_core_call(PXENV_UDP_OPEN); if (udpopen_p->status != 0) { @@ -365,13 +375,14 @@ #ifdef PXE_DEBUG printf("pxe_netif_init(): called.\n"); #endif - uint8_t* mac = pxe_get_mymac(); + uint8_t *mac = pxe_get_mymac(); int i; for (i = 0; i < 6; ++i) desc->myea[i] = mac[i]; - - desc->xid = pxe_get_ip32(PXE_IP_MY); + + const PXE_IPADDR *my = pxe_get_ip(PXE_IP_MY); + desc->xid = my->ip; } static int @@ -458,8 +469,11 @@ inet_ntoa(h->destip), ntohs(h->destport)); #endif void *ipdata = pkt - sizeof(PXE_UDP_PACKET); + + PXE_IPADDR dst; + dst.ip = h->destip.s_addr; - if (!pxe_udp_send(ipdata, h->destip.s_addr, ntohs(h->destport), + if (!pxe_udp_send(ipdata, &dst, ntohs(h->destport), ntohs(h->myport), len + sizeof(PXE_UDP_PACKET))) { printf("sendudp(): failed\n"); ==== //depot/projects/soc2007/taleks-pxe_http/pxe_arp.c#15 (text+ko) ==== @@ -68,11 +68,13 @@ /* filling source related data: client ip & MAC */ pxe_memcpy(pxe_get_mymac(), packet_to_send.body.src_hwaddr, 6); - packet_to_send.body.src_paddr = pxe_get_ip32(PXE_IP_MY); + + const PXE_IPADDR *addr = pxe_get_ip(PXE_IP_MY);; + packet_to_send.body.src_paddr = addr->ip; /* filling entry for own ip/mac*/ pxe_memcpy(pxe_get_mymac(), arp_table[MAX_ARP_ENTRIES].mac, 6); - arp_table[MAX_ARP_ENTRIES].ip4.ip = pxe_get_ip32(PXE_IP_MY); + arp_table[MAX_ARP_ENTRIES].addr.ip = addr->ip; /* setting broadcast target address */ pxe_memset(packet_to_send.body.target_hwaddr, 0xff, 6); @@ -96,7 +98,7 @@ for (; entry < MAX_ARP_ENTRIES + 1; ++entry) { - if (arp_table[entry].ip4.ip == ip) { + if (arp_table[entry].addr.ip == ip) { uint8_t *mac = &arp_table[entry].mac[0]; #ifdef PXE_ARP_DEBUG_HELL @@ -124,21 +126,18 @@ for (; entry < limit; ++entry) { - PXE_IPADDR ip; - uint8_t *mac = arp_table[entry].mac; - ip.ip = arp_table[entry].ip4.ip; - - if ( (ip.ip == 0) || (mac == NULL) ) + if ( (arp_table[entry].addr.ip == 0) || + (arp_table[entry].mac == NULL) ) continue; - printf("%d.%d.%d.%d\t%2x:%2x:%2x:%2x:%2x:%2x\n", - ip.octet[0], ip.octet[1], ip.octet[2], ip.octet[3], - mac[0], mac[1], mac[2], mac[3], mac[4], mac[5] - ); + printf("%s\t%6D\n", + inet_ntoa(arp_table[entry].addr.ip), + arp_table[entry].mac, ":"); } } -#endif +#endif /* PXE_MORE */ + /* * pxe_arp_protocol() - process received arp packet, this function is called in * style of pxe_protocol_call function type, but last @@ -162,12 +161,14 @@ uint8_t *mac_src = arp_reply->body.src_hwaddr; uint8_t *mac_dst = arp_reply->body.target_hwaddr; PXE_IPADDR ip4_src; - PXE_IPADDR ip4_dst; + PXE_IPADDR ip4_dst; + + const PXE_IPADDR *addr = pxe_get_ip(PXE_IP_MY); ip4_src.ip = arp_reply->body.src_paddr; ip4_dst.ip = arp_reply->body.target_paddr; - if (ip4_src.ip == pxe_get_ip32(PXE_IP_MY)) { + if (ip4_src.ip == addr->ip) { /* got broadcast send by us */ #ifdef PXE_ARP_DEBUG_HELL printf("arp request from myself ignored.\n"); @@ -176,21 +177,15 @@ } #ifdef PXE_ARP_DEBUG - printf("arp request from %x:%x:%x:%x:%x:%x/%d.%d.%d.%d\n\t" - " to: %x:%x:%x:%x:%x:%x/%d.%d.%d.%d\n", - mac_src[0], mac_src[1], mac_src[2], - mac_src[3], mac_src[4], mac_src[5], - ip4_src.octet[0], ip4_src.octet[1], - ip4_src.octet[2], ip4_src.octet[3], - mac_dst[0], mac_dst[1], mac_dst[2], - mac_dst[3], mac_dst[4], mac_dst[5], - ip4_dst.octet[0], ip4_dst.octet[1], - ip4_dst.octet[2], ip4_dst.octet[3] - ); + printf("arp request from %6D/%s\n\t", + mac_src, ":", inet_ntoa(ip4_src.ip)); + + printf("to: %6D/%s\n", + mac_dst, ":", inet_ntoa(ip4_dst.ip)); #endif /* somebody is looking for us */ - if (ip4_dst.ip == arp_table[MAX_ARP_ENTRIES].ip4.ip) { + if (ip4_dst.ip == arp_table[MAX_ARP_ENTRIES].addr.ip) { pxe_memcpy(arp_reply->body.src_hwaddr, packet_to_send.body.target_hwaddr, 6); @@ -262,7 +257,7 @@ pxe_memcpy(&arp_reply->body.src_hwaddr, &arp_table[arp_usage % MAX_ARP_ENTRIES].mac, 6); - arp_table[arp_usage % MAX_ARP_ENTRIES].ip4.ip = + arp_table[arp_usage % MAX_ARP_ENTRIES].addr.ip = arp_reply->body.src_paddr; ++arp_usage; @@ -325,7 +320,7 @@ switch (function) { case PXE_AWAIT_STARTTRY: /* handle start of new try */ - if (!pxe_arp_send_whois(wait_data->ip)) { + if (!pxe_arp_send_whois(wait_data->addr.ip)) { /* failed to send request, try once more * after waiting a little */ @@ -338,7 +333,7 @@ /* check if ARP protocol was called and * arp_table updated */ - res = pxe_arp_table_search(wait_data->ip); + res = pxe_arp_table_search(wait_data->addr.ip); if (res != NULL) { wait_data->mac = res; return (PXE_AWAIT_COMPLETED); @@ -370,9 +365,9 @@ * not NULL - pointer to MAC address */ const MAC_ADDR * -pxe_arp_ip4mac(uint32_t ip) +pxe_arp_ip4mac(const PXE_IPADDR *addr) { - const MAC_ADDR *res = pxe_arp_table_search(ip); + const MAC_ADDR *res = pxe_arp_table_search(addr->ip); if (res != NULL) return (res); @@ -381,7 +376,7 @@ #endif PXE_ARP_WAIT_DATA wait_data; - wait_data.ip = ip; + wait_data.addr.ip = addr->ip; wait_data.mac = NULL; pxe_await(pxe_arp_await, PXE_MAX_ARP_TRY, PXE_TIME_TO_DIE, &wait_data); ==== //depot/projects/soc2007/taleks-pxe_http/pxe_arp.h#10 (text+ko) ==== @@ -52,7 +52,7 @@ #define PXE_ARP_SNIFF typedef struct pxe_arp_entry { - PXE_IPADDR ip4; + PXE_IPADDR addr; MAC_ADDR mac; } PXE_ARP_ENTRY; @@ -61,7 +61,7 @@ void pxe_arp_init(); /* find MAC by provided ip */ -const MAC_ADDR *pxe_arp_ip4mac(uint32_t ip); +const MAC_ADDR *pxe_arp_ip4mac(const PXE_IPADDR *addr); /* protocol handler for received packets */ int pxe_arp_protocol(PXE_PACKET *pack, uint8_t function); @@ -99,7 +99,7 @@ } __packed PXE_ARP_PACK_DATA; typedef struct pxe_arp_wait_data { - uint32_t ip; + PXE_IPADDR addr; const MAC_ADDR *mac; } PXE_ARP_WAIT_DATA; ==== //depot/projects/soc2007/taleks-pxe_http/pxe_await.c#4 (text+ko) ==== @@ -116,4 +116,3 @@ */ return (0); } - ==== //depot/projects/soc2007/taleks-pxe_http/pxe_connection.c#12 (text+ko) ==== @@ -252,11 +252,11 @@ connection->dst_port = filter->src_port; connection->src_port = filter->dst_port; - connection->dst_ip = filter->src_ip; + connection->dst.ip = filter->src.ip; connection->next_recv = 0; /* NOTE: need to make more correct initial number */ - connection->iss = (filter->src_ip + filter->dst_ip) + + connection->iss = (filter->src.ip + filter->dst.ip) + (uint32_t)pxe_get_secs(); connection->next_send = connection->iss; @@ -688,4 +688,4 @@ connection->iss, connection->irs); } } -#endif+#endif /* PXE_MORE */ ==== //depot/projects/soc2007/taleks-pxe_http/pxe_connection.h#9 (text+ko) ==== @@ -79,7 +79,7 @@ uint16_t src_port; /* source port */ uint16_t dst_port; /* destination port */ - uint32_t dst_ip; /* destination ip */ + PXE_IPADDR dst; /* destination ip */ PXE_BUFFER *recv; /* recieve buffer */ PXE_BUFFER *send; /* send buffer */ ==== //depot/projects/soc2007/taleks-pxe_http/pxe_core.c#25 (text+ko) ==== @@ -46,22 +46,22 @@ * the only difference - installation of isr, that was not needed in pxe.c. */ -/* calls PXE/UNDI API, registers of processor must be filled in with - * appropriate values. - */ -/* static int pxe_core_call(int func); */ /* stores data in packet */ static int pxe_core_recieve(PXE_PACKET *pack, void *data, size_t size); uint8_t *scratch_buffer = NULL; uint8_t *data_buffer = NULL; +#ifdef PXE_CORE_STATIC_BUFFERS +static uint8_t static_scratch_buffer[PXE_BUFFER_SIZE]; +static uint8_t static_data_buffer[PXE_BUFFER_SIZE]; +#endif + #ifdef PXE_EXCLUSIVE static uint8_t exclusive_protocol = 0; #endif static pxenv_t *pxenv = NULL; /* PXENV+ */ static pxe_t *pxe = NULL; /* !PXE */ -/* static BOOTPLAYER* bootplayer; /* pointer PXE Cached information. */ /* pxe core structures*/ /* current processing packet */ @@ -76,61 +76,6 @@ static int pxe_state = PXE_DOWN; -/* pxe_core_undi_startup() - performs UNDI startup call during pxe_core_init() - * in: - * none - * out: - * 1 - success - * 0 - failed - */ -int -pxe_core_undi_startup() -{ - t_PXENV_UNDI_STARTUP *undi_startup = - (t_PXENV_UNDI_STARTUP *)scratch_buffer; - -#ifdef PXE_CORE_DEBUG - printf("pxe_core_undi_startup(): started\n"); -#endif - - undi_startup->Status = 0; - - int status = pxe_core_call(PXENV_UNDI_STARTUP); - - if (!status) - printf("pxe_core_undi_startup(): status 0x%x\n", - undi_startup->Status); - - return (status); -} - -/* pxe_core_undi_init() - performs UNDI initialization - * in: - * none - * out: - * 1 - success - * 0 - failed - */ -int pxe_core_undi_init() -{ - t_PXENV_UNDI_INITIALIZE *undi_init = - (t_PXENV_UNDI_INITIALIZE *)scratch_buffer; - -#ifdef PXE_CORE_DEBUG - printf("pxe_core_undi_init(): started\n"); -#endif - - pxe_memset(undi_init, 0, sizeof(t_PXENV_UNDI_INITIALIZE)); - - int status = pxe_core_call(PXENV_UNDI_INITIALIZE); - - if (!status) - printf("pxe_core_undi_init(): status 0x%x\n", - undi_init->Status); - - return (status); -} - /* pxe_core_init() - performs initialization of all PXE related code * in: * pxenv_p - pointer to PXENV+ structure @@ -162,6 +107,7 @@ pxenv = pxenv_p; pxe = pxe_p; +#ifndef PXE_CORE_STATIC_BUFFERS /* 0. initing scratch and data buffers */ data_buffer = pxe_alloc(PXE_BUFFER_SIZE); @@ -175,7 +121,10 @@ pxe_free(data_buffer); return (0); } - +#else + data_buffer = static_data_buffer; + scratch_buffer = static_scratch_buffer; +#endif /* 1. determine PXE API entry point */ if(pxenv_p == NULL) return (0); @@ -262,9 +211,9 @@ /* getting Boot Server Discovery reply */ /* pointer to PXE Cached information. */ - BOOTPLAYER* bootplayer = data_buffer; + BOOTPLAYER* bootplayer = (BOOTPLAYER *)data_buffer; + gci_p->PacketType = PXENV_PACKET_TYPE_BINL_REPLY; - gci_p->BufferSize = sizeof(BOOTPLAYER); gci_p->Buffer.segment = VTOPSEG(bootplayer); gci_p->Buffer.offset = VTOPOFF(bootplayer); @@ -302,30 +251,37 @@ } /* showing information about NIC */ - PXE_IPADDR nic_ip; - - nic_ip.ip = bootplayer->yip; /* my ip */ - printf("my ip: %d.%d.%d.%d\n", - nic_ip.octet[0], nic_ip.octet[1], nic_ip.octet[2], nic_ip.octet[3]); + PXE_IPADDR addr; + addr.ip = bootplayer->yip; /* my ip */ + + printf("my ip: %s\n", inet_ntoa(addr.ip)); /* my MAC */ pxe_memcpy(&bootplayer->CAddr, &nic_mac, MAC_ADDR_LEN); printf("my MAC: %6D\n", nic_mac, ":"); /* setting default ips*/ - pxe_set_ip32(PXE_IP_MY, bootplayer->yip); /* nic ip */ - pxe_set_ip32(PXE_IP_SERVER, bootplayer->sip); /* boot server ip */ + pxe_set_ip(PXE_IP_MY, &addr); /* nic ip */ + + addr.ip = bootplayer->sip; /* boot server ip */ + pxe_set_ip(PXE_IP_SERVER, &addr); + + /* setting next to default ip (boot server ip) */ + /* nameserver ip*/ + pxe_set_ip(PXE_IP_NAMESERVER, &addr); + /* gateway ip */ + pxe_set_ip(PXE_IP_GATEWAY, &addr); + - /* nameserver ip, default to 192.168.0.1 */ - pxe_set_ip32(PXE_IP_NAMESERVER, 0x0100a8c0); - /* gateway ip, default to 192.168.0.1 */ - pxe_set_ip32(PXE_IP_GATEWAY, 0x0100a8c0); + /* web server */ + addr.ip = 0; + pxe_set_ip(PXE_IP_WWW, &addr); + + addr.ip = 0xffffffff; /* netmask, default to 255.255.255.0 */ - pxe_set_ip32(PXE_IP_NETMASK, 0x00ffffff); + pxe_set_ip(PXE_IP_NETMASK, &addr); /* broadcast address, default to 255.255.255.255 */ - pxe_set_ip32(PXE_IP_BROADCAST, 0xffffffff); - /* web server */ - pxe_set_ip32(PXE_IP_WWW, 0x0); + pxe_set_ip(PXE_IP_BROADCAST, &addr); /* initing modules */ pxe_arp_init(); @@ -345,7 +301,7 @@ pxe_dhcp_query(bootplayer->ident); #endif /* initing route tables, using DHCP reply data */ - pxe_ip_route_init(pxe_get_ip32(PXE_IP_GATEWAY)); + pxe_ip_route_init(pxe_get_ip(PXE_IP_GATEWAY)); #ifdef PXE_CORE_DEBUG printf("pxe_core_init(): ended.\n"); @@ -492,13 +448,14 @@ t_PXENV_UNDI_SHUTDOWN *undi_shutdown_p = (t_PXENV_UNDI_SHUTDOWN *)scratch_buffer; - -/* pxe_core_call(PXENV_UNDI_SHUTDOWN); +/* + pxe_core_call(PXENV_UNDI_SHUTDOWN); pxe_core_call(PXENV_UNLOAD_STACK); */ +#ifndef PXE_CORE_STATIC_BUFFERS pxe_free(scratch_buffer); pxe_free(data_buffer); - +#endif /* make pxe_core_call() unavailable */ pxe_state = PXE_DOWN; @@ -1030,22 +987,22 @@ return (const MAC_ADDR *)&nic_mac; } -/* pxe_get_ip32() - returns ip related data, specified by id parameter +/* pxe_get_ip() - returns ip related data, specified by id parameter * in: * id - id of needed data (PXE_IP_ constants) * out: * associated with this id value */ -uint32_t -pxe_get_ip32(uint8_t id) +const PXE_IPADDR * +pxe_get_ip(uint8_t id) { if (id < PXE_IP_MAX) - return (core_ips[id].ip); + return (&core_ips[id]); return (0); } -/* pxe_set_ip32() - sets ip related data, specified by id parameter +/* pxe_set_ip() - sets ip related data, specified by id parameter * in: * id - id of needed data (PXE_IP_ constants) * new_ip - new uint32_t data @@ -1053,10 +1010,10 @@ * none */ void -pxe_set_ip32(uint8_t id, uint32_t new_ip) +pxe_set_ip(uint8_t id, const PXE_IPADDR *new_ip) { if (id < PXE_IP_MAX) { - core_ips[id].ip = new_ip; + pxe_memcpy(new_ip, &core_ips[id], sizeof(PXE_IPADDR)); } } ==== //depot/projects/soc2007/taleks-pxe_http/pxe_core.h#21 (text+ko) ==== @@ -37,9 +37,16 @@ #include <stddef.h> #include "../libi386/pxe.h" +#include "pxe_ip.h" #define PXE_BUFFER_SIZE 0x0800 +/* define to use statically allocated buffers */ +#define PXE_CORE_STATIC_BUFFERS + +/* packet states for packets, used by pxe_core. + * Currently (only one packet at any time) - is unused. + */ #define PXE_PACKET_STATE_FREE 0 #define PXE_PACKET_STATE_USING 1 @@ -134,8 +141,8 @@ #define PXE_IP_WWW 7 #define PXE_IP_ROOT 7 #define PXE_IP_MAX 8 -uint32_t pxe_get_ip32(uint8_t id); -void pxe_set_ip32(uint8_t id, uint32_t ip); +const PXE_IPADDR *pxe_get_ip(uint8_t id); +void pxe_set_ip(uint8_t id, const PXE_IPADDR *ip); /* returns time in seconds */ time_t pxe_get_secs(); ==== //depot/projects/soc2007/taleks-pxe_http/pxe_dhcp.c#8 (text+ko) ==== @@ -29,6 +29,7 @@ #include "pxe_core.h" #include "pxe_dhcp.h" +#include "pxe_ip.h" #ifdef PXE_BOOTP_USE_LIBSTAND #include <netinet/in.h> @@ -96,19 +97,19 @@ case PXE_DHCP_OPT_NETMASK: printf("netmask: %d.%d.%d.%d\n", *(p + 1), *(p + 2), *(p + 3), *(p + 4)); - result->netmask = *((uint32_t *)(p + 1)); + result->netmask.ip = *((uint32_t *)(p + 1)); break; case PXE_DHCP_OPT_ROUTER: printf("first router: %d.%d.%d.%d\n", *(p + 1), *(p + 2), *(p + 3), *(p + 4)); - result->gw = *((uint32_t *)(p + 1)); + result->gw.ip = *((uint32_t *)(p + 1)); break; case PXE_DHCP_OPT_NAMESERVER: printf("first nameserver: %d.%d.%d.%d\n", *(p + 1), *(p + 2), *(p + 3), *(p + 4)); - result->ns = *((uint32_t *)(p + 1)); + result->ns.ip = *((uint32_t *)(p + 1)); break; case PXE_DHCP_OPT_TYPE: @@ -122,7 +123,7 @@ case PXE_DHCP_OPT_WWW_SERVER: printf("www server ip: %d.%d.%d.%d\n", *(p + 1), *(p + 2), *(p + 3), *(p + 4)); - result->www = *((uint32_t *)(p + 1)); + result->www.ip = *((uint32_t *)(p + 1)); break; case PXE_DHCP_OPT_ROOTPATH: @@ -154,7 +155,7 @@ case PXE_DHCP_OPT_BROADCAST_IP: printf("broadcast: %d.%d.%d.%d\n", *(p + 1), *(p + 2), *(p + 3), *(p + 4)); - result->bcast_addr = *((uint32_t *)(p + 1)); + result->bcast_addr.ip = *((uint32_t *)(p + 1)); break; case PXE_DHCP_OPT_ID: @@ -205,7 +206,9 @@ dhcp_hdr->hops = 0; dhcp_hdr->secs = 0; dhcp_hdr->xid = wait_data->xid; - dhcp_hdr->ciaddr = pxe_get_ip32(PXE_IP_MY); + + const PXE_IPADDR *my = pxe_get_ip(PXE_IP_MY); + dhcp_hdr->ciaddr = my->ip; dhcp_hdr->magic = htonl(PXE_MAGIC_DHCP); pxe_memcpy(pxe_get_mymac(), dhcp_hdr->chaddr, dhcp_hdr->hlen); @@ -233,10 +236,10 @@ options = add_option(options, PXE_DHCP_OPT_TYPE, &message_type, 1); /* requesting for my ip */ - uint32_t client_ip = pxe_get_ip32(PXE_IP_MY); + const PXE_IPADDR *client_ip = pxe_get_ip(PXE_IP_MY); options = add_option(options, PXE_DHCP_OPT_REQUEST_IP, - &client_ip, sizeof(client_ip)); + &(client_ip->ip), sizeof(client_ip->ip)); /* end of options */ options = add_option(options, PXE_DHCP_OPT_END, NULL, 0); @@ -258,7 +261,10 @@ return (0); } - if (send_size != pxe_sendto(socket, PXE_IP_BCAST, PXE_DHCP_SERVER_PORT, + PXE_IPADDR bcast; + bcast.ip = PXE_IP_BCAST; + + if (send_size != pxe_sendto(socket, &bcast, PXE_DHCP_SERVER_PORT, wait_data->data, send_size)) { printf("dhcp_send_request(): failed to send DHCP request.\n"); @@ -314,20 +320,20 @@ } /* if successfuly parsed, setting appropriate ip data */ - if (opts_result.ns) - pxe_set_ip32(PXE_IP_NAMESERVER, opts_result.ns); + if (opts_result.ns.ip) + pxe_set_ip(PXE_IP_NAMESERVER, &opts_result.ns); - if (opts_result.gw) - pxe_set_ip32(PXE_IP_GATEWAY, opts_result.gw); + if (opts_result.gw.ip) + pxe_set_ip(PXE_IP_GATEWAY, &opts_result.gw); - if (opts_result.netmask) - pxe_set_ip32(PXE_IP_NETMASK, opts_result.netmask); + if (opts_result.netmask.ip) + pxe_set_ip(PXE_IP_NETMASK, &opts_result.netmask); - if (opts_result.bcast_addr) - pxe_set_ip32(PXE_IP_BROADCAST, opts_result.bcast_addr); + if (opts_result.bcast_addr.ip) + pxe_set_ip(PXE_IP_BROADCAST, &opts_result.bcast_addr); - if (opts_result.www) - pxe_set_ip32(PXE_IP_WWW, opts_result.www); + if (opts_result.www.ip) + pxe_set_ip(PXE_IP_WWW, &opts_result.www); if (opts_result.rootpath[0]) strcpy(PXENFSROOTPATH, opts_result.rootpath); @@ -423,10 +429,28 @@ printf("pxe_dhcp_query(): starting libstand bootp()\n"); bootp(pxe_sock, BOOTP_PXE); - pxe_set_ip32(PXE_IP_NAMESERVER, nameip.s_addr); - pxe_set_ip32(PXE_IP_GATEWAY, gateip.s_addr); - pxe_set_ip32(PXE_IP_NETMASK, netmask); - pxe_set_ip32(PXE_IP_ROOT, rootip.s_addr); + /* setting pxe_core variables */ + PXE_IPADDR addr; + + addr.ip = nameip.s_addr; + pxe_set_ip(PXE_IP_NAMESERVER, &addr); + + addr.ip = netmask; + pxe_set_ip(PXE_IP_NETMASK, &addr); + + addr.ip = rootip.s_addr; + pxe_set_ip(PXE_IP_ROOT, &addr); + + /* "network route". direct connect for those addresses */ + pxe_ip_route_add(pxe_get_ip(PXE_IP_MY), netmask, NULL); + + addr.ip = gateip.s_addr; + pxe_set_ip(PXE_IP_GATEWAY, &addr); + + /* need update gateway information, cause it's already set to default */ + pxe_ip_route_default(&addr); + + } #endif /* PXE_BOOTP_USE_LIBSTAND */ ==== //depot/projects/soc2007/taleks-pxe_http/pxe_dhcp.h#8 (text+ko) ==== @@ -37,7 +37,7 @@ /* define if want use bootp() instead of functions, provided by * pxe_dhcp module */ -/* #define PXE_BOOTP_USE_LIBSTAND */ +#define PXE_BOOTP_USE_LIBSTAND /* DHCP request/reply packet header */ typedef struct pxe_dhcp_hdr { @@ -123,11 +123,11 @@ } PXE_DHCP_WAIT_DATA; typedef struct pxe_dhcp_parse_result { - uint32_t netmask; - uint32_t bcast_addr; - uint32_t ns; - uint32_t gw; - uint32_t www; + PXE_IPADDR netmask; + PXE_IPADDR bcast_addr; + PXE_IPADDR ns; + PXE_IPADDR gw; + PXE_IPADDR www; char rootpath[256]; uint8_t message_type; } PXE_DHCP_PARSE_RESULT; ==== //depot/projects/soc2007/taleks-pxe_http/pxe_dns.c#7 (text+ko) ==== @@ -33,6 +33,8 @@ #include "pxe_ip.h" #include "pxe_sock.h" +static PXE_DNS_WAIT_DATA static_wait_data; + /* write_question_for()- writes labels for provided domain name * in: * question - where to write @@ -85,18 +87,19 @@ /* create_dns_packet()- creates DNS request packet * in: - * name - domain name to resolve - * data - buffer for request packet. - * max_size - size of buffer [NOT IMPLEMENTED] + * wd - pointer to wait data structure * id - request id to distinguish requests * out: * 0 - failed * >0 - size of created packet */ int -create_dns_packet(char *name, void *data, int max_size, uint16_t id, - uint16_t query_type) +create_dns_packet(PXE_DNS_WAIT_DATA *wd, uint16_t id, uint16_t query_type) { + char *name = wd->name; + void *data = wd->data; + int max_size = wd->size; + PXE_DNS_REQUEST_HDR *request = (PXE_DNS_REQUEST_HDR *)data; pxe_memset(request, 0, sizeof(PXE_DNS_REQUEST_HDR)); @@ -175,17 +178,19 @@ /* parse_dns_reply() - parses reply from DNS server * in: - * data - pointer to buffer, containing packet data - * size - buffer size - * name - domain name to resolve - * canme - where to store cname if found. + * wd - pointer to waiting data structure * out: * 0 - parsing failed, or packet has no information about our domain - * ip - success, 32bit ip4 address + * 1 - success, wait_data->result contains ip */ -uint32_t -parse_dns_reply(uint8_t* data, int size, char *name, uint16_t id, uint8_t *cname) +int +parse_dns_reply(PXE_DNS_WAIT_DATA *wd) { + uint8_t *data = wd->data; + int size = wd->size; + char *name = wd->name; + uint16_t id = wd->id; + uint8_t *cname = wd->cname; cname[0] = 0; @@ -331,19 +336,15 @@ } /* answer points to rdata = ip4 */ - PXE_IPADDR ret; - - ret.octet[0] = answer[0]; - ret.octet[1] = answer[1]; - ret.octet[2] = answer[2]; - ret.octet[3] = answer[3]; + + wd->result.octet[0] = answer[0]; + wd->result.octet[1] = answer[1]; + wd->result.octet[2] = answer[2]; + wd->result.octet[3] = answer[3]; #ifdef PXE_DEBUG - printf(" = %d.%d.%d.%d\n", - ret.octet[0], ret.octet[1], - ret.octet[2], ret.octet[3] - ); + printf(" = %s\n", inet_ntoa(wd->result.ip)); #endif - return ret.ip; + return (1); } #ifdef PXE_DEBUG @@ -433,8 +434,8 @@ return (0); } - uint16_t size = create_dns_packet(wait_data->name, wait_data->data, - wait_data->size, wait_data->id, PXE_DNS_QUERY_A); + uint16_t size = create_dns_packet(wait_data, wait_data->id, + PXE_DNS_QUERY_A); if (size == 0) { printf("dns_request(): failed to create request.\n"); @@ -442,7 +443,7 @@ return (0); } - if (size != pxe_sendto(socket, pxe_get_ip32(PXE_IP_NAMESERVER), 53, + if (size != pxe_sendto(socket, pxe_get_ip(PXE_IP_NAMESERVER), 53, wait_data->data, size)) { printf("dns_request(): failed to send DNS request.\n"); @@ -494,12 +495,9 @@ printf("dns_await(): Received DNS reply (%d bytes).\n", size); >>> TRUNCATED FOR MAIL (1000 lines) <<<
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200708071617.l77GH0or086686>