New IPC interface, lwip sends data to rndis

This commit is contained in:
songyanguang 2024-08-13 14:43:22 +08:00
parent 84ab3dff35
commit aaceb82386
11 changed files with 129 additions and 15 deletions

View File

@ -1,3 +1,3 @@
SRC_DIR := components
SRC_DIR := components usb_service
include $(KERNEL_ROOT)/compiler.mk

View File

@ -36,6 +36,7 @@ INC_DIR = -I$(KERNEL_ROOT)/services/drivers/usb/ \
-I$(KERNEL_ROOT)/services/drivers/usb/components/osal \
-I$(KERNEL_ROOT)/services/drivers/usb/components/port \
-I$(KERNEL_ROOT)/services/drivers/usb/components/port/xhci \
-I$(KERNEL_ROOT)/services/drivers/usb/usb_service \
-I$(KERNEL_ROOT)/services//semaphore \
-I$(KERNEL_ROOT)/services/lib/ipc \
-I$(KERNEL_ROOT)/services/lib/memory \

View File

@ -0,0 +1,10 @@
include $(KERNEL_ROOT)/services/drivers/usb/components/usb.mk
objs = usb_host.o
all: ${objs}
@echo "generate $^"
%.o: %.c
@echo "cc $^"
@${cc} ${cflags} ${c_useropts} ${INC_DIR} -o $@ -c $^

View File

@ -0,0 +1,13 @@
#include "libipc.h"
#include "rndis_service.h"
IPC_INTERFACE(Ipc_usbh_rndis_eth_tx, 2, dataptr, tot_len, *(size_t *)tot_len, sizeof(size_t));
int ipc_usbh_rndis_eth_tx(struct Session* session, void *dataptr, size_t tot_len){
return IPC_CALL(Ipc_usbh_rndis_eth_tx)(session, dataptr, &tot_len);
}
IPC_INTERFACE(Ipc_usbh_rndis_eth_control, 3, cmd, args, len, sizeof(int), *(size_t *)len, sizeof(size_t));
int ipc_usbh_rndis_eth_control(struct Session* session, int cmd, void *args, size_t len){
return IPC_CALL(Ipc_usbh_rndis_eth_control)(session, &cmd, args, &len);
}

View File

@ -0,0 +1,12 @@
#ifndef RNDIS_SERVICE_H_
#define RNDIS_SERVICE_H_
#include "libipc.h"
IPC_SERVICES(IpcRndisServer, Ipc_usbh_rndis_eth_tx, Ipc_usbh_rndis_eth_control);
int ipc_usbh_rndis_eth_tx(struct Session* session, void *dataptr, size_t tot_len);
int ipc_usbh_rndis_eth_control(struct Session* session, int cmd, void *args, size_t len);
#endif

View File

@ -1,6 +1,37 @@
#include "usb_host.h"
int main(){
return 0;
}
#include "usb_host.h"
#include "usyscall.h"
#include "libipc.h"
#include "rndis_service.h"
/* IPC rndis server */
int IPC_DO_SERVE_FUNC(Ipc_usbh_rndis_eth_tx)(void *dataptr, size_t *tot_len){
return usbh_rndis_eth_tx(dataptr, *tot_len);
}
int IPC_DO_SERVE_FUNC(Ipc_usbh_rndis_eth_control)(int *cmd, void *args, size_t *len){
return usbh_rndis_eth_control(*cmd, args, *len);
}
IPC_SERVER_INTERFACE(Ipc_usbh_rndis_eth_tx, 2);
IPC_SERVER_INTERFACE(Ipc_usbh_rndis_eth_control, 3);
IPC_SERVER_REGISTER_INTERFACES(IpcRndisServer, 2, Ipc_usbh_rndis_eth_tx, Ipc_usbh_rndis_eth_control);
int ipc_rndis_server_init(void)
{
if (register_server("RndisServer") < 0) {
printf("register server name: %s failed.\n", "RndisServer");
return -1;
}
ipc_server_loop(&IpcRndisServer);
return 0;
}
/* usb main*/
int main(){
ipc_rndis_server_init();
return 0;
}

View File

@ -1,9 +1,8 @@
#ifndef USB_HOST_H_
#define USB_HOST_H_
#include <usb_osal.h>
int usbh_rndis_eth_tx(void *dataptr, size_t tot_len);
int usbh_rndis_eth_control(int cmd, void *args, size_t len);
#endif

View File

@ -53,10 +53,12 @@ arch_usyscall = $(KERNEL_ROOT)/services/app/arch_usyscall.o
session = $(KERNEL_ROOT)/services/app/session.o
libipc = $(KERNEL_ROOT)/services/app/libipc.o
libsem = $(KERNEL_ROOT)/services/app/libsemaphore.o
librndis = $(KERNEL_ROOT)/services/net/net_server/rndis_service.o
lwip: COMPILER lwip_server.o | bin
@${ld} ${user_ldflags} -e main -o $@ ${sys} ${api} ${core} ${ipv4} ${netif} lwip_server.o ${libserial} ${printf} ${libmem} ${usyscall} ${arch_usyscall} ${session} ${libipc} ${libsem} ${board_specs}
@${ld} ${user_ldflags} -e main -o $@ ${librndis} ${sys} ${api} ${core} ${ipv4} ${netif} lwip_server.o ${libserial} ${printf} ${libmem} ${usyscall} ${arch_usyscall} ${session} ${libipc} ${libsem} ${board_specs}
@${objdump} -S $@ > $@.asm
@$(ar) -r liblwip.a ${sys} ${api} ${core} ${ipv4} ${netif}
@$(ar) -r liblwip.a ${librndis} ${sys} ${api} ${core} ${ipv4} ${netif}
@mv *.o bin
@mv $@ $(KERNEL_ROOT)/services/app
@mv $@.asm $(KERNEL_ROOT)/services/app

View File

@ -1,5 +1,6 @@
include $(KERNEL_ROOT)/services/net/net_server/lwip.mk
objs += sys_arch.o ethernetif.o
objs += $(KERNEL_ROOT)/services/drivers/usb/usb_service/rndis_service.o
arch: ${objs}

View File

@ -20,10 +20,15 @@
#include "lwip/ethip6.h"
#include "lwip/etharp.h"
#include "libserial.h"
#include "rndis_service.h"
/* Define those to better describe your network interface. */
#define IFNAME0 'e'
#define IFNAME1 'n'
/* IPC rndis client */
struct Session *g_session_rndis = NULL;
/**
* In this function, the hardware should be initialized.
* Called from ethernetif_init().
@ -80,6 +85,21 @@ void print_packet_data(const char *packet_data, int length) {
}
}
}
/**
* This function should do the actual transmission of the packet.
*
* @param dataptr pointer to the actual data in the buffer
* @param tot_len the length of this buffer
* @return ERR_OK if the send is success
* any other err_t on error
*/
int usbh_rndis_eth_tx(void *dataptr, size_t tot_len)
{
struct Session* session = g_session_rndis;
return ipc_usbh_rndis_eth_tx(session, dataptr, tot_len);;
}
/**
* This function should do the actual transmission of the packet. The packet is
* contained in the pbuf that is passed to the function. This pbuf
@ -104,8 +124,11 @@ static err_t low_level_output(struct netif *netif, struct pbuf *p)
#endif
pbuf_copy_partial(p, buf, p->tot_len, 0);
print_packet_data(buf, p->tot_len);
usbh_rndis_eth_tx(buf, p->tot_len);
return ERR_OK;
}
@ -149,6 +172,26 @@ void ethernetif_input(struct netif *netif)
}
}
/**
* In this function, get session info.
* Called from ethernetif_init().
*
* @return lwIP error code
*/
int ipc_rndis_client_init(void)
{
struct Session *session;
session = mem_malloc(sizeof(struct Session));
if(connect_session(session, "RndisServer", 4096) < 0) {
printf("connect session failed\n");
return ERR_IF;
}
g_session_rndis = session;
return ERR_OK;
}
/**
* Should be called at the beginning of the program to set up the
* network interface. It calls the function low_level_init() to do the
@ -190,6 +233,7 @@ err_t ethernetif_init(struct netif *netif)
/* initialize the hardware */
low_level_init(netif);
ipc_rndis_client_init();
return ERR_OK;
}

View File

@ -41,4 +41,5 @@ INC_DIR = -I$(KERNEL_ROOT)/services/net/libnet \
-I$(KERNEL_ROOT)/services/lib/serial \
-I$(KERNEL_ROOT)/services/lib/usyscall \
-I$(KERNEL_ROOT)/services/boards/$(BOARD) \
-I$(KERNEL_ROOT)/services/app
-I$(KERNEL_ROOT)/services/app \
-I$(KERNEL_ROOT)/services/drivers/usb/usb_service