2016-08-30 20:27:56 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2016 The Android Open Source Project
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2016-08-08 20:12:30 +02:00
|
|
|
package android.hardware.tests.msgq@1.0;
|
|
|
|
|
|
|
|
interface ITestMsgQ {
|
2016-12-15 18:14:13 +01:00
|
|
|
enum EventFlagBits : uint32_t {
|
|
|
|
FMQ_NOT_EMPTY = 1 << 0,
|
|
|
|
FMQ_NOT_FULL = 1 << 1,
|
|
|
|
};
|
|
|
|
|
2017-03-28 23:40:58 +02:00
|
|
|
/**
|
2016-10-15 01:48:01 +02:00
|
|
|
* This method requests the service to set up a synchronous read/write
|
2018-07-15 02:23:45 +02:00
|
|
|
* wait-free FMQ using the input descriptor with the client as reader.
|
|
|
|
*
|
|
|
|
* @param mqDesc This structure describes the FMQ that was set up by the
|
|
|
|
* client. Server uses this descriptor to set up a FMQ object at its end.
|
2016-10-15 01:48:01 +02:00
|
|
|
*
|
|
|
|
* @return ret True if the setup is successful.
|
2016-09-22 02:47:06 +02:00
|
|
|
*/
|
2020-09-22 19:20:54 +02:00
|
|
|
configureFmqSyncReadWrite(fmq_sync<int32_t> mqDesc) generates(bool ret);
|
2016-08-08 20:12:30 +02:00
|
|
|
|
2017-03-28 23:40:58 +02:00
|
|
|
/**
|
2017-02-13 23:38:26 +01:00
|
|
|
* This method requests the service to return an MQDescriptor to
|
|
|
|
* an unsynchronized FMQ set up by the server. If 'configureFmq' is
|
|
|
|
* true, then the server sets up a new unsynchronized FMQ. This
|
|
|
|
* method is to be used to test multiple reader processes.
|
2016-10-15 01:48:01 +02:00
|
|
|
*
|
2017-02-13 23:38:26 +01:00
|
|
|
* @param configureFmq The server sets up a new unsynchronized FMQ if
|
|
|
|
* this parameter is true.
|
2021-01-19 01:11:20 +01:00
|
|
|
* @param userFd True to initialize the message queue with a user supplied
|
|
|
|
* file descriptor for the ring buffer.
|
|
|
|
* False to let the message queue use a single FD for everything.
|
2017-02-13 23:38:26 +01:00
|
|
|
*
|
|
|
|
* @return ret True if successful.
|
|
|
|
* @return mqDesc This structure describes the unsynchronized FMQ that was
|
2016-10-15 01:48:01 +02:00
|
|
|
* set up by the service. Client can use it to set up the FMQ at its end.
|
|
|
|
*/
|
2021-01-19 01:11:20 +01:00
|
|
|
getFmqUnsyncWrite(bool configureFmq, bool userFd) generates(bool ret, fmq_unsync<int32_t> mqDesc);
|
2016-10-15 01:48:01 +02:00
|
|
|
|
2017-03-28 23:40:58 +02:00
|
|
|
/**
|
2016-10-15 01:48:01 +02:00
|
|
|
* This method request the service to write into the synchronized read/write
|
|
|
|
* flavor of the FMQ.
|
|
|
|
*
|
2016-09-22 02:47:06 +02:00
|
|
|
* @param count Number to messages to write.
|
2016-10-15 01:48:01 +02:00
|
|
|
*
|
|
|
|
* @return ret True if the write operation was successful.
|
2016-09-22 02:47:06 +02:00
|
|
|
*/
|
2016-10-15 01:48:01 +02:00
|
|
|
requestWriteFmqSync(int32_t count) generates(bool ret);
|
2016-08-08 20:12:30 +02:00
|
|
|
|
2017-03-28 23:40:58 +02:00
|
|
|
/**
|
2016-10-15 01:48:01 +02:00
|
|
|
* This method request the service to read from the synchronized read/write
|
|
|
|
* FMQ.
|
|
|
|
*
|
2016-09-22 02:47:06 +02:00
|
|
|
* @param count Number to messages to read.
|
2016-10-15 01:48:01 +02:00
|
|
|
*
|
|
|
|
* @return ret True if the read operation was successful.
|
2016-09-22 02:47:06 +02:00
|
|
|
*/
|
2016-10-15 01:48:01 +02:00
|
|
|
requestReadFmqSync(int32_t count) generates(bool ret);
|
|
|
|
|
2017-03-28 23:40:58 +02:00
|
|
|
/**
|
2016-10-15 01:48:01 +02:00
|
|
|
* This method request the service to write into the unsynchronized flavor
|
|
|
|
* of FMQ.
|
|
|
|
*
|
|
|
|
* @param count Number to messages to write.
|
|
|
|
*
|
|
|
|
* @return ret True if the write operation was successful.
|
|
|
|
*/
|
|
|
|
requestWriteFmqUnsync(int32_t count) generates(bool ret);
|
|
|
|
|
2017-03-28 23:40:58 +02:00
|
|
|
/**
|
2016-10-15 01:48:01 +02:00
|
|
|
* This method request the service to read from the unsynchronized flavor of
|
|
|
|
* FMQ.
|
|
|
|
*
|
|
|
|
* @param count Number to messages to read.
|
|
|
|
*
|
|
|
|
* @return ret Will be True if the read operation was successful.
|
|
|
|
*/
|
|
|
|
requestReadFmqUnsync(int32_t count) generates(bool ret);
|
|
|
|
|
2017-03-28 23:40:58 +02:00
|
|
|
/**
|
2016-12-15 18:14:13 +01:00
|
|
|
* This method requests the service to trigger a blocking read.
|
|
|
|
*
|
|
|
|
* @param count Number of messages to read.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
oneway requestBlockingRead(int32_t count);
|
2017-01-05 01:19:36 +01:00
|
|
|
|
2017-03-28 23:40:58 +02:00
|
|
|
/**
|
2017-01-14 05:58:17 +01:00
|
|
|
* This method requests the service to trigger a blocking read using
|
|
|
|
* default Event Flag notification bits defined by the MessageQueue class.
|
|
|
|
*
|
|
|
|
* @param count Number of messages to read.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
oneway requestBlockingReadDefaultEventFlagBits(int32_t count);
|
|
|
|
|
2017-03-28 23:40:58 +02:00
|
|
|
/**
|
2017-01-05 01:19:36 +01:00
|
|
|
* This method requests the service to repeatedly trigger blocking reads.
|
|
|
|
*
|
|
|
|
* @param count Number of messages to read in a single blocking read.
|
|
|
|
* @param numIter Number of blocking reads to trigger.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
oneway requestBlockingReadRepeat(int32_t count, int32_t numIter);
|
|
|
|
|
2016-08-08 20:12:30 +02:00
|
|
|
};
|