aboutsummaryrefslogtreecommitdiffstats
path: root/include/asm-mips/sn/sn0/addrs.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/asm-mips/sn/sn0/addrs.h')
-rw-r--r--include/asm-mips/sn/sn0/addrs.h76
1 files changed, 3 insertions, 73 deletions
diff --git a/include/asm-mips/sn/sn0/addrs.h b/include/asm-mips/sn/sn0/addrs.h
index 7cb9c31f6878..0ee8cbcb5b03 100644
--- a/include/asm-mips/sn/sn0/addrs.h
+++ b/include/asm-mips/sn/sn0/addrs.h
@@ -85,15 +85,15 @@
85#define NASID_GET(_pa) (int) ((UINT64_CAST (_pa) >> \ 85#define NASID_GET(_pa) (int) ((UINT64_CAST (_pa) >> \
86 NASID_SHFT) & NASID_BITMASK) 86 NASID_SHFT) & NASID_BITMASK)
87 87
88#if !defined(__ASSEMBLY__) && !defined(_STANDALONE) 88#if !defined(__ASSEMBLY__)
89 89
90#define NODE_SWIN_BASE(nasid, widget) \ 90#define NODE_SWIN_BASE(nasid, widget) \
91 ((widget == 0) ? NODE_BWIN_BASE((nasid), SWIN0_BIGWIN) \ 91 ((widget == 0) ? NODE_BWIN_BASE((nasid), SWIN0_BIGWIN) \
92 : RAW_NODE_SWIN_BASE(nasid, widget)) 92 : RAW_NODE_SWIN_BASE(nasid, widget))
93#else /* __ASSEMBLY__ || _STANDALONE */ 93#else /* __ASSEMBLY__ */
94#define NODE_SWIN_BASE(nasid, widget) \ 94#define NODE_SWIN_BASE(nasid, widget) \
95 (NODE_IO_BASE(nasid) + (UINT64_CAST (widget) << SWIN_SIZE_BITS)) 95 (NODE_IO_BASE(nasid) + (UINT64_CAST (widget) << SWIN_SIZE_BITS))
96#endif /* __ASSEMBLY__ || _STANDALONE */ 96#endif /* __ASSEMBLY__ */
97 97
98/* 98/*
99 * The following definitions pertain to the IO special address 99 * The following definitions pertain to the IO special address
@@ -276,76 +276,6 @@
276 276
277#define _ARCSPROM 277#define _ARCSPROM
278 278
279#ifdef _STANDALONE
280
281/*
282 * The PROM needs to pass the device base address and the
283 * device pci cfg space address to the device drivers during
284 * install. The COMPONENT->Key field is used for this purpose.
285 * Macros needed by SN0 device drivers to convert the
286 * COMPONENT->Key field to the respective base address.
287 * Key field looks as follows:
288 *
289 * +----------------------------------------------------+
290 * |devnasid | widget |pciid |hubwidid|hstnasid | adap |
291 * | 2 | 1 | 1 | 1 | 2 | 1 |
292 * +----------------------------------------------------+
293 * | | | | | | |
294 * 64 48 40 32 24 8 0
295 *
296 * These are used by standalone drivers till the io infrastructure
297 * is in place.
298 */
299
300#ifndef __ASSEMBLY__
301
302#define uchar unsigned char
303
304#define KEY_DEVNASID_SHFT 48
305#define KEY_WIDID_SHFT 40
306#define KEY_PCIID_SHFT 32
307#define KEY_HUBWID_SHFT 24
308#define KEY_HSTNASID_SHFT 8
309
310#define MK_SN0_KEY(nasid, widid, pciid) \
311 ((((__psunsigned_t)nasid)<< KEY_DEVNASID_SHFT |\
312 ((__psunsigned_t)widid) << KEY_WIDID_SHFT) |\
313 ((__psunsigned_t)pciid) << KEY_PCIID_SHFT)
314
315#define ADD_HUBWID_KEY(key,hubwid)\
316 (key|=((__psunsigned_t)hubwid << KEY_HUBWID_SHFT))
317
318#define ADD_HSTNASID_KEY(key,hstnasid)\
319 (key|=((__psunsigned_t)hstnasid << KEY_HSTNASID_SHFT))
320
321#define GET_DEVNASID_FROM_KEY(key) ((short)(key >> KEY_DEVNASID_SHFT))
322#define GET_WIDID_FROM_KEY(key) ((uchar)(key >> KEY_WIDID_SHFT))
323#define GET_PCIID_FROM_KEY(key) ((uchar)(key >> KEY_PCIID_SHFT))
324#define GET_HUBWID_FROM_KEY(key) ((uchar)(key >> KEY_HUBWID_SHFT))
325#define GET_HSTNASID_FROM_KEY(key) ((short)(key >> KEY_HSTNASID_SHFT))
326
327#define PCI_64_TARGID_SHFT 60
328
329#define GET_PCIBASE_FROM_KEY(key) (NODE_SWIN_BASE(GET_DEVNASID_FROM_KEY(key),\
330 GET_WIDID_FROM_KEY(key))\
331 | BRIDGE_DEVIO(GET_PCIID_FROM_KEY(key)))
332
333#define GET_PCICFGBASE_FROM_KEY(key) \
334 (NODE_SWIN_BASE(GET_DEVNASID_FROM_KEY(key),\
335 GET_WIDID_FROM_KEY(key))\
336 | BRIDGE_TYPE0_CFG_DEV(GET_PCIID_FROM_KEY(key)))
337
338#define GET_WIDBASE_FROM_KEY(key) \
339 (NODE_SWIN_BASE(GET_DEVNASID_FROM_KEY(key),\
340 GET_WIDID_FROM_KEY(key)))
341
342#define PUT_INSTALL_STATUS(c,s) c->Revision = s
343#define GET_INSTALL_STATUS(c) c->Revision
344
345#endif /* !__ASSEMBLY__ */
346
347#endif /* _STANDALONE */
348
349#if defined (HUB_ERR_STS_WAR) 279#if defined (HUB_ERR_STS_WAR)
350 280
351#define ERR_STS_WAR_REGISTER IIO_IIBUSERR 281#define ERR_STS_WAR_REGISTER IIO_IIBUSERR