Blame src/interface.c

Packit d36e9b
/*
Packit d36e9b
 * libieee1284 - IEEE 1284 library
Packit d36e9b
 * Copyright (C) 2001, 2002, 2003  Tim Waugh <twaugh@redhat.com>
Packit d36e9b
 *
Packit d36e9b
 * This program is free software; you can redistribute it and/or modify
Packit d36e9b
 * it under the terms of the GNU General Public License as published by
Packit d36e9b
 * the Free Software Foundation; either version 2 of the License, or
Packit d36e9b
 * (at your option) any later version.
Packit d36e9b
 *
Packit d36e9b
 * This program is distributed in the hope that it will be useful,
Packit d36e9b
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit d36e9b
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit d36e9b
 * GNU General Public License for more details.
Packit d36e9b
 *
Packit d36e9b
 * You should have received a copy of the GNU General Public License
Packit d36e9b
 * along with this program; if not, write to the Free Software
Packit d36e9b
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
Packit d36e9b
 */
Packit d36e9b
Packit d36e9b
#include "ieee1284.h"
Packit d36e9b
#include "debug.h"
Packit d36e9b
#include "detect.h"
Packit d36e9b
Packit d36e9b
/* ieee1284_open is in state.c */
Packit d36e9b
Packit d36e9b
static const char *needs_open_port = \
Packit d36e9b
"%s called for port that wasn't opened (use ieee1284_open first)\n";
Packit d36e9b
static const char *needs_claimed_port = \
Packit d36e9b
"%s called for port that wasn't claimed (use ieee1284_claim first)\n";
Packit d36e9b
Packit d36e9b
int
Packit d36e9b
ieee1284_ref (struct parport *port)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
  return ++priv->ref;
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
int
Packit d36e9b
ieee1284_unref (struct parport *port)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
  if (priv->opened && priv->ref == 1)
Packit d36e9b
    {
Packit d36e9b
      int ret;
Packit d36e9b
      debugprintf ("ieee1284_unref called for last reference to open port!\n");
Packit d36e9b
      ret = ieee1284_close (port);
Packit d36e9b
      if (ret == E1284_OK)
Packit d36e9b
	return 0;
Packit d36e9b
Packit d36e9b
      return 1;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return deref_port (port);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
int
Packit d36e9b
ieee1284_close (struct parport *port)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
  if (!priv->opened)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_open_port, "ieee1284_close");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
  if (priv->fn->cleanup)
Packit d36e9b
    priv->fn->cleanup (priv);
Packit d36e9b
  priv->opened = 0;
Packit d36e9b
  deref_port (port);
Packit d36e9b
  return E1284_OK;
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
int
Packit d36e9b
ieee1284_claim (struct parport *port)
Packit d36e9b
{
Packit d36e9b
  int ret = E1284_OK;
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->opened)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_open_port, "ieee1284_claim");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  if (priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf ("ieee1284_claim called for a port already claimed\n");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  if (priv->fn->claim)
Packit d36e9b
    ret = priv->fn->claim (priv);
Packit d36e9b
Packit d36e9b
  if (ret == E1284_OK)
Packit d36e9b
    priv->claimed = 1;
Packit d36e9b
Packit d36e9b
  return ret;
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
int
Packit d36e9b
ieee1284_get_irq_fd (struct parport *port)
Packit d36e9b
{
Packit d36e9b
  int ret = E1284_NOTAVAIL;
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->opened)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_open_port, "ieee1284_get_irq_fd");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  if (priv->fn->get_irq_fd)
Packit d36e9b
    ret = priv->fn->get_irq_fd (priv);
Packit d36e9b
  return ret;
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
int
Packit d36e9b
ieee1284_clear_irq (struct parport *port, unsigned int *count)
Packit d36e9b
{
Packit d36e9b
  int ret = E1284_NOTAVAIL;
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (priv->fn->clear_irq)
Packit d36e9b
    {
Packit d36e9b
      if (!priv->claimed)
Packit d36e9b
	{
Packit d36e9b
	  debugprintf (needs_claimed_port, "ieee1284_clear_irq");
Packit d36e9b
	  return E1284_INVALIDPORT;
Packit d36e9b
	}
Packit d36e9b
Packit d36e9b
      ret = priv->fn->clear_irq (priv, count);
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return ret;
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
void
Packit d36e9b
ieee1284_release (struct parport *port)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
  if (priv->claimed && priv->fn->release)
Packit d36e9b
    priv->fn->release (priv);
Packit d36e9b
  priv->claimed = 0;
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
int
Packit d36e9b
ieee1284_read_data (struct parport *port)
Packit d36e9b
{
Packit d36e9b
  int ret = -E1284_NOTAVAIL;
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_read_data");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  if (priv->fn->read_data)
Packit d36e9b
    ret = priv->fn->read_data (priv);
Packit d36e9b
Packit d36e9b
  return ret;
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
void
Packit d36e9b
ieee1284_write_data (struct parport *port, unsigned char st)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
  if (priv->claimed)
Packit d36e9b
    priv->fn->write_data (priv, st);
Packit d36e9b
  else
Packit d36e9b
    debugprintf (needs_claimed_port, "ieee1284_write_data");
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
int
Packit d36e9b
ieee1284_wait_data (struct parport *port,
Packit d36e9b
		    unsigned char mask,
Packit d36e9b
		    unsigned char val,
Packit d36e9b
		    struct timeval *timeout)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_wait_data");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return priv->fn->wait_data (priv, mask, val, timeout);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
int
Packit d36e9b
ieee1284_data_dir (struct parport *port, int reverse)
Packit d36e9b
{
Packit d36e9b
  int ret = E1284_NOTAVAIL;
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_data_dir");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  if (priv->fn->data_dir)
Packit d36e9b
    ret = priv->fn->data_dir (priv, reverse);
Packit d36e9b
Packit d36e9b
  return ret;
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
int
Packit d36e9b
ieee1284_read_status (struct parport *port)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_read_status");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return priv->fn->read_status (priv);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
int
Packit d36e9b
ieee1284_wait_status (struct parport *port,
Packit d36e9b
		      unsigned char mask,
Packit d36e9b
		      unsigned char val,
Packit d36e9b
		      struct timeval *timeout)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_wait_status");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return priv->fn->wait_status (priv, mask, val, timeout);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
int
Packit d36e9b
ieee1284_read_control (struct parport *port)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_read_control");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return priv->fn->read_control (priv);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
void
Packit d36e9b
ieee1284_write_control (struct parport *port, unsigned char ct)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
  if (priv->claimed)
Packit d36e9b
    priv->fn->write_control (priv, ct);
Packit d36e9b
  else
Packit d36e9b
    debugprintf (needs_claimed_port, "ieee1284_write_control");
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
void
Packit d36e9b
ieee1284_frob_control (struct parport *port, unsigned char mask,
Packit d36e9b
		       unsigned char val)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (priv->claimed)
Packit d36e9b
    priv->fn->frob_control (priv, mask, val);
Packit d36e9b
  else
Packit d36e9b
    debugprintf (needs_claimed_port, "ieee1284_frob_control");
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
int
Packit d36e9b
ieee1284_do_nack_handshake (struct parport *port,
Packit d36e9b
			    unsigned char ct_before,
Packit d36e9b
			    unsigned char ct_after,
Packit d36e9b
			    struct timeval *timeout)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_do_nack_handshake");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return priv->fn->do_nack_handshake (priv, ct_before, ct_after, timeout);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
int
Packit d36e9b
ieee1284_negotiate (struct parport *port, int mode)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_negotiate");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return priv->fn->negotiate (priv, mode);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
void
Packit d36e9b
ieee1284_terminate (struct parport *port)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
  if (priv->claimed)
Packit d36e9b
    priv->fn->terminate (priv);
Packit d36e9b
  else
Packit d36e9b
    debugprintf (needs_claimed_port, "ieee1284_terminate");
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
int
Packit d36e9b
ieee1284_ecp_fwd_to_rev (struct parport *port)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_ecp_fwd_to_rev");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return priv->fn->ecp_fwd_to_rev (priv);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
int
Packit d36e9b
ieee1284_ecp_rev_to_fwd (struct parport *port)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_ecp_rev_to_fwd");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return priv->fn->ecp_rev_to_fwd (priv);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
ssize_t
Packit d36e9b
ieee1284_nibble_read (struct parport *port, int flags,
Packit d36e9b
		      char *buffer, size_t len)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_nibble_read");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return priv->fn->nibble_read (priv, flags, buffer, len);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
ssize_t
Packit d36e9b
ieee1284_compat_write (struct parport *port, int flags,
Packit d36e9b
		       const char *buffer, size_t len)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_compat_write");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return priv->fn->compat_write (priv, flags, buffer, len);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
ssize_t
Packit d36e9b
ieee1284_byte_read (struct parport *port, int flags, 
Packit d36e9b
		    char *buffer, size_t len)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_byte_read");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return priv->fn->byte_read (priv, flags, buffer, len);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
ssize_t
Packit d36e9b
ieee1284_epp_read_data (struct parport *port, int flags, char *buffer,
Packit d36e9b
			size_t len)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_epp_read_data");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return priv->fn->epp_read_data (priv, flags, buffer, len);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
ssize_t
Packit d36e9b
ieee1284_epp_write_data (struct parport *port, int flags,
Packit d36e9b
			 const char *buffer, size_t len)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_epp_write_data");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return priv->fn->epp_write_data (priv, flags, buffer, len);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
ssize_t
Packit d36e9b
ieee1284_epp_read_addr (struct parport *port, int flags, char *buffer,
Packit d36e9b
			size_t len)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_epp_read_addr");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return priv->fn->epp_read_addr (priv, flags, buffer, len);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
ssize_t
Packit d36e9b
ieee1284_epp_write_addr (struct parport *port, int flags,
Packit d36e9b
			 const char *buffer, size_t len)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_epp_write_addr");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return priv->fn->epp_write_addr (priv, flags, buffer, len);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
ssize_t
Packit d36e9b
ieee1284_ecp_read_data (struct parport *port, int flags, char *buffer,
Packit d36e9b
			size_t len)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_ecp_read_data");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return priv->fn->ecp_read_data (priv, flags, buffer, len);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
ssize_t
Packit d36e9b
ieee1284_ecp_write_data (struct parport *port, int flags,
Packit d36e9b
			 const char *buffer, size_t len)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_ecp_write_data");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return priv->fn->ecp_write_data (priv, flags, buffer, len);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
ssize_t
Packit d36e9b
ieee1284_ecp_read_addr (struct parport *port, int flags,
Packit d36e9b
			char *buffer, size_t len)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_ecp_read_addr");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return priv->fn->ecp_read_addr (priv, flags, buffer, len);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
ssize_t
Packit d36e9b
ieee1284_ecp_write_addr (struct parport *port, int flags,
Packit d36e9b
			 const char *buffer, size_t len)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
Packit d36e9b
  if (!priv->claimed)
Packit d36e9b
    {
Packit d36e9b
      debugprintf (needs_claimed_port, "ieee1284_ecp_write_addr");
Packit d36e9b
      return E1284_INVALIDPORT;
Packit d36e9b
    }
Packit d36e9b
Packit d36e9b
  return priv->fn->ecp_write_addr (priv, flags, buffer, len);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
struct timeval *
Packit d36e9b
ieee1284_set_timeout (struct parport *port, struct timeval *timeout)
Packit d36e9b
{
Packit d36e9b
  struct parport_internal *priv = port->priv;
Packit d36e9b
  return priv->fn->set_timeout (priv, timeout);
Packit d36e9b
}
Packit d36e9b
Packit d36e9b
/*
Packit d36e9b
 * Local Variables:
Packit d36e9b
 * eval: (c-set-style "gnu")
Packit d36e9b
 * End:
Packit d36e9b
 */