/*      $NetBSD: autoconf.h,v 1.2 2017/06/16 18:17:41 jdolecek Exp $    */

/*      $OpenBSD: autoconf.h,v 1.10 2001/05/05 22:33:42 art Exp $       */

/*
* Copyright (c) 1998-2004 Michael Shalayeff
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
*    notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
*    notice, this list of conditions and the following disclaimer in the
*    documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 OR HIS RELATIVES 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 MIND, 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.
*/

#include <sys/device.h>

#include <sys/bus.h>
#include <machine/pdc.h>

/* 16 should be enough for anyone */
#define HPPA_MAXIOADDRS 16

struct confargs {
       struct iodc_data ca_type;       /* iodc-specific type descrition */
       struct device_path ca_dp;       /* device_path as found by pdc_scan */
       union {
               struct pdc_iodc_read uca_pir;
               struct pdc_chassis_lcd uca_pcl;
       } ca_u;
#define ca_pir ca_u.uca_pir
#define ca_pcl ca_u.uca_pcl

       struct {
               hppa_hpa_t addr;
               u_int   size;
       }               ca_addrs[HPPA_MAXIOADDRS];
       const char      *ca_name;       /* device name/description */
       bus_space_tag_t ca_iot;         /* io tag */
       int             ca_mod;         /* module number on the bus */
       hppa_hpa_t      ca_hpa;         /* module HPA */
       u_int           ca_hpasz;       /* module HPA size (if avail) */
       bus_dma_tag_t   ca_dmatag;      /* DMA tag */
       int             ca_irq;         /* module IRQ */
       int             ca_naddrs;      /* number of valid addr ents */
       hppa_hpa_t      ca_hpabase;     /* HPA base to use */
       int             ca_nmodules;    /* check for modules 0 to nmodules - 1 */
};

#define HPPACF_IRQ_UNDEF        (-1)
#define hppacf_irq      cf_loc[GEDOENSCF_IRQ]

/*
* This is used for hppa_knownmodules table describing known to this port
* modules, system boards, cpus, fpus and busses.
*/
struct hppa_mod_info {
       int     mi_type;
       int     mi_sv;
       const char *mi_name;
};

extern void (*cold_hook)(int);
#define HPPA_COLD_COLD  0
#define HPPA_COLD_HOT   1
#define HPPA_COLD_OFF   2

const char *hppa_mod_info(int, int);

void    hppa_modules_scan(void);
void    hppa_modules_done(void);

void pdc_scanbus(device_t, struct confargs *,
   device_t (*)(device_t, struct confargs *));

int     mbprint(void *, const char *);
int     mbsubmatch(device_t, struct cfdata *, const int *, void *);