Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit b4358455 authored by Hridya Valsaraju's avatar Hridya Valsaraju
Browse files

Add methods to test flavor of FMQ supporting unsynchronized writes.

Test: Built and ran the unit tests.
Bug: 31223183

Change-Id: Ib0c52c4d17d31a24f4c5f5cd96547bcfae673725
parent f7ad111d
Loading
Loading
Loading
Loading
+47 −10
Original line number Diff line number Diff line
@@ -18,9 +18,10 @@ package android.hardware.tests.msgq@1.0;

interface ITestMsgQ {
    /*
     * This method requests the service to set up Synchronous read/write
     * This method requests the service to set up a synchronous read/write
     * wait-free FMQ with the client as reader.
     * @return ret Will be true if the setup is successful, false otherwise.
     *
     * @return ret True if the setup is successful.
     * @return mqDesc This structure describes the FMQ that was
     * set up by the service. Client can use it to set up the FMQ at its end.
     */
@@ -28,18 +29,54 @@ interface ITestMsgQ {
        generates(bool ret, MQDescriptorSync mqDesc);

    /*
     * This method request the service to write into the FMQ.
     * This method requests the service to set up an unsynchronized write
     * wait-free FMQ with the client as reader.
     *
     * @return ret True if the setup is successful.
     * @return mqDesc This structure describes the FMQ that was
     * set up by the service. Client can use it to set up the FMQ at its end.
     */
    configureFmqUnsyncWrite()
        generates(bool ret, MQDescriptorUnsync mqDesc);

    /*
     * This method request the service to write into the synchronized read/write
     * flavor of the FMQ.
     *
     * @param count Number to messages to write.
     * @return ret Will be true if the write operation was successful,
     * false otherwise.
     *
     * @return ret True if the write operation was successful.
     */
    requestWrite(int32_t count) generates(bool ret);
    requestWriteFmqSync(int32_t count) generates(bool ret);

    /*
     * This method request the service to read from the FMQ.
     * This method request the service to read from the synchronized read/write
     * FMQ.
     *
     * @param count Number to messages to read.
     * @return ret Will be true if the read operation was successful, false
     * otherwise.
     *
     * @return ret True if the read operation was successful.
     */
    requestRead(int32_t count) generates(bool ret);
    requestReadFmqSync(int32_t count) generates(bool ret);

    /*
     * 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);

    /*
     * 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);

};