Home | History | Annotate | Line # | Download | only in ic
      1  1.2  jmcneill /* $NetBSD: pl061var.h,v 1.2 2018/10/21 18:31:14 jmcneill Exp $ */
      2  1.1  jmcneill 
      3  1.1  jmcneill /*
      4  1.1  jmcneill  * Copyright (c) 2018 Jonathan A. Kollasch
      5  1.1  jmcneill  * All rights reserved.
      6  1.1  jmcneill  *
      7  1.1  jmcneill  * Redistribution and use in source and binary forms, with or without
      8  1.1  jmcneill  * modification, are permitted provided that the following conditions
      9  1.1  jmcneill  * are met:
     10  1.1  jmcneill  * 1. Redistributions of source code must retain the above copyright
     11  1.1  jmcneill  *    notice, this list of conditions and the following disclaimer.
     12  1.1  jmcneill  * 2. Redistributions in binary form must reproduce the above copyright
     13  1.1  jmcneill  *    notice, this list of conditions and the following disclaimer in the
     14  1.1  jmcneill  *    documentation and/or other materials provided with the distribution.
     15  1.1  jmcneill  *
     16  1.1  jmcneill  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
     17  1.1  jmcneill  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     18  1.1  jmcneill  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     19  1.1  jmcneill  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
     20  1.1  jmcneill  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
     21  1.1  jmcneill  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
     22  1.1  jmcneill  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
     23  1.1  jmcneill  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
     24  1.1  jmcneill  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
     25  1.1  jmcneill  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
     26  1.1  jmcneill  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     27  1.1  jmcneill  */
     28  1.1  jmcneill 
     29  1.1  jmcneill #ifndef _PL061VAR_H
     30  1.1  jmcneill #define _PL061VAR_H
     31  1.1  jmcneill 
     32  1.1  jmcneill struct plgpio_softc {
     33  1.1  jmcneill 	device_t		sc_dev;
     34  1.1  jmcneill 	bus_space_tag_t		sc_bst;
     35  1.1  jmcneill 	bus_space_handle_t	sc_bsh;
     36  1.1  jmcneill 
     37  1.1  jmcneill 	struct gpio_chipset_tag	sc_gc;
     38  1.1  jmcneill 	gpio_pin_t		sc_pins[8];
     39  1.2  jmcneill 
     40  1.2  jmcneill 	uint32_t		sc_reserved_mask;
     41  1.1  jmcneill };
     42  1.1  jmcneill 
     43  1.1  jmcneill void	plgpio_attach(struct plgpio_softc *);
     44  1.1  jmcneill 
     45  1.1  jmcneill int	plgpio_pin_read(void *, int);
     46  1.1  jmcneill void	plgpio_pin_write(void *, int, int);
     47  1.1  jmcneill void	plgpio_pin_ctl(void *, int, int);
     48  1.1  jmcneill 
     49  1.1  jmcneill #define PLGPIO_WRITE(sc, reg, val) \
     50  1.1  jmcneill 	bus_space_write_4((sc)->sc_bst, (sc)->sc_bsh, (reg), (val))
     51  1.1  jmcneill #define PLGPIO_READ(sc, reg) \
     52  1.1  jmcneill 	bus_space_read_4((sc)->sc_bst, (sc)->sc_bsh, (reg))
     53  1.1  jmcneill 
     54  1.1  jmcneill #endif /* !_PL061VAR_H */
     55