nfv/guest-comm/host-guest-comm-2.0/test/host_app.c
Dean Troyer 85cd488bef StarlingX open source release updates
Signed-off-by: Dean Troyer <dtroyer@gmail.com>
2018-05-31 07:36:51 -07:00

188 lines
5.9 KiB
C

/*
* Copyright (c) 2013-2016, Wind River Systems, Inc.
*
* Redistribution and use in source and binary forms, with or without modification, are
* permitted provided that the following conditions are met:
*
* 1) Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
*
* 2) Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation and/or
* other materials provided with the distribution.
*
* 3) Neither the name of Wind River Systems nor the names of its contributors may be
* used to endorse or promote products derived from this software without specific
* prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
* USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
/**
build: gcc -I../ -o host_app host_app.c -ljson-c
*/
#include <stddef.h>
#include <errno.h>
#include <error.h>
#include <fcntl.h>
#include <poll.h>
#include <pthread.h>
#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
#include <string.h>
#include <unistd.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <sys/select.h>
#include <sys/un.h>
#include <sys/socket.h>
#include <json-c/json.h>
#include "host_guest_msg_type.h"
struct json_object *create_new_jobj_data()
{
struct json_object *jobj_data = json_object_new_object();
if (jobj_data == NULL) {
printf("failed to allocate json object for data\n");
return NULL;
}
json_object_object_add(jobj_data, VERSION, json_object_new_int(CUR_VERSION));
json_object_object_add(jobj_data, "resource", json_object_new_string("cpu"));
json_object_object_add(jobj_data, "direction", json_object_new_string("down"));
return jobj_data;
}
// create app to daemon msg
const char *create_outmsg(int msg_count, const char *dest_instance)
{
struct json_object *jobj_msg = json_object_new_object();
if (jobj_msg == NULL) {
printf("failed to allocate json object for msg\n");
return NULL;
}
json_object_object_add(jobj_msg, VERSION, json_object_new_int(CUR_VERSION));
json_object_object_add(jobj_msg, DEST_ADDR, json_object_new_string("g_scale_agent"));
json_object_object_add(jobj_msg, DEST_INSTANCE, json_object_new_string(dest_instance));
json_object_object_add(jobj_msg, "msg_count", json_object_new_int(msg_count));
struct json_object *jobj_data = create_new_jobj_data();
if (jobj_data == NULL) {
json_object_put(jobj_msg);
return NULL;
}
json_object_object_add(jobj_msg, DATA, create_new_jobj_data());
const char *msg = json_object_to_json_string_ext(jobj_msg, JSON_C_TO_STRING_PLAIN);
return msg;
}
// create daemon to app msg
const char *create_inmsg()
{
struct json_object *jobj_msg = json_object_new_object();
if (jobj_msg == NULL) {
printf("failed to allocate json object for msg\n");
return NULL;
}
json_object_object_add(jobj_msg, VERSION, json_object_new_int(CUR_VERSION));
json_object_object_add(jobj_msg, SOURCE_ADDR, json_object_new_string("h_scale_agent"));
struct json_object *jobj_data = create_new_jobj_data();
if (jobj_data == NULL) {
json_object_put(jobj_msg);
return NULL;
}
json_object_object_add(jobj_msg, DATA, create_new_jobj_data());
const char *msg = json_object_to_json_string_ext(jobj_msg, JSON_C_TO_STRING_PLAIN);
return msg;
}
//argv[1] should be the instance name
int main(int argc, char **argv)
{
char buf[4096];
int len;
struct sockaddr_un cliaddr, srvaddr;
int rc;
if (argc != 2) {
printf("call with instance name as arg\n");
exit(1);
}
// set up socket for talking to host agent
int fd = socket(AF_UNIX, SOCK_DGRAM, 0);
if (fd == -1) {
perror("socket");
exit(-1);
}
memset(&cliaddr, 0, sizeof(struct sockaddr_un));
cliaddr.sun_family = AF_UNIX;
cliaddr.sun_path[0] = '\0';
strncpy(cliaddr.sun_path+1, "h_scale_agent", sizeof(cliaddr.sun_path) - 2);
if (bind(fd, (struct sockaddr *) &cliaddr, sizeof(struct sockaddr_un)) == -1) {
perror("bind");
exit(-1);
}
/* Construct address of server */
memset(&srvaddr, 0, sizeof(struct sockaddr_un));
srvaddr.sun_family = AF_UNIX;
srvaddr.sun_path[0] = '\0';
strncpy(srvaddr.sun_path+1, AGENT_ADDR, sizeof(srvaddr.sun_path) - 2);
const char* inmsg = create_inmsg();
// pass argv[1] as dest_instance
const char* outmsg = create_outmsg(1, argv[1]);
len = strlen(outmsg);
rc = sendto(fd, outmsg, len, 0, (struct sockaddr *) &srvaddr,
sizeof(struct sockaddr_un));
if (rc != len) {
perror("sendto");
exit(-1);
}
outmsg = create_outmsg(2, argv[1]);
len = strlen(outmsg);
rc = sendto(fd, outmsg, len, 0, (struct sockaddr *) &srvaddr,
sizeof(struct sockaddr_un));
if (rc != len) {
perror("sendto");
exit(-1);
}
while (1) {
len = recv(fd, buf, sizeof(buf), 0);
if (len == -1) {
perror("recvfrom");
exit(-1);
}
printf("Msg from instance %s\n", buf);
fflush(0);
}
}