| /* SPDX-License-Identifier: GPL-2.0 */ |
| /* |
| * IMPORTANT: The following constants must match the ones used and defined in |
| * external/qemu/include/hw/misc/goldfish_pipe.h |
| */ |
| |
| #ifndef GOLDFISH_PIPE_QEMU_H |
| #define GOLDFISH_PIPE_QEMU_H |
| |
| /* List of bitflags returned in status of CMD_POLL command */ |
| enum PipePollFlags { |
| PIPE_POLL_IN = 1 << 0, |
| PIPE_POLL_OUT = 1 << 1, |
| PIPE_POLL_HUP = 1 << 2 |
| }; |
| |
| /* Possible status values used to signal errors */ |
| enum PipeErrors { |
| PIPE_ERROR_INVAL = -1, |
| PIPE_ERROR_AGAIN = -2, |
| PIPE_ERROR_NOMEM = -3, |
| PIPE_ERROR_IO = -4 |
| }; |
| |
| /* Bit-flags used to signal events from the emulator */ |
| enum PipeWakeFlags { |
| /* emulator closed pipe */ |
| PIPE_WAKE_CLOSED = 1 << 0, |
| |
| /* pipe can now be read from */ |
| PIPE_WAKE_READ = 1 << 1, |
| |
| /* pipe can now be written to */ |
| PIPE_WAKE_WRITE = 1 << 2, |
| |
| /* unlock this pipe's DMA buffer */ |
| PIPE_WAKE_UNLOCK_DMA = 1 << 3, |
| |
| /* unlock DMA buffer of the pipe shared to this pipe */ |
| PIPE_WAKE_UNLOCK_DMA_SHARED = 1 << 4, |
| }; |
| |
| /* Possible pipe closing reasons */ |
| enum PipeCloseReason { |
| /* guest sent a close command */ |
| PIPE_CLOSE_GRACEFUL = 0, |
| |
| /* guest rebooted, we're closing the pipes */ |
| PIPE_CLOSE_REBOOT = 1, |
| |
| /* close old pipes on snapshot load */ |
| PIPE_CLOSE_LOAD_SNAPSHOT = 2, |
| |
| /* some unrecoverable error on the pipe */ |
| PIPE_CLOSE_ERROR = 3, |
| }; |
| |
| /* Bit flags for the 'flags' field */ |
| enum PipeFlagsBits { |
| BIT_CLOSED_ON_HOST = 0, /* pipe closed by host */ |
| BIT_WAKE_ON_WRITE = 1, /* want to be woken on writes */ |
| BIT_WAKE_ON_READ = 2, /* want to be woken on reads */ |
| }; |
| |
| enum PipeRegs { |
| PIPE_REG_CMD = 0, |
| |
| PIPE_REG_SIGNAL_BUFFER_HIGH = 4, |
| PIPE_REG_SIGNAL_BUFFER = 8, |
| PIPE_REG_SIGNAL_BUFFER_COUNT = 12, |
| |
| PIPE_REG_OPEN_BUFFER_HIGH = 20, |
| PIPE_REG_OPEN_BUFFER = 24, |
| |
| PIPE_REG_VERSION = 36, |
| |
| PIPE_REG_GET_SIGNALLED = 48, |
| }; |
| |
| enum PipeCmdCode { |
| /* to be used by the pipe device itself */ |
| PIPE_CMD_OPEN = 1, |
| |
| PIPE_CMD_CLOSE, |
| PIPE_CMD_POLL, |
| PIPE_CMD_WRITE, |
| PIPE_CMD_WAKE_ON_WRITE, |
| PIPE_CMD_READ, |
| PIPE_CMD_WAKE_ON_READ, |
| |
| /* |
| * TODO(zyy): implement a deferred read/write execution to allow |
| * parallel processing of pipe operations on the host. |
| */ |
| PIPE_CMD_WAKE_ON_DONE_IO, |
| }; |
| |
| #endif /* GOLDFISH_PIPE_QEMU_H */ |