FreeRTOS Emulator with SDL2 Based Graphics and Input Library  1.0
A POSIX wrapper to run FreeRTOS on an x86 machine with some basic input and output libraries aimed at making teaching FreeRTOS simpler.
AsyncIO.c File Reference

A single file asyncronous UNIX communications library to perform UDP, TCP and POSIX message queue communications. More...

#include <mqueue.h>
#include <signal.h>
#include <stdlib.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <inttypes.h>
#include <errno.h>
#include <unistd.h>
#include <stdio.h>
#include <stdint.h>
#include <string.h>
#include <pthread.h>
#include "AsyncIO.h"

Classes

struct  aIO_socket_t
 
struct  aIO_mq_t
 
struct  aIO_serial_t
 
union  aIO_attr
 
struct  aIO
 
struct  aIO_tcp_client
 

Macros

#define _GNU_SOURCE
 
#define PRINT_CHECK
 

Typedefs

typedef struct aIO aIO_t
 

Enumerations

enum  aIO_conn_e {
  NONE = 0 , SOCKET , MSG_QUEUE , SERIAL ,
  NO_OF_CONN_TYPES
}
 

Functions

void * aIOTCPHandler (void *conn)
 
aIO_tgetLastConnection (void)
 
void aIOCloseConn (aIO_handle_t conn)
 Closes a connection and frees all resources used by that connection. More...
 
void aIODeinit (void)
 Function that closes all open connections. More...
 
aIO_tcreateAsyncIO (aIO_conn_e type, size_t buffer_size, void(*callback)(size_t, char *, void *), void *args)
 
int aIOMessageQueuePut (const char *mq_name, char *buffer)
 Sends the data stored in buffer to the message queue with the provided name. More...
 
int aIOSocketPut (aIO_socket_e protocol, char *s_addr, in_port_t port, char *buffer, size_t buffer_size)
 Send the data stored in buffer to the socket described by s_addr and port. More...
 
aIO_handle_t aIOOpenMessageQueue (const char *name, long max_msg_num, long max_msg_size, void(*callback)(size_t, char *, void *), void *args)
 
aIO_handle_t aIOOpenUDPSocket (char *s_addr, in_port_t port, size_t buffer_size, void(*callback)(size_t, char *, void *), void *args)
 
aIO_handle_t aIOOpenTCPSocket (char *s_addr, in_port_t port, size_t buffer_size, void(*callback)(size_t, char *, void *), void *args)
 

Variables

aIO_t head = { .type = NONE, .lock = PTHREAD_MUTEX_INITIALIZER }
 
pthread_cond_t aIO_quit_conn = PTHREAD_COND_INITIALIZER
 
pthread_mutex_t aIO_quit_lock = PTHREAD_MUTEX_INITIALIZER
 

Detailed Description

A single file asyncronous UNIX communications library to perform UDP, TCP and POSIX message queue communications.

Author
Alex Hoffman
Date
20 January 2020
   ----------------------------------------------------------------------
    Copyright (C) Alexander Hoffman, 2019
    This program is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation, either version 3 of the License, or
    any later version.
    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.
    You should have received a copy of the GNU General Public License
    along with this program.  If not, see <http://www.gnu.org/licenses/>.
   ----------------------------------------------------------------------

Macro Definition Documentation

◆ _GNU_SOURCE

#define _GNU_SOURCE

◆ PRINT_CHECK

#define PRINT_CHECK
Value:
fprintf(stderr, "[ERRNO: %s] %s:%d -> %s\n", strerror(errno), \
__FILE__, __LINE__, __func__);

Typedef Documentation

◆ aIO_t

typedef struct aIO aIO_t

Enumeration Type Documentation

◆ aIO_conn_e

enum aIO_conn_e
Enumerator
NONE 
SOCKET 
MSG_QUEUE 
SERIAL 
NO_OF_CONN_TYPES 

Function Documentation

◆ aIOOpenMessageQueue()

aIO_handle_t aIOOpenMessageQueue ( const char *  name,
long  max_msg_num,
long  max_msg_size,
void(*)(size_t, char *, void *)  callback,
void *  args 
)

Attributes of MQ used in mq_open

sigval struct that is passed to handler. sival_ptr is used to pass pointer

to structure containing MQ information

Create MQ

sigevent needed to enable to passing of si_value to the handler

used by SIGEV_THREAD

◆ aIOOpenTCPSocket()

aIO_handle_t aIOOpenTCPSocket ( char *  s_addr,
in_port_t  port,
size_t  buffer_size,
void(*)(size_t, char *, void *)  callback,
void *  args 
)

Sprinkle a little reuseability on our shiny socket

◆ aIOOpenUDPSocket()

aIO_handle_t aIOOpenUDPSocket ( char *  s_addr,
in_port_t  port,
size_t  buffer_size,
void(*)(size_t, char *, void *)  callback,
void *  args 
)

◆ aIOTCPHandler()

void * aIOTCPHandler ( void *  conn)

◆ createAsyncIO()

aIO_t* createAsyncIO ( aIO_conn_e  type,
size_t  buffer_size,
void(*)(size_t, char *, void *)  callback,
void *  args 
)

◆ getLastConnection()

aIO_t* getLastConnection ( void  )

Variable Documentation

◆ aIO_quit_conn

pthread_cond_t aIO_quit_conn = PTHREAD_COND_INITIALIZER

◆ aIO_quit_lock

pthread_mutex_t aIO_quit_lock = PTHREAD_MUTEX_INITIALIZER

◆ head

aIO_t head = { .type = NONE, .lock = PTHREAD_MUTEX_INITIALIZER }