/*1* Copyright (c) 2000, 2001, 2002, 2003, 2004, 2005, 2008, 20092* The President and Fellows of Harvard College.3*4* Redistribution and use in source and binary forms, with or without5* modification, are permitted provided that the following conditions6* are met:7* 1. Redistributions of source code must retain the above copyright8* notice, this list of conditions and the following disclaimer.9* 2. Redistributions in binary form must reproduce the above copyright10* notice, this list of conditions and the following disclaimer in the11* documentation and/or other materials provided with the distribution.12* 3. Neither the name of the University nor the names of its contributors13* may be used to endorse or promote products derived from this software14* without specific prior written permission.15*16* THIS SOFTWARE IS PROVIDED BY THE UNIVERSITY AND CONTRIBUTORS ``AS IS'' AND17* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE18* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE19* ARE DISCLAIMED. IN NO EVENT SHALL THE UNIVERSITY OR CONTRIBUTORS BE LIABLE20* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL21* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS22* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)23* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT24* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY25* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF26* SUCH DAMAGE.27*/2829#include <types.h>30#include <lib.h>31#include <lamebus/lamebus.h>32#include <lamebus/lser.h>33#include "autoconf.h"3435/* Lowest revision we support */36#define LOW_VERSION 137/* Highest revision we support */38#define HIGH_VERSION 13940/*41* wrappers to satisfy the type system42*/43static44void45do_lamebus_mask_interrupt(void *bus, uint32_t buspos)46{47struct lamebus_softc *lb = bus;48lamebus_mask_interrupt(lb, buspos);49}5051static52void53do_lamebus_unmask_interrupt(void *bus, uint32_t buspos)54{55struct lamebus_softc *lb = bus;56lamebus_unmask_interrupt(lb, buspos);57}5859/*60* attachment function61*/62struct lser_softc *63attach_lser_to_lamebus(int lserno, struct lamebus_softc *sc)64{65struct lser_softc *ls;66int slot = lamebus_probe(sc, LB_VENDOR_CS161, LBCS161_SERIAL,67LOW_VERSION, HIGH_VERSION);68if (slot < 0) {69return NULL;70}7172ls = kmalloc(sizeof(struct lser_softc));73if (ls==NULL) {74return NULL;75}7677(void)lserno; // unused7879ls->ls_busdata = sc;80ls->ls_buspos = slot;81ls->ls_maskinterrupt = do_lamebus_mask_interrupt;82ls->ls_unmaskinterrupt = do_lamebus_unmask_interrupt;8384lamebus_mark(sc, slot);85lamebus_attach_interrupt(sc, slot, ls, lser_irq);8687return ls;88}899091