140 lines
3.6 KiB
Plaintext
Raw Normal View History

2018-01-29 00:30:36 +08:00
// Copyright 2017 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
module device.mojom;
struct SerialDeviceInfo {
string path;
uint16 vendor_id;
bool has_vendor_id = false;
uint16 product_id;
bool has_product_id = false;
string? display_name;
};
enum SerialSendError {
NONE,
DISCONNECTED,
PENDING,
TIMEOUT,
SYSTEM_ERROR,
};
enum SerialReceiveError {
NONE,
DISCONNECTED,
TIMEOUT,
DEVICE_LOST,
BREAK,
FRAME_ERROR,
OVERRUN,
BUFFER_OVERFLOW,
PARITY_ERROR,
SYSTEM_ERROR,
};
enum SerialDataBits {
NONE,
SEVEN,
EIGHT,
};
enum SerialParityBit {
NONE,
NO_PARITY,
ODD,
EVEN,
};
enum SerialStopBits {
NONE,
ONE,
TWO,
};
struct SerialConnectionOptions {
uint32 bitrate = 0;
SerialDataBits data_bits = NONE;
SerialParityBit parity_bit = NONE;
SerialStopBits stop_bits = NONE;
bool cts_flow_control;
bool has_cts_flow_control = false;
};
struct SerialConnectionInfo {
uint32 bitrate = 0;
SerialDataBits data_bits = NONE;
SerialParityBit parity_bit = NONE;
SerialStopBits stop_bits = NONE;
bool cts_flow_control;
};
struct SerialHostControlSignals {
bool dtr;
bool has_dtr = false;
bool rts;
bool has_rts = false;
};
struct SerialDeviceControlSignals {
bool dcd;
bool cts;
bool ri;
bool dsr;
};
// Discovers and enumerates serial devices available to the host.
interface SerialDeviceEnumerator {
GetDevices() => (array<SerialDeviceInfo> devices);
};
// Performs asynchronous I/O on serial devices.
interface SerialIoHandler {
// Initiates an Open of the device then returns result.
Open(string port, SerialConnectionOptions options) => (bool success);
// Performs a Read operation then returns retrieved data and the
// result. Note that the Read may succeed partially, means that even if
// |error| indicates an error other than NONE, |data| may still contain
// some retrieved data with the max size |bytes|. Behavior is undefined if
// this is called while a Read is already pending.
Read(uint32 bytes) => (array<uint8> data, SerialReceiveError error);
// Performs a Write operation then returns written data and the result.
// Note that the Write may succeed partially, means that even if |error|
// indicates an error other than NONE, |bytes_written| bytes have already been
// written although it may be <= size of |data|. Behavior is undefined if this
// is called while a Write is already pending.
Write(array<uint8> data) => (uint32 bytes_written, SerialSendError error);
// Attempts to cancel a pending read operation.
CancelRead(SerialReceiveError reason);
// Attempts to cancel a pending write operation.
CancelWrite(SerialSendError reason);
// Flushes input and output buffers.
Flush() => (bool success);
// Reads current control signals (DCD, CTS, etc.).
GetControlSignals() => (SerialDeviceControlSignals signals);
// Sets one or more control signals (DTR and/or RTS) and returns result.
SetControlSignals(SerialHostControlSignals signals) => (bool success);
// Performs platform-specific port configuration and returns result.
ConfigurePort(SerialConnectionOptions options) => (bool success);
// Performs a platform-specific port configuration query and returns got info.
GetPortInfo() => (SerialConnectionInfo info);
// Initiates a BREAK signal. Places the transmission line in a break state
// until the |ClearBreak| is called.
SetBreak() => (bool success);
// Terminates the BREAK signal. Places the transmission line in a nonbreak
// state.
ClearBreak() => (bool success);
};