All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.wimpi.modbus.io.ModbusSerialTransport Maven / Gradle / Ivy

Go to download

jamod is an object oriented implementation of the Modbus protocol, realized 100% in Java. It allows to quickly realize master and slave applications in various transport flavors (IP and serial).

The newest version!
/***
 * Copyright 2002-2010 jamod development team
 *
 * 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.
 ***/

package net.wimpi.modbus.io;

import net.wimpi.modbus.Modbus;
import net.wimpi.modbus.ModbusIOException;
import net.wimpi.modbus.msg.ModbusMessage;
import net.wimpi.modbus.msg.ModbusRequest;
import net.wimpi.modbus.msg.ModbusResponse;
import net.wimpi.modbus.util.ModbusUtil;

import java.io.IOException;
import gnu.io.CommPort;
import java.io.InputStream;
import java.io.OutputStream;
import gnu.io.UnsupportedCommOperationException;

/**
 * Abstract base class for serial ModbusTransport
 * implementations.
 *
 * @author Dieter Wimberger
 * @author John Charlton
 *
 * @version @version@ (@date@)
 */
abstract public class ModbusSerialTransport
    implements ModbusTransport {
  protected CommPort  m_CommPort;
  protected boolean   m_Echo = false;     // require RS-485 echo processing

  /**
   * prepareStreams prepares the input and output streams of this
   * ModbusSerialTransport instance.
   *
   * @param in the input stream to be read from.
   * @param out the output stream to write to.
   * @throws IOException if an I\O error occurs.
   */
  abstract public void prepareStreams(InputStream in, OutputStream out)
      throws IOException;

  /**
   *  readResponse reads a response message from the slave
   *  responding to a master writeMessage request.
   *
   * @return a ModbusResponse value
   * @exception ModbusIOException if an error occurs
   */
  abstract public ModbusResponse readResponse()
      throws ModbusIOException;
  
  /**
   * The readRequest method listens continuously on the serial
   * input stream for master request messages and replies if the request slave
   * ID matches its own set in ModbusCoupler.getUnitID().
   *
   * @return a ModbusRequest value
   * @exception ModbusIOException if an error occurs
   */
  abstract public ModbusRequest readRequest()
    throws ModbusIOException;
  
  /**
   * The writeMessage method writes a modbus serial message to
   * its serial output stream to a specified slave unit ID.
   *
   * @param msg a ModbusMessage value
   * @exception ModbusIOException if an error occurs
   */
  abstract public void writeMessage(ModbusMessage msg)
    throws ModbusIOException;


  /**
   * The close method closes the serial input/output streams.
   *
   * @exception IOException if an error occurs
   */
  abstract public void close() throws IOException;
  
  /**
   * setCommPort sets the comm port member and prepares the input
   * and output streams to be used for reading from and writing to.
   *
   * @param cp the comm port to read from/write to.
   * @throws IOException if an I/O related error occurs.
   */
  public void setCommPort(CommPort cp) throws IOException {
    m_CommPort = cp;
    if (cp != null) {
      prepareStreams(cp.getInputStream(), cp.getOutputStream());
    }
  }
  
  /**
   * isEcho method returns the output echo state.
   *
   * @return a boolean value
   */
  public boolean isEcho() {
    return m_Echo;
  }//isEcho

  /**
   * setEcho method sets the output echo state.
   *
   * @param b a boolean value
   */
  public void setEcho(boolean b) {
    this.m_Echo = b;
  }//setEcho


  /**
   * Describe setReceiveThreshold method here.
   *
   * @param th an int value
   */
  public void setReceiveThreshold(int th) {
    try {
      m_CommPort.enableReceiveThreshold(th); /* chars */
    } catch (UnsupportedCommOperationException e) {
      System.out.println(e.getMessage());
    }
  }
  
  /**
   * Describe setReceiveTimeout method here.
   *
   * @param ms an int value
   */
  public void setReceiveTimeout(int ms) {
    try {
      m_CommPort.enableReceiveTimeout(ms); /* milliseconds */
    } catch (UnsupportedCommOperationException e) {
      System.out.println(e.getMessage());
    }
  }

  /**
   * Reads the own message echo produced in RS485 Echo Mode
   * within the given time frame.
   *
   * @param len is the length of the echo to read.  Timeout will occur if the
   * echo is not received in the time specified in the SerialConnection.
   *
   * @throws IOException if a I/O error occurred.
   */
  public void readEcho(int len) throws IOException {

    byte echoBuf[] = new byte[len];
    setReceiveThreshold(len);
    int echoLen = m_CommPort.getInputStream().read(echoBuf, 0, len);
    if (Modbus.debug)
      System.out.println("Echo: " +
                         ModbusUtil.toHex(echoBuf, 0, echoLen));
    m_CommPort.disableReceiveThreshold();
    if (echoLen != len) {
      if (Modbus.debug)
        System.err.println("Error: Transmit echo not received.");
      throw new IOException("Echo not received.");
    }
  }//readEcho

  
}//interface ModbusSerialTransport




© 2015 - 2024 Weber Informatics LLC | Privacy Policy