186d7f5d3SJohn Marino# 286d7f5d3SJohn Marino# Copyright (c) 1999 Nicolas Souchu 386d7f5d3SJohn Marino# All rights reserved. 486d7f5d3SJohn Marino# 586d7f5d3SJohn Marino# Redistribution and use in source and binary forms, with or without 686d7f5d3SJohn Marino# modification, are permitted provided that the following conditions 786d7f5d3SJohn Marino# are met: 886d7f5d3SJohn Marino# 1. Redistributions of source code must retain the above copyright 986d7f5d3SJohn Marino# notice, this list of conditions and the following disclaimer. 1086d7f5d3SJohn Marino# 2. Redistributions in binary form must reproduce the above copyright 1186d7f5d3SJohn Marino# notice, this list of conditions and the following disclaimer in the 1286d7f5d3SJohn Marino# documentation and/or other materials provided with the distribution. 1386d7f5d3SJohn Marino# 1486d7f5d3SJohn Marino# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 1586d7f5d3SJohn Marino# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 1686d7f5d3SJohn Marino# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 1786d7f5d3SJohn Marino# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 1886d7f5d3SJohn Marino# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 1986d7f5d3SJohn Marino# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 2086d7f5d3SJohn Marino# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 2186d7f5d3SJohn Marino# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 2286d7f5d3SJohn Marino# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 2386d7f5d3SJohn Marino# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 2486d7f5d3SJohn Marino# SUCH DAMAGE. 2586d7f5d3SJohn Marino# 2686d7f5d3SJohn Marino# $FreeBSD: src/sys/dev/ppbus/ppbus_if.m,v 1.1.2.1 2000/05/24 00:20:57 n_hibma Exp $ 2786d7f5d3SJohn Marino# $DragonFly: src/sys/bus/ppbus/ppbus_if.m,v 1.3 2003/08/07 21:16:47 dillon Exp $ 2886d7f5d3SJohn Marino# 2986d7f5d3SJohn Marino 3086d7f5d3SJohn Marino#include <sys/bus.h> 3186d7f5d3SJohn Marino#include <bus/ppbus/ppbconf.h> 3286d7f5d3SJohn Marino 3386d7f5d3SJohn MarinoINTERFACE ppbus; 3486d7f5d3SJohn Marino 3586d7f5d3SJohn Marino# 3686d7f5d3SJohn Marino# Do low level i/o operations 3786d7f5d3SJohn Marino# 3886d7f5d3SJohn MarinoMETHOD u_char io { 3986d7f5d3SJohn Marino device_t dev; 4086d7f5d3SJohn Marino int opcode; 4186d7f5d3SJohn Marino u_char *addr; 4286d7f5d3SJohn Marino int cnt; 4386d7f5d3SJohn Marino u_char byte; 4486d7f5d3SJohn Marino}; 4586d7f5d3SJohn Marino 4686d7f5d3SJohn Marino# 4786d7f5d3SJohn Marino# Execution of a microsequence 4886d7f5d3SJohn Marino# 4986d7f5d3SJohn MarinoMETHOD int exec_microseq { 5086d7f5d3SJohn Marino device_t dev; 5186d7f5d3SJohn Marino struct ppb_microseq **ppb_microseq; 5286d7f5d3SJohn Marino}; 5386d7f5d3SJohn Marino 5486d7f5d3SJohn Marino# 5586d7f5d3SJohn Marino# Reset EPP timeout 5686d7f5d3SJohn Marino# 5786d7f5d3SJohn MarinoMETHOD int reset_epp { 5886d7f5d3SJohn Marino device_t dev; 5986d7f5d3SJohn Marino} 6086d7f5d3SJohn Marino 6186d7f5d3SJohn Marino# 6286d7f5d3SJohn Marino# Set chipset mode 6386d7f5d3SJohn Marino# 6486d7f5d3SJohn MarinoMETHOD int setmode { 6586d7f5d3SJohn Marino device_t dev; 6686d7f5d3SJohn Marino int mode; 6786d7f5d3SJohn Marino} 6886d7f5d3SJohn Marino 6986d7f5d3SJohn Marino# 7086d7f5d3SJohn Marino# Synchronize ECP FIFO 7186d7f5d3SJohn Marino# 7286d7f5d3SJohn MarinoMETHOD int ecp_sync { 7386d7f5d3SJohn Marino device_t dev; 7486d7f5d3SJohn Marino} 7586d7f5d3SJohn Marino 7686d7f5d3SJohn Marino# 7786d7f5d3SJohn Marino# Do chipset dependent low level read 7886d7f5d3SJohn Marino# 7986d7f5d3SJohn MarinoMETHOD int read { 8086d7f5d3SJohn Marino device_t dev; 8186d7f5d3SJohn Marino char *buf; 8286d7f5d3SJohn Marino int len; 8386d7f5d3SJohn Marino int how; 8486d7f5d3SJohn Marino} 8586d7f5d3SJohn Marino 8686d7f5d3SJohn Marino# 8786d7f5d3SJohn Marino# Do chipset dependent low level write 8886d7f5d3SJohn Marino# 8986d7f5d3SJohn MarinoMETHOD int write { 9086d7f5d3SJohn Marino device_t dev; 9186d7f5d3SJohn Marino char *buf; 9286d7f5d3SJohn Marino int len; 9386d7f5d3SJohn Marino int how; 9486d7f5d3SJohn Marino} 95