为什么有一个错误的S_objLib_OBJ_UNAVAILABLE?

时间:2016-10-05 21:52:07

标签: c message-queue vxworks

我想将一些数据发送到队列但由于某种原因得到错误S_objLib_OBJ_UNAVAILABLE(3997698),我不知道为什么。这就是我所拥有的:

static MSG_Q_ID bfd_to_alm_data = NULL;
// in bfd_queues_create(void)
if (!bfd_to_alm_data) {
        bfd_to_alm_data = msgQCreate
            (
            MAX_BFD_MSGS,              /* max messages that can be queued */
            sizeof(bfd_report_t),         /* max bytes in a message */
            MSG_Q_FIFO               /* message queue options */
            );
        if (!bfd_to_alm_data) {
            printErrno(errno);
            jpax_logMsg(LOG_ERROR, LOGSTREAM_SWITCH, "ERROR: Failed to create queue for bfd messages to alarm engine. errno %d\n",errno,0,0,0,0);
            return ERROR;
        }
// and this is where I get the error:
if (!bfd_to_alm_data)
            rv = bfd_queues_create();
        if (rv < 0) {
            jpax_logMsg(LOG_ERROR, LOGSTREAM_SWITCH, "ERROR: Could not initialize bfd_to_alm_data! errcode %d \n",rv,0,0,0,0);
            return;
        }

        rv = msgQSend(bfd_to_alm_data, 
                &bfd_info,
                sizeof(bfd_report_t),
                NO_WAIT,
                MSG_PRI_NORMAL);        
        if (rv < 0) {
            jpax_logMsg(LOG_ERROR, LOGSTREAM_SWITCH, "ERROR: Could not push Bfd alarm data onto queue! errno %d\n",errno,0,0,0,0);
        }

这里可能会发生什么?

我可以确认,在msgQCreate()msgQSend()

的来电之间,Qeue句柄保持不变

1 个答案:

答案 0 :(得分:1)

从手册(特别是内核API参考指南)中,我们可以看到当队列中没有空间时,errno将被设置为S_objLib_OBJ_UNAVAILABLE,并且您已将NO_WAIT指定为超时值。

  

S_objLib_OBJ_UNAVAILABLE没有可用的空闲缓冲区空间   指定了NO_WAIT超时。

我们可以在您的代码中看到您指定了NO_WAIT。没有任何迹象表明msgQ应该已满 - 但也许您还没有显示所有代码。

要检查的事项:

  1. MAX_BFD_MSGS的定义 - 确保它足够大
  2. 确保某些内容正在从队列中读取。
  3. 考虑使用WAIT_FOREVER。这将导致msgQSend操作阻塞,直到队列中有空间。