@@ -28,6 +28,7 @@
#include "net.h"
#include "qemu-char.h"
#include "qemu-common.h"
+#include "qjson.h"
#include "qemu-error.h"
#include "qemu-option.h"
#include "qemu_socket.h"
@@ -49,6 +50,16 @@ typedef struct NetSocketListenState {
int fd;
} NetSocketListenState;
+static QDict *net_socket_format_info_dict(const char *host,
+ int service,
+ const char *family,
+ int is_server)
+{
+ return qobject_to_qdict(qobject_from_jsonf("{ 'model': 'socket', \
+ 'host': %s, 'family': %s, 'service': %d, 'server': %i }", host,
+ family, service, is_server));
+}
+
/* XXX: we consider we can send the whole packet without blocking */
static ssize_t net_socket_receive(VLANClientState *nc, const uint8_t *buf, size_t size)
{
@@ -369,6 +380,9 @@ static void net_socket_accept(void *opaque)
snprintf(s1->nc.info_str, sizeof(s1->nc.info_str),
"socket: connection from %s:%d",
inet_ntoa(saddr.sin_addr), ntohs(saddr.sin_port));
+
+ s1->nc.info_dict = net_socket_format_info_dict(inet_ntoa(saddr.sin_addr),
+ ntohs(saddr.sin_port), "ipv4", 1);
}
}
@@ -462,6 +476,10 @@ static int net_socket_connect_init(VLANState *vlan,
snprintf(s->nc.info_str, sizeof(s->nc.info_str),
"socket: connect to %s:%d",
inet_ntoa(saddr.sin_addr), ntohs(saddr.sin_port));
+
+ s->nc.info_dict = net_socket_format_info_dict(inet_ntoa(saddr.sin_addr),
+ ntohs(saddr.sin_port), "ipv4", 0);
+
return 0;
}
@@ -491,6 +509,10 @@ static int net_socket_mcast_init(VLANState *vlan,
snprintf(s->nc.info_str, sizeof(s->nc.info_str),
"socket: mcast=%s:%d",
inet_ntoa(saddr.sin_addr), ntohs(saddr.sin_port));
+
+ s->nc.info_dict = net_socket_format_info_dict(inet_ntoa(saddr.sin_addr),
+ ntohs(saddr.sin_port), "ipv4", 0);
+
return 0;
}
Signed-off-by: Miguel Di Ciurcio Filho <miguel.filho@gmail.com> --- net/socket.c | 22 ++++++++++++++++++++++ 1 files changed, 22 insertions(+), 0 deletions(-)