blob: 7a221666c58ed4e0febd78e2ab32a07920e3eda1 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
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 * SGI IP27 specific setup.
7 *
8 * Copyright (C) 1995 - 1997, 1999 Silcon Graphics, Inc.
9 * Copyright (C) 1999 Ralf Baechle (ralf@gnu.org)
10 */
11#ifndef _ASM_SN_SN0_ARCH_H
12#define _ASM_SN_SN0_ARCH_H
13
Linus Torvalds1da177e2005-04-16 15:20:36 -070014
15#ifndef SABLE
16
17#ifndef SN0XXL /* 128 cpu SMP max */
18/*
19 * This is the maximum number of nodes that can be part of a kernel.
20 * Effectively, it's the maximum number of compact node ids (cnodeid_t).
21 */
22#define MAX_COMPACT_NODES 64
23
24/*
25 * MAXCPUS refers to the maximum number of CPUs in a single kernel.
26 * This is not necessarily the same as MAXNODES * CPUS_PER_NODE
27 */
28#define MAXCPUS 128
29
30#else /* SN0XXL system */
31
32#define MAX_COMPACT_NODES 128
33#define MAXCPUS 256
34
35#endif /* SN0XXL */
36
37/*
38 * This is the maximum number of NASIDS that can be present in a system.
39 * (Highest NASID plus one.)
40 */
41#define MAX_NASIDS 256
42
43/*
44 * MAX_REGIONS refers to the maximum number of hardware partitioned regions.
45 */
46#define MAX_REGIONS 64
47#define MAX_NONPREMIUM_REGIONS 16
48#define MAX_PREMIUM_REGIONS MAX_REGIONS
49
50/*
51 * MAX_PARITIONS refers to the maximum number of logically defined
52 * partitions the system can support.
53 */
54#define MAX_PARTITIONS MAX_REGIONS
55
56
57#else
58
59#define MAX_COMPACT_NODES 4
60#define MAX_NASIDS 4
61#define MAXCPUS 8
62
63#endif
64
65#define NASID_MASK_BYTES ((MAX_NASIDS + 7) / 8)
66
67/*
68 * Slot constants for SN0
69 */
70#ifdef CONFIG_SGI_SN0_N_MODE
71#define MAX_MEM_SLOTS 16 /* max slots per node */
72#else /* !CONFIG_SGI_SN0_N_MODE, assume M_MODE */
73#define MAX_MEM_SLOTS 32 /* max slots per node */
74#endif /* defined(N_MODE) */
75
Linus Torvalds1da177e2005-04-16 15:20:36 -070076#define SLOT_SHIFT (27)
77#define SLOT_MIN_MEM_SIZE (32*1024*1024)
Linus Torvalds1da177e2005-04-16 15:20:36 -070078
79#define CPUS_PER_NODE 2 /* CPUs on a single hub */
80#define CPUS_PER_NODE_SHFT 1 /* Bits to shift in the node number */
81#define CPUS_PER_SUBNODE 2 /* CPUs on a single hub PI */
82
83#endif /* _ASM_SN_SN0_ARCH_H */