net: convert vde to NetClientInfo
Signed-off-by: Mark McLoughlin <markmc@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
		
							parent
							
								
									ce20b5be50
								
							
						
					
					
						commit
						b4e859c6a1
					
				
							
								
								
									
										45
									
								
								net/vde.c
								
								
								
								
							
							
						
						
									
										45
									
								
								net/vde.c
								
								
								
								
							| 
						 | 
				
			
			@ -34,7 +34,7 @@
 | 
			
		|||
#include "sysemu.h"
 | 
			
		||||
 | 
			
		||||
typedef struct VDEState {
 | 
			
		||||
    VLANClientState *vc;
 | 
			
		||||
    VLANClientState nc;
 | 
			
		||||
    VDECONN *vde;
 | 
			
		||||
} VDEState;
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -46,13 +46,13 @@ static void vde_to_qemu(void *opaque)
 | 
			
		|||
 | 
			
		||||
    size = vde_recv(s->vde, (char *)buf, sizeof(buf), 0);
 | 
			
		||||
    if (size > 0) {
 | 
			
		||||
        qemu_send_packet(s->vc, buf, size);
 | 
			
		||||
        qemu_send_packet(&s->nc, buf, size);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static ssize_t vde_receive(VLANClientState *vc, const uint8_t *buf, size_t size)
 | 
			
		||||
static ssize_t vde_receive(VLANClientState *nc, const uint8_t *buf, size_t size)
 | 
			
		||||
{
 | 
			
		||||
    VDEState *s = vc->opaque;
 | 
			
		||||
    VDEState *s = DO_UPCAST(VDEState, nc, nc);
 | 
			
		||||
    ssize_t ret;
 | 
			
		||||
 | 
			
		||||
    do {
 | 
			
		||||
| 
						 | 
				
			
			@ -62,19 +62,27 @@ static ssize_t vde_receive(VLANClientState *vc, const uint8_t *buf, size_t size)
 | 
			
		|||
    return ret;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void vde_cleanup(VLANClientState *vc)
 | 
			
		||||
static void vde_cleanup(VLANClientState *nc)
 | 
			
		||||
{
 | 
			
		||||
    VDEState *s = vc->opaque;
 | 
			
		||||
    VDEState *s = DO_UPCAST(VDEState, nc, nc);
 | 
			
		||||
    qemu_set_fd_handler(vde_datafd(s->vde), NULL, NULL, NULL);
 | 
			
		||||
    vde_close(s->vde);
 | 
			
		||||
    qemu_free(s);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static NetClientInfo net_vde_info = {
 | 
			
		||||
    .type = NET_CLIENT_TYPE_VDE,
 | 
			
		||||
    .size = sizeof(VDEState),
 | 
			
		||||
    .receive = vde_receive,
 | 
			
		||||
    .cleanup = vde_cleanup,
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
static int net_vde_init(VLANState *vlan, const char *model,
 | 
			
		||||
                        const char *name, const char *sock,
 | 
			
		||||
                        int port, const char *group, int mode)
 | 
			
		||||
{
 | 
			
		||||
    VLANClientState *nc;
 | 
			
		||||
    VDEState *s;
 | 
			
		||||
    VDECONN *vde;
 | 
			
		||||
    char *init_group = (char *)group;
 | 
			
		||||
    char *init_sock = (char *)sock;
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -84,19 +92,22 @@ static int net_vde_init(VLANState *vlan, const char *model,
 | 
			
		|||
        .mode = mode,
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
    s = qemu_mallocz(sizeof(VDEState));
 | 
			
		||||
    s->vde = vde_open(init_sock, (char *)"QEMU", &args);
 | 
			
		||||
    if (!s->vde){
 | 
			
		||||
        free(s);
 | 
			
		||||
    vde = vde_open(init_sock, (char *)"QEMU", &args);
 | 
			
		||||
    if (!vde){
 | 
			
		||||
        return -1;
 | 
			
		||||
    }
 | 
			
		||||
    s->vc = qemu_new_vlan_client(NET_CLIENT_TYPE_VDE,
 | 
			
		||||
                                 vlan, NULL, model, name, NULL,
 | 
			
		||||
                                 vde_receive, NULL, NULL,
 | 
			
		||||
                                 vde_cleanup, s);
 | 
			
		||||
 | 
			
		||||
    nc = qemu_new_net_client(&net_vde_info, vlan, NULL, model, name);
 | 
			
		||||
 | 
			
		||||
    snprintf(nc->info_str, sizeof(nc->info_str), "sock=%s,fd=%d",
 | 
			
		||||
             sock, vde_datafd(vde));
 | 
			
		||||
 | 
			
		||||
    s = DO_UPCAST(VDEState, nc, nc);
 | 
			
		||||
 | 
			
		||||
    s->vde = vde;
 | 
			
		||||
 | 
			
		||||
    qemu_set_fd_handler(vde_datafd(s->vde), vde_to_qemu, NULL, s);
 | 
			
		||||
    snprintf(s->vc->info_str, sizeof(s->vc->info_str), "sock=%s,fd=%d",
 | 
			
		||||
             sock, vde_datafd(s->vde));
 | 
			
		||||
 | 
			
		||||
    return 0;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in New Issue