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
6 * Copyright (c) 2003-2005 Silicon Graphics, Inc. All rights reserved.
9 #ifndef _ASM_IA64_SN_TIO_CA_AGP_PROVIDER_H
10 #define _ASM_IA64_SN_TIO_CA_AGP_PROVIDER_H
12 #include <asm/sn/tioca.h>
16 * Defines for individual WARs. Each is a bitmask of applicable
17 * part revision numbers. (1 << 1) == rev A, (1 << 2) == rev B,
18 * (3 << 1) == (rev A or rev B), etc
21 #define TIOCA_WAR_ENABLED(pv, tioca_common) \
22 ((1 << tioca_common->ca_rev) & pv)
24 /* TIO:ICE:FRZ:Freezer loses a PIO data ucred on PIO RD RSP with CW error */
25 #define PV907908 (1 << 1)
26 /* ATI config space problems after BIOS execution starts */
27 #define PV908234 (1 << 1)
28 /* CA:AGPDMA write request data mismatch with ABC1CL merge */
29 #define PV895469 (1 << 1)
30 /* TIO:CA TLB invalidate of written GART entries possibly not occuring in CA*/
31 #define PV910244 (1 << 1)
34 struct list_head cad_list
; /* headed by ca_list */
36 dma_addr_t cad_dma_addr
; /* Linux dma handle */
37 uint cad_gart_entry
; /* start entry in ca_gart_pagemap */
38 uint cad_gart_size
; /* #entries for this map */
42 * Kernel only fields. Prom may look at this stuff for debugging only.
43 * Access this structure through the ca_kernel_private ptr.
49 struct tioca_common
*ca_common
; /* tioca this belongs to */
50 struct list_head ca_list
; /* list of all ca's */
51 struct list_head ca_dmamaps
;
52 spinlock_t ca_lock
; /* Kernel lock */
53 cnodeid_t ca_closest_node
;
54 struct list_head
*ca_devices
; /* bus->devices */
59 uint64_t ca_ap_size
; /* size of aperature in bytes */
60 uint32_t ca_gart_entries
; /* # uint64_t entries in gart */
61 uint32_t ca_ap_pagesize
; /* aperature page size in bytes */
62 uint64_t ca_ap_bus_base
; /* bus address of CA aperature */
63 uint64_t ca_gart_size
; /* gart size in bytes */
64 uint64_t *ca_gart
; /* gart table vaddr */
65 uint64_t ca_gart_coretalk_addr
; /* gart coretalk addr */
66 uint8_t ca_gart_iscoherent
; /* used in tioca_tlbflush */
68 /* PCI GART convenience values */
69 uint64_t ca_pciap_base
; /* pci aperature bus base address */
70 uint64_t ca_pciap_size
; /* pci aperature size (bytes) */
71 uint64_t ca_pcigart_base
; /* gfx GART bus base address */
72 uint64_t *ca_pcigart
; /* gfx GART vm address */
73 uint32_t ca_pcigart_entries
;
74 uint32_t ca_pcigart_start
; /* PCI start index in ca_gart */
75 void *ca_pcigart_pagemap
;
77 /* AGP GART convenience values */
78 uint64_t ca_gfxap_base
; /* gfx aperature bus base address */
79 uint64_t ca_gfxap_size
; /* gfx aperature size (bytes) */
80 uint64_t ca_gfxgart_base
; /* gfx GART bus base address */
81 uint64_t *ca_gfxgart
; /* gfx GART vm address */
82 uint32_t ca_gfxgart_entries
;
83 uint32_t ca_gfxgart_start
; /* agpgart start index in ca_gart */
87 * Common tioca info shared between kernel and prom
89 * DO NOT CHANGE THIS STRUCT WITHOUT MAKING CORRESPONDING CHANGES
90 * TO THE PROM VERSION.
94 struct pcibus_bussoft ca_common
; /* common pciio header */
97 uint32_t ca_closest_nasid
;
99 uint64_t ca_prom_private
;
100 uint64_t ca_kernel_private
;
104 * tioca_paddr_to_gart - Convert an SGI coretalk address to a CA GART entry
105 * @paddr: page address to convert
107 * Convert a system [coretalk] address to a GART entry. GART entries are
108 * formed using the following:
110 * data = ( (1<<63) | ( (REMAP_NODE_ID << 40) | (MD_CHIPLET_ID << 38) |
111 * (REMAP_SYS_ADDR) ) >> 12 )
113 * DATA written to 1 GART TABLE Entry in system memory is remapped system
116 * The data is for coretalk address format right shifted 12 bits with a
119 * GART_TABLE_ENTRY [ 25:0 ] -- REMAP_SYS_ADDRESS[37:12].
120 * GART_TABLE_ENTRY [ 27:26 ] -- SHUB MD chiplet id.
121 * GART_TABLE_ENTRY [ 41:28 ] -- REMAP_NODE_ID.
122 * GART_TABLE_ENTRY [ 63 ] -- Valid Bit
125 tioca_paddr_to_gart(unsigned long paddr
)
128 * We are assuming right now that paddr already has the correct
129 * format since the address from xtalk_dmaXXX should already have
130 * NODE_ID, CHIPLET_ID, and SYS_ADDR in the correct locations.
133 return ((paddr
) >> 12) | (1UL << 63);
137 * tioca_physpage_to_gart - Map a host physical page for SGI CA based DMA
138 * @page_addr: system page address to map
141 static inline unsigned long
142 tioca_physpage_to_gart(uint64_t page_addr
)
144 uint64_t coretalk_addr
;
146 coretalk_addr
= PHYS_TO_TIODMA(page_addr
);
147 if (!coretalk_addr
) {
151 return tioca_paddr_to_gart(coretalk_addr
);
155 * tioca_tlbflush - invalidate cached SGI CA GART TLB entries
156 * @tioca_kernel: CA context
158 * Invalidate tlb entries for a given CA GART. Main complexity is to account
162 tioca_tlbflush(struct tioca_kernel
*tioca_kernel
)
164 volatile uint64_t tmp
;
165 volatile struct tioca
*ca_base
;
166 struct tioca_common
*tioca_common
;
168 tioca_common
= tioca_kernel
->ca_common
;
169 ca_base
= (struct tioca
*)tioca_common
->ca_common
.bs_base
;
172 * Explicit flushes not needed if GART is in cached mode
174 if (tioca_kernel
->ca_gart_iscoherent
) {
175 if (TIOCA_WAR_ENABLED(PV910244
, tioca_common
)) {
177 * PV910244: RevA CA needs explicit flushes.
178 * Need to put GART into uncached mode before
179 * flushing otherwise the explicit flush is ignored.
181 * Alternate WAR would be to leave GART cached and
182 * touch every CL aligned GART entry.
185 ca_base
->ca_control2
&= ~(CA_GART_MEM_PARAM
);
186 ca_base
->ca_control2
|= CA_GART_FLUSH_TLB
;
187 ca_base
->ca_control2
|=
188 (0x2ull
<< CA_GART_MEM_PARAM_SHFT
);
189 tmp
= ca_base
->ca_control2
;
196 * Gart in uncached mode ... need an explicit flush.
199 ca_base
->ca_control2
|= CA_GART_FLUSH_TLB
;
200 tmp
= ca_base
->ca_control2
;
203 extern uint32_t tioca_gart_found
;
204 extern int tioca_init_provider(void);
205 extern void tioca_fastwrite_enable(struct tioca_kernel
*tioca_kern
);
206 #endif /* _ASM_IA64_SN_TIO_CA_AGP_PROVIDER_H */