blob: 4cba1523ec50463116108f6eb8fbe101d5fb4362 [file] [log] [blame]
Ishizaki Kou551a3d82007-01-12 10:03:28 +09001/*
2 * pci prototypes for Celleb platform
3 *
4 * (C) Copyright 2006-2007 TOSHIBA CORPORATION
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License along
17 * with this program; if not, write to the Free Software Foundation, Inc.,
18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
19 */
20
21#ifndef _CELLEB_PCI_H
22#define _CELLEB_PCI_H
23
24#include <linux/pci.h>
25
26#include <asm/pci-bridge.h>
27#include <asm/prom.h>
Ishizaki Kouda0bd342007-10-02 18:26:53 +100028#include <asm/ppc-pci.h>
Ishizaki Kou551a3d82007-01-12 10:03:28 +090029
Ishizaki Kou116bdc42008-04-24 19:25:16 +100030#include "io-workarounds.h"
Ishizaki Kou6ec859e2008-04-24 19:24:13 +100031
32struct celleb_phb_spec {
33 int (*setup)(struct device_node *, struct pci_controller *);
34 struct ppc_pci_io *ops;
35 int (*iowa_init)(struct iowa_bus *, void *);
36 void *iowa_data;
37};
38
Ishizaki Kou551a3d82007-01-12 10:03:28 +090039extern int celleb_setup_phb(struct pci_controller *);
40extern int celleb_pci_probe_mode(struct pci_bus *);
41
Ishizaki Kou6ec859e2008-04-24 19:24:13 +100042extern struct celleb_phb_spec celleb_epci_spec;
Ishizaki Kou884d04c2008-04-24 20:27:39 +100043extern struct celleb_phb_spec celleb_pciex_spec;
Ishizaki Kouda0bd342007-10-02 18:26:53 +100044
Ishizaki Kou551a3d82007-01-12 10:03:28 +090045#endif /* _CELLEB_PCI_H */