/*
* Copyright (c) 2017 Petr Vorel <pvorel@suse.cz>
*
* 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 2 of
* the License, or (at your option) any later version.
*
* This program is distributed in the hope that it would 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/>.
*/
#ifndef MQ_H
#define MQ_H
#include "tst_test.h"
#include "tst_sig_proc.h"
#include "tst_safe_posix_ipc.h"
#define MAX_MSGSIZE 8192
#define MSG_LENGTH 10
#define QUEUE_NAME "/test_mqueue"
#define QUEUE_NAME_NONBLOCK "/test_mqueue_nonblock"
static char smsg[MAX_MSGSIZE];
static struct sigaction act;
static void cleanup_common(void)
{
if (fd_root > 0)
SAFE_CLOSE(fd_root);
if (fd > 0)
SAFE_CLOSE(fd);
if (fd_nonblock > 0)
SAFE_CLOSE(fd_nonblock);
mq_unlink(QUEUE_NAME);
mq_unlink(QUEUE_NAME_NONBLOCK);
}
static void sighandler(int sig LTP_ATTRIBUTE_UNUSED) { }
static void setup_common(void)
{
int i;
act.sa_handler = sighandler;
sigaction(SIGINT, &act, NULL);
cleanup_common();
fd_root = SAFE_OPEN("/", O_RDONLY);
fd = SAFE_MQ_OPEN(QUEUE_NAME, O_CREAT | O_EXCL | O_RDWR, 0700, NULL);
fd_nonblock = SAFE_MQ_OPEN(QUEUE_NAME_NONBLOCK, O_CREAT | O_EXCL | O_RDWR |
O_NONBLOCK, 0700, NULL);
for (i = 0; i < MAX_MSGSIZE; i++)
smsg[i] = i;
}
static void cleanup_queue(mqd_t fd)
{
int i;
struct mq_attr mqstat;
unsigned int prio;
char rmsg[MAX_MSGSIZE];
memset(&mqstat, 0, sizeof(mqstat));
if (mq_getattr(fd, &mqstat) == -1) {
tst_brk(TWARN, "mq_getattr() failed");
return;
}
for (i = 0; i < mqstat.mq_curmsgs; i++) {
tst_res(TINFO, "receive %d/%ld message", i + 1, mqstat.mq_curmsgs);
mq_receive(fd, rmsg, MAX_MSGSIZE, &prio);
}
}
#endif /* MQ_H */