hc
2024-01-03 2f7c68cb55ecb7331f2381deb497c27155f32faf
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
/*
 * This file is subject to the terms and conditions of the GNU General Public
 * License.  See the file "COPYING" in the main directory of this archive
 * for more details.
 *
 * Copyright (C) 1992 - 1997, 1999 Silicon Graphics, Inc.
 * Copyright (C) 1999 by Ralf Baechle
 */
#ifndef _ASM_SN_SN0_HUB_H
#define _ASM_SN_SN0_HUB_H
 
/* The secret password; used to release protection */
#define HUB_PASSWORD        0x53474972756c6573ull
 
#define CHIPID_HUB        0
#define CHIPID_ROUTER        1
 
#define HUB_REV_1_0        1
#define HUB_REV_2_0        2
#define HUB_REV_2_1        3
#define HUB_REV_2_2        4
#define HUB_REV_2_3        5
#define HUB_REV_2_4        6
 
#define MAX_HUB_PATH        80
 
#include <asm/sn/sn0/addrs.h>
#include <asm/sn/sn0/hubpi.h>
#include <asm/sn/sn0/hubmd.h>
#include <asm/sn/sn0/hubio.h>
#include <asm/sn/sn0/hubni.h>
//#include <asm/sn/sn0/hubcore.h>
 
/* Translation of uncached attributes */
#define UATTR_HSPEC    0
#define UATTR_IO    1
#define UATTR_MSPEC    2
#define UATTR_UNCAC    3
 
#ifdef __ASSEMBLY__
/*
 * Returns the local nasid into res.
 */
   .macro GET_NASID_ASM res
   dli    \res, LOCAL_HUB_ADDR(NI_STATUS_REV_ID)
   ld    \res, (\res)
   and    \res, NSRI_NODEID_MASK
   dsrl    \res, NSRI_NODEID_SHFT
   .endm
#else
 
/*
 * get_nasid() returns the physical node id number of the caller.
 */
static inline nasid_t get_nasid(void)
{
   return (nasid_t)((LOCAL_HUB_L(NI_STATUS_REV_ID) & NSRI_NODEID_MASK)
            >> NSRI_NODEID_SHFT);
}
#endif
 
#endif /* _ASM_SN_SN0_HUB_H */