blob: 32c32f30b0998b1f22877ff23a8784c253313fe0 [file] [log] [blame]
Mark Maule48b1dcc2005-11-17 15:50:01 -06001/*
2 * This file is subject to the terms and conditions of the GNU General Public
3 * License. See the file "COPYING" in the main directory of this archive
4 * for more details.
5 *
6 * Copyright (c) 2003-2005 Silicon Graphics, Inc. All rights reserved.
7 */
Mark Maulec9221da2005-08-03 14:07:00 -07008
9#ifndef _ASM_IA64_SN_CE_PROVIDER_H
10#define _ASM_IA64_SN_CE_PROVIDER_H
11
12#include <asm/sn/pcibus_provider_defs.h>
13#include <asm/sn/tioce.h>
14
15/*
16 * Common TIOCE structure shared between the prom and kernel
17 *
18 * DO NOT CHANGE THIS STRUCT WITHOUT MAKING CORRESPONDING CHANGES TO THE
19 * PROM VERSION.
20 */
21struct tioce_common {
22 struct pcibus_bussoft ce_pcibus; /* common pciio header */
23
Prarit Bhargava53493dc2006-01-16 19:54:40 -080024 u32 ce_rev;
25 u64 ce_kernel_private;
26 u64 ce_prom_private;
Mark Maulec9221da2005-08-03 14:07:00 -070027};
28
29struct tioce_kernel {
30 struct tioce_common *ce_common;
31 spinlock_t ce_lock;
32 struct list_head ce_dmamap_list;
33
Prarit Bhargava53493dc2006-01-16 19:54:40 -080034 u64 ce_ate40_shadow[TIOCE_NUM_M40_ATES];
35 u64 ce_ate3240_shadow[TIOCE_NUM_M3240_ATES];
36 u32 ce_ate3240_pagesize;
Mark Maulec9221da2005-08-03 14:07:00 -070037
Prarit Bhargava53493dc2006-01-16 19:54:40 -080038 u8 ce_port1_secondary;
Mark Maulec9221da2005-08-03 14:07:00 -070039
40 /* per-port resources */
41 struct {
42 int dirmap_refcnt;
Prarit Bhargava53493dc2006-01-16 19:54:40 -080043 u64 dirmap_shadow;
Mark Maulec9221da2005-08-03 14:07:00 -070044 } ce_port[TIOCE_NUM_PORTS];
45};
46
47struct tioce_dmamap {
48 struct list_head ce_dmamap_list; /* headed by tioce_kernel */
Prarit Bhargava53493dc2006-01-16 19:54:40 -080049 u32 refcnt;
Mark Maulec9221da2005-08-03 14:07:00 -070050
Prarit Bhargava53493dc2006-01-16 19:54:40 -080051 u64 nbytes; /* # bytes mapped */
Mark Maulec9221da2005-08-03 14:07:00 -070052
Prarit Bhargava53493dc2006-01-16 19:54:40 -080053 u64 ct_start; /* coretalk start address */
54 u64 pci_start; /* bus start address */
Mark Maulec9221da2005-08-03 14:07:00 -070055
Al Viroa9f627c2006-10-10 22:46:27 +010056 u64 __iomem *ate_hw;/* hw ptr of first ate in map */
Prarit Bhargava53493dc2006-01-16 19:54:40 -080057 u64 *ate_shadow; /* shadow ptr of firat ate */
58 u16 ate_count; /* # ate's in the map */
Mark Maulec9221da2005-08-03 14:07:00 -070059};
60
61extern int tioce_init_provider(void);
62
63#endif /* __ASM_IA64_SN_CE_PROVIDER_H */