123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 |
- #include "custom_memory_manager.h"
- #include <pthread.h>
- #include <open62541/plugin/log_stdout.h>
- #include <open62541/server_config_default.h>
- #include <open62541/types.h>
- #include "ua_server_internal.h"
- #include "testing_networklayers.h"
- #define RECEIVE_BUFFER_SIZE 65535
- #define SERVER_PORT 4840
- volatile bool running = true;
- static void *serverLoop(void *server_ptr) {
- UA_Server *server = (UA_Server*) server_ptr;
- while (running) {
- UA_Server_run_iterate(server, false);
- }
- return NULL;
- }
- extern "C" int
- LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
- UA_Server *server = UA_Server_new();
- if(!server) {
- UA_LOG_FATAL(UA_Log_Stdout, UA_LOGCATEGORY_SERVER,
- "Could not create server instance using UA_Server_new");
- return EXIT_FAILURE;
- }
- UA_ServerConfig *config = UA_Server_getConfig(server);
- UA_StatusCode retval = UA_ServerConfig_setMinimal(config, SERVER_PORT, NULL);
- if (retval != UA_STATUSCODE_GOOD) {
- UA_LOG_FATAL(UA_Log_Stdout, UA_LOGCATEGORY_SERVER,
- "Could not create server instance using UA_Server_new. %s", UA_StatusCode_name(retval));
- UA_Server_delete(server);
- return EXIT_FAILURE;
- }
-
- config->discovery.mdnsEnable = true;
- config->discovery.mdns.mdnsServerName = UA_String_fromChars("Sample Multicast Server");
- retval = UA_Server_run_startup(server);
- if(retval != UA_STATUSCODE_GOOD) {
- UA_LOG_FATAL(UA_Log_Stdout, UA_LOGCATEGORY_SERVER,
- "Could not run UA_Server_run_startup. %s", UA_StatusCode_name(retval));
- UA_Server_delete(server);
- return EXIT_FAILURE;
- }
- if (!UA_memoryManager_setLimitFromLast4Bytes(data, size)) {
- UA_Server_run_shutdown(server);
- UA_Server_delete(server);
- return EXIT_SUCCESS;
- }
- size -= 4;
-
- UA_Server_run_iterate(server, true);
- pthread_t serverThread;
- int rc = pthread_create(&serverThread, NULL, serverLoop, (void *)server);
- if (rc){
- UA_LOG_FATAL(UA_Log_Stdout, UA_LOGCATEGORY_SERVER,
- "return code from pthread_create() is %d", rc);
- UA_Server_run_shutdown(server);
- UA_Server_delete(server);
- return -1;
- }
- int retCode = EXIT_SUCCESS;
- int sockfd = 0;
- {
-
- if((sockfd = socket(AF_INET, SOCK_STREAM, 0)) < 0)
- {
- UA_LOG_FATAL(UA_Log_Stdout, UA_LOGCATEGORY_CLIENT,
- "Could not create socket");
- retCode = EXIT_FAILURE;
- } else {
- struct sockaddr_in serv_addr;
- serv_addr.sin_family = AF_INET;
- serv_addr.sin_port = htons(SERVER_PORT);
- serv_addr.sin_addr.s_addr = inet_addr("127.0.0.1");
- int status = connect(sockfd, (struct sockaddr *) &serv_addr, sizeof(serv_addr));
- if (status >= 0) {
- if (write(sockfd, data, size) != size) {
- UA_LOG_FATAL(UA_Log_Stdout, UA_LOGCATEGORY_CLIENT,
- "Did not write %d bytes", size);
- retCode = EXIT_FAILURE;
- }
- } else {
- UA_LOG_FATAL(UA_Log_Stdout, UA_LOGCATEGORY_CLIENT,
- "Could not connect to server: %s", strerror(errno));
- retCode = EXIT_FAILURE;
- }
- }
- }
- running = false;
- void *status;
- pthread_join(serverThread, &status);
-
- for (size_t i=0; i<5; i++) {
- UA_Server_run_iterate(server, false);
- }
- close(sockfd);
- UA_Server_run_shutdown(server);
- UA_Server_delete(server);
- return retCode;
- }
|