⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 mqueue1.c

📁 ecos实时嵌入式操作系统
💻 C
字号:
/*========================================================================////      mqueue1.c////      POSIX Message queues tests////========================================================================//####ECOSGPLCOPYRIGHTBEGIN####// -------------------------------------------// This file is part of eCos, the Embedded Configurable Operating System.// Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.//// eCos 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 or (at your option) any later version.//// eCos 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 eCos; if not, write to the Free Software Foundation, Inc.,// 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.//// As a special exception, if other files instantiate templates or use macros// or inline functions from this file, or you compile this file and link it// with other works to produce a work based on this file, this file does not// by itself cause the resulting work to be covered by the GNU General Public// License. However the source code for this file must still be made available// in accordance with section (3) of the GNU General Public License.//// This exception does not invalidate any other reasons why a work based on// this file might be covered by the GNU General Public License.//// Alternative licenses for eCos may be arranged by contacting Red Hat, Inc.// at http://sources.redhat.com/ecos/ecos-license/// -------------------------------------------//####ECOSGPLCOPYRIGHTEND####//========================================================================//#####DESCRIPTIONBEGIN####//// Author(s):     jlarmour// Contributors:  // Date:          2000-05-18// Purpose:       This file provides tests for POSIX mqueues// Description:   // Usage:         ////####DESCRIPTIONEND####////======================================================================*//* CONFIGURATION */#include <pkgconf/posix.h>#ifndef CYGPKG_POSIX_MQUEUES# define NA_MSG "Message queues not configured"#endif#ifdef NA_MSG#include <cyg/infra/testcase.h>      // test APIvoidcyg_user_start(void){    CYG_TEST_NA( NA_MSG );}#else/* INCLUDES */#include <fcntl.h>                   // O_*#include <errno.h>                   // errno#include <sys/stat.h>                // file modes#include <mqueue.h>                  // Mqueue Header#include <cyg/infra/testcase.h>      // test API/* FUNCTIONS */static intmy_memcmp(const void *m1, const void *m2, size_t n){    char *s1 = (char *)m1;    char *s2 = (char *)m2;    while (n--) {        if (*s1 != *s2)            return *s1 - *s2;        s1++;        s2++;    }    return 0;} // my_memcmp()//************************************************************************intmain(void){    mqd_t q1, q2;    char buf[20];    ssize_t recvlen;    unsigned int prio;    struct mq_attr attr, oattr;    mode_t mode;    int err;    CYG_TEST_INIT();    CYG_TEST_INFO( "Starting POSIX message test 1" );    q1 = mq_open( "/mq1", O_RDWR );    CYG_TEST_PASS_FAIL( q1 == (mqd_t)-1, "error for non-existent queue" );    CYG_TEST_PASS_FAIL( ENOENT == errno,                        "errno correct for non-existent queue" );    attr.mq_flags = 0;    attr.mq_maxmsg = 4;    attr.mq_msgsize = 20;    mode = S_IRWXU|S_IRWXG|S_IRWXO; // rwx for all    q1 = mq_open( "/mq1", O_CREAT|O_NONBLOCK|O_WRONLY, mode, &attr );    CYG_TEST_PASS_FAIL( q1 != (mqd_t)-1, "simple mq_open (write only)" );        err = mq_getattr( q1, &attr );    CYG_TEST_PASS_FAIL( 0 == err, "simple mq_getattr" );    CYG_TEST_PASS_FAIL( (4 == attr.mq_maxmsg) &&                        (20 == attr.mq_msgsize) &&                        (O_NONBLOCK == (attr.mq_flags & O_NONBLOCK)) &&                        (O_RDONLY != (attr.mq_flags & O_RDONLY)) &&                        (O_WRONLY == (attr.mq_flags & O_WRONLY)) &&                        (O_RDWR != (attr.mq_flags & O_RDWR)) &&                        (0 == attr.mq_curmsgs ), "getattr attributes correct" );                            err = mq_send( q1, "Vik is brill", sizeof("Vik is brill"), 10 );    CYG_TEST_PASS_FAIL( 0 == err, "simple mq_send" );        err = mq_getattr( q1, &attr );    CYG_TEST_PASS_FAIL( 0 == err, "simple mq_getattr after send" );    CYG_TEST_PASS_FAIL( (4 == attr.mq_maxmsg) &&                        (20 == attr.mq_msgsize) &&                        (O_NONBLOCK == (attr.mq_flags & O_NONBLOCK)) &&                        (O_RDONLY != (attr.mq_flags & O_RDONLY)) &&                        (O_WRONLY == (attr.mq_flags & O_WRONLY)) &&                        (O_RDWR != (attr.mq_flags & O_RDWR)) &&                        (1 == attr.mq_curmsgs ),                        "getattr attributes correct #2" );                            q2 = mq_open( "/mq1", O_RDONLY|O_CREAT|O_EXCL );    CYG_TEST_PASS_FAIL( q2 == (mqd_t)-1,                        "error for exclusive open of existing queue" );    CYG_TEST_PASS_FAIL( EEXIST == errno,                        "errno correct for exclusive open of existing queue" );        q2 = mq_open( "/mq1", O_RDONLY );    CYG_TEST_PASS_FAIL( q2 != (mqd_t)-1, "simple mq_open (read only)" );        err = mq_getattr( q2, &attr );    CYG_TEST_PASS_FAIL( 0 == err, "simple mq_getattr, different mqd_t" );    CYG_TEST_PASS_FAIL( (4 == attr.mq_maxmsg) &&                        (20 == attr.mq_msgsize) &&                        (O_NONBLOCK != (attr.mq_flags & O_NONBLOCK)) &&                        (O_RDONLY == (attr.mq_flags & O_RDONLY)) &&                        (O_WRONLY != (attr.mq_flags & O_WRONLY)) &&                        (O_RDWR != (attr.mq_flags & O_RDWR)) &&                        (1 == attr.mq_curmsgs ),                        "getattr attributes correct #3" );    err = mq_close( q2 );    CYG_TEST_PASS_FAIL( 0 == err, "simple mq_close" );        q2 = mq_open( "/mq1", O_RDONLY );    CYG_TEST_PASS_FAIL( q2 != (mqd_t)-1, "mq_open reopen (read only)" );        err = mq_getattr( q2, &attr );    CYG_TEST_PASS_FAIL( 0 == err, "simple mq_getattr, different mqd_t" );    CYG_TEST_PASS_FAIL( (4 == attr.mq_maxmsg) &&                        (20 == attr.mq_msgsize) &&                        (O_NONBLOCK != (attr.mq_flags & O_NONBLOCK)) &&                        (O_RDONLY == (attr.mq_flags & O_RDONLY)) &&                        (O_WRONLY != (attr.mq_flags & O_WRONLY)) &&                        (O_RDWR != (attr.mq_flags & O_RDWR)) &&                        (1 == attr.mq_curmsgs ),                        "getattr attributes correct #4" );    recvlen = mq_receive( q2, buf, sizeof(buf), &prio );    CYG_TEST_PASS_FAIL( recvlen == sizeof("Vik is brill"),                        "receive message length" );    CYG_TEST_PASS_FAIL( 0 == my_memcmp( buf, "Vik is brill",                                        sizeof("Vik is brill")),                        "received message data intact" );    CYG_TEST_PASS_FAIL( 10 == prio, "received at correct priority" );    err = mq_getattr( q1, &attr );    CYG_TEST_PASS_FAIL( 0 == err, "simple mq_getattr after send" );    CYG_TEST_PASS_FAIL( (4 == attr.mq_maxmsg) &&                        (20 == attr.mq_msgsize) &&                        (O_NONBLOCK == (attr.mq_flags & O_NONBLOCK)) &&                        (O_RDONLY != (attr.mq_flags & O_RDONLY)) &&                        (O_WRONLY == (attr.mq_flags & O_WRONLY)) &&                        (O_RDWR != (attr.mq_flags & O_RDWR)) &&                        (0 == attr.mq_curmsgs ),                        "getattr attributes correct #5" );    attr.mq_flags |= O_NONBLOCK;    err = mq_setattr( q2, &attr, &oattr );    CYG_TEST_PASS_FAIL( 0 == err, "mq_setattr O_NONBLOCK" );    CYG_TEST_PASS_FAIL( (4 == oattr.mq_maxmsg) &&                        (20 == oattr.mq_msgsize) &&                        (O_NONBLOCK != (oattr.mq_flags & O_NONBLOCK)) &&                        (O_RDONLY == (oattr.mq_flags & O_RDONLY)) &&                        (O_WRONLY != (oattr.mq_flags & O_WRONLY)) &&                        (O_RDWR != (oattr.mq_flags & O_RDWR)) &&                        (0 == oattr.mq_curmsgs ),                        "old attribute correct" );    err = mq_getattr( q2, &attr );    CYG_TEST_PASS_FAIL( 0 == err, "mq_getattr after O_NONBLOCK" );    CYG_TEST_PASS_FAIL( (4 == attr.mq_maxmsg) &&                        (20 == attr.mq_msgsize) &&                        (O_NONBLOCK == (attr.mq_flags & O_NONBLOCK)) &&                        (O_RDONLY == (attr.mq_flags & O_RDONLY)) &&                        (O_WRONLY != (attr.mq_flags & O_WRONLY)) &&                        (O_RDWR != (attr.mq_flags & O_RDWR)) &&                        (0 == attr.mq_curmsgs ),                        "new attribute correct" );    recvlen = mq_receive( q2, buf, sizeof(buf), &prio );    CYG_TEST_PASS_FAIL( recvlen == (ssize_t)-1,                        "mq_receive, empty buffer, non-blocking" );    CYG_TEST_PASS_FAIL( EAGAIN == errno,                        "errno correct for non-blocking" );        err = mq_send( q2, "foo", sizeof("foo"), 1 );    CYG_TEST_PASS_FAIL( -1 == err, "error on mq_send on read-only descriptor" );    CYG_TEST_PASS_FAIL( EBADF == errno,                        "errno correct for mq_send on r/o descriptor" );        err = mq_send( q2, "supercalifragilisticexpealidocious", 21, 2 );    CYG_TEST_PASS_FAIL( -1 == err, "error on mq_send (message too long)" );    CYG_TEST_PASS_FAIL( EMSGSIZE == errno,                        "errno correct for mq_send (message too long)" );        err = mq_send( q1, "", sizeof(""), 5 );    CYG_TEST_PASS_FAIL( 0 == err, "mq_send \"\"" );        err = mq_send( q1, "I love Vik", sizeof("I love Vik"), 7 );    CYG_TEST_PASS_FAIL( 0 == err, "mq_send (different priority)" );        err = mq_send( q1, "a lot!", sizeof("a lot!"), 7 );    CYG_TEST_PASS_FAIL( 0 == err, "mq_send (same priority)" );        err = mq_send( q1, "Vik is a babe", sizeof("Vik is a babe"), 6 );    CYG_TEST_PASS_FAIL( 0 == err, "mq_send (middle priority)" );        err = mq_send( q1, "wibble", sizeof("wibble"), 6 );    CYG_TEST_PASS_FAIL( -1 == err, "error on mq_send with full queue" );    CYG_TEST_PASS_FAIL( EAGAIN == errno,                        "errno correct for mq_send full queue" );        err = mq_getattr( q2, &attr );    CYG_TEST_PASS_FAIL( 0 == err, "mq_getattr after sends" );    CYG_TEST_PASS_FAIL( (4 == attr.mq_maxmsg) &&                        (20 == attr.mq_msgsize) &&                        (O_NONBLOCK == (attr.mq_flags & O_NONBLOCK)) &&                        (O_RDONLY == (attr.mq_flags & O_RDONLY)) &&                        (O_WRONLY != (attr.mq_flags & O_WRONLY)) &&                        (O_RDWR != (attr.mq_flags & O_RDWR)) &&                        (4 == attr.mq_curmsgs ),                        "getattr attributes correct #5" );    recvlen = mq_receive( q2, buf, sizeof(buf), &prio );    CYG_TEST_PASS_FAIL( recvlen == sizeof("I love Vik"),                        "receive message length (prioritized) #1" );    CYG_TEST_PASS_FAIL( 0 == my_memcmp( buf, "I love Vik",                                        sizeof("I love Vik")),                        "received message data intact (prioritized) #1" );    CYG_TEST_PASS_FAIL( 7 == prio,                        "received at correct priority (prioritized) #1" );    recvlen = mq_receive( q2, buf, sizeof(buf), &prio );    CYG_TEST_PASS_FAIL( recvlen == sizeof("a lot!"),                        "receive message length (prioritized) #2" );    CYG_TEST_PASS_FAIL( 0 == my_memcmp( buf, "a lot!",                                        sizeof("a lot!")),                        "received message data intact (prioritized) #2" );    CYG_TEST_PASS_FAIL( 7 == prio,                        "received at correct priority (prioritized) #2" );    recvlen = mq_receive( q2, buf, sizeof(buf), &prio );    CYG_TEST_PASS_FAIL( recvlen == sizeof("Vik is a babe"),                        "receive message length (prioritized) #3" );    CYG_TEST_PASS_FAIL( 0 == my_memcmp( buf, "Vik is a babe",                                        sizeof("Vik is a babe")),                        "received message data intact (prioritized) #3" );    CYG_TEST_PASS_FAIL( 6 == prio,                        "received at correct priority (prioritized) #3" );    recvlen = mq_receive( q2, buf, 0, &prio );    CYG_TEST_PASS_FAIL( recvlen == (ssize_t)-1,                        "mq_receive, zero-sized buffer" );    recvlen = mq_receive( q2, buf, sizeof(buf), &prio );    CYG_TEST_PASS_FAIL( recvlen == sizeof(""),                        "receive message length (prioritized) #4" );    CYG_TEST_PASS_FAIL( 0 == my_memcmp( buf, "",                                        sizeof("")),                        "received message data intact (prioritized) #4" );    CYG_TEST_PASS_FAIL( 5 == prio,                        "received at correct priority (prioritzed) #4" );    recvlen = mq_receive( q2, buf, sizeof(buf), &prio );    CYG_TEST_PASS_FAIL( recvlen == (ssize_t)-1,                        "mq_receive, empty buffer, non-blocking #2" );    CYG_TEST_PASS_FAIL( EAGAIN == errno,                        "errno correct for non-blocking #2" );        err = mq_send( q1, "12345678901234567890", 20, 15 );    CYG_TEST_PASS_FAIL( 0 == err, "mq_send (before closing)" );        err = mq_unlink( "/foo" );    CYG_TEST_PASS_FAIL( -1 == err, "mq_unlink (wrong name)" );    CYG_TEST_PASS_FAIL( ENOENT == errno,                        "errno correct for mq_unlink (wrong name)" );    err = mq_unlink( "/mq1" );    CYG_TEST_PASS_FAIL( 0 == err, "mq_unlink (before closing)" );    err = mq_close( q1 );    CYG_TEST_PASS_FAIL( 0 == err, "mq_close (send descriptor)" );    recvlen = mq_receive( q2, buf, sizeof(buf), &prio );    CYG_TEST_PASS_FAIL( recvlen == 20,                        "receive message length (mid close)" );    CYG_TEST_PASS_FAIL( 0 == my_memcmp( buf, "12345678901234567890", 20 ),                        "received message data intact (mid close)" );    CYG_TEST_PASS_FAIL( 15 == prio,                        "received at correct priority (mid close)" );    err = mq_close( q2 );    CYG_TEST_PASS_FAIL( 0 == err, "mq_close (receive descriptor)" );    q1 = mq_open( "/mq1", O_RDONLY );    CYG_TEST_PASS_FAIL( q1 == (mqd_t)-1, "error for non-existent queue" );    CYG_TEST_PASS_FAIL( ENOENT == errno,                        "errno correct for non-existent queue" );    CYG_TEST_EXIT("POSIX message test 1");    return 0;} // main()//------------------------------------------------------------------------#endif/* EOF mqueue1.c */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -