OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [linux/] [linux-2.4/] [drivers/] [char/] [ipmi/] [ipmi_kcs_sm.h] - Rev 1765

Compare with Previous | Blame | View Log

/*
 * ipmi_kcs_sm.h
 *
 * State machine for handling IPMI KCS interfaces.
 *
 * Author: MontaVista Software, Inc.
 *         Corey Minyard <minyard@mvista.com>
 *         source@mvista.com
 *
 * Copyright 2002 MontaVista Software Inc.
 *
 *  This program is free software; you can redistribute it and/or modify it
 *  under the terms of the GNU General Public License as published by the
 *  Free Software Foundation; either version 2 of the License, or (at your
 *  option) any later version.
 *
 *
 *  THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED
 *  WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
 *  MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
 *  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
 *  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
 *  BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
 *  OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 *  ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
 *  TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
 *  USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 *
 *  You should have received a copy of the GNU General Public License along
 *  with this program; if not, write to the Free Software Foundation, Inc.,
 *  675 Mass Ave, Cambridge, MA 02139, USA.
 */
 
struct kcs_data;
 
void init_kcs_data(struct kcs_data *kcs,
		   unsigned int    port,
		   unsigned char   *addr);
 
/* Start a new transaction in the state machine.  This will return -2
   if the state machine is not idle, -1 if the size is invalid (to
   large or too small), or 0 if the transaction is successfully
   completed. */
int start_kcs_transaction(struct kcs_data *kcs, char *data, unsigned int size);
 
/* Return the results after the transaction.  This will return -1 if
   the buffer is too small, zero if no transaction is present, or the
   actual length of the result data. */
int kcs_get_result(struct kcs_data *kcs, unsigned char *data, int length);
 
enum kcs_result
{
	KCS_CALL_WITHOUT_DELAY, /* Call the driver again immediately */
	KCS_CALL_WITH_DELAY,	/* Delay some before calling again. */
	KCS_TRANSACTION_COMPLETE, /* A transaction is finished. */
	KCS_SM_IDLE,		/* The SM is in idle state. */
	KCS_SM_HOSED,		/* The hardware violated the state machine. */
	KCS_ATTN		/* The hardware is asserting attn and the
				   state machine is idle. */
};
 
/* Call this periodically (for a polled interface) or upon receiving
   an interrupt (for a interrupt-driven interface).  If interrupt
   driven, you should probably poll this periodically when not in idle
   state.  This should be called with the time that passed since the
   last call, if it is significant.  Time is in microseconds. */
enum kcs_result kcs_event(struct kcs_data *kcs, long time);
 
/* Return the size of the KCS structure in bytes. */
int kcs_size(void);
 

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.