/* Copyright 2011 Google Inc. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, * USA. * * Project home page: http://code.google.com/p/usb-serial-for-android/ */ package com.hoho.android.usbserial.driver; import android.hardware.usb.UsbDevice; import android.hardware.usb.UsbDeviceConnection; import java.io.IOException; /** * Driver interface for a supported USB serial device. * * @author mike wakerly (opensource@hoho.com) */ public abstract class UsbSerialDriver { public static final int DEFAULT_READ_BUFFER_SIZE = 16 * 1024; public static final int DEFAULT_WRITE_BUFFER_SIZE = 16 * 1024; protected final UsbDevice mDevice; protected final UsbDeviceConnection mConnection; protected final Object mReadBufferLock = new Object(); protected final Object mWriteBufferLock = new Object(); /** Internal read buffer. Guarded by {@link #mReadBufferLock}. */ protected byte[] mReadBuffer; /** Internal write buffer. Guarded by {@link #mWriteBufferLock}. */ protected byte[] mWriteBuffer; public UsbSerialDriver(UsbDevice device, UsbDeviceConnection connection) { mDevice = device; mConnection = connection; mReadBuffer = new byte[DEFAULT_READ_BUFFER_SIZE]; mWriteBuffer = new byte[DEFAULT_WRITE_BUFFER_SIZE]; } /** * Opens and initializes the device as a USB serial device. Upon success, * caller must ensure that {@link #close()} is eventually called. * * @throws IOException on error opening or initializing the device. */ public abstract void open() throws IOException; /** * Closes the serial device. * * @throws IOException on error closing the device. */ public abstract void close() throws IOException; /** * Reads as many bytes as possible into the destination buffer. * * @param dest the destination byte buffer * @param timeoutMillis the timeout for reading * @return the actual number of bytes read * @throws IOException if an error occurred during reading */ public abstract int read(final byte[] dest, final int timeoutMillis) throws IOException; /** * Writes as many bytes as possible from the source buffer. * * @param src the source byte buffer * @param timeoutMillis the timeout for writing * @return the actual number of bytes written * @throws IOException if an error occurred during writing */ public abstract int write(final byte[] src, final int timeoutMillis) throws IOException; /** * Sets the baud rate of the serial device. * * @param baudRate the desired baud rate, in bits per second * @return the actual rate set * @throws IOException on error setting the baud rate */ public abstract int setBaudRate(final int baudRate) throws IOException; /** * Gets the CD (Carrier Detect) bit from the underlying UART. * * @return the current state, or {@code false} if not supported. * @throws IOException if an error occurred during reading */ public abstract boolean getCD() throws IOException; /** * Gets the CTS (Clear To Send) bit from the underlying UART. * * @return the current state, or {@code false} if not supported. * @throws IOException if an error occurred during reading */ public abstract boolean getCTS() throws IOException; /** * Gets the DSR (Data Set Ready) bit from the underlying UART. * * @return the current state, or {@code false} if not supported. * @throws IOException if an error occurred during reading */ public abstract boolean getDSR() throws IOException; /** * Gets the DTR (Data Terminal Ready) bit from the underlying UART. * * @return the current state, or {@code false} if not supported. * @throws IOException if an error occurred during reading */ public abstract boolean getDTR() throws IOException; /** * Sets the DTR (Data Terminal Ready) bit on the underlying UART, if * supported. * * @param value the value to set * @throws IOException if an error occurred during writing */ public abstract boolean setDTR(boolean value) throws IOException; /** * Gets the RI (Ring Indicator) bit from the underlying UART. * * @return the current state, or {@code false} if not supported. * @throws IOException if an error occurred during reading */ public abstract boolean getRI() throws IOException; /** * Gets the RTS (Request To Send) bit from the underlying UART. * * @return the current state, or {@code false} if not supported. * @throws IOException if an error occurred during reading */ public abstract boolean getRTS() throws IOException; /** * Sets the RTS (Request To Send) bit on the underlying UART, if * supported. * * @param value thje value to set * @throws IOException if an error occurred during writing */ public abstract boolean setRTS(boolean value) throws IOException; /** * Returns the currently-bound USB device. * * @return the device */ public final UsbDevice getDevice() { return mDevice; } /** * Sets the size of the internal buffer used to exchange data with the USB * stack for read operations. Most users should not need to change this. * * @param bufferSize the size in bytes */ public final void setReadBufferSize(int bufferSize) { synchronized (mReadBufferLock) { if (bufferSize == mReadBuffer.length) { return; } mReadBuffer = new byte[bufferSize]; } } /** * Sets the size of the internal buffer used to exchange data with the USB * stack for write operations. Most users should not need to change this. * * @param bufferSize the size in bytes */ public final void setWriteBufferSize(int bufferSize) { synchronized (mWriteBufferLock) { if (bufferSize == mWriteBuffer.length) { return; } mWriteBuffer = new byte[bufferSize]; } } }