xref: /aosp_15_r20/external/coreboot/src/vendorcode/cavium/bdk/libbdk-arch/bdk-numa.c (revision b9411a12aaaa7e1e6a6fb7c5e057f44ee179a49c)
1 /***********************license start***********************************
2 * Copyright (c) 2003-2017  Cavium Inc. ([email protected]). All rights
3 * reserved.
4 *
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions are
8 * met:
9 *
10 *   * Redistributions of source code must retain the above copyright
11 *     notice, this list of conditions and the following disclaimer.
12 *
13 *   * Redistributions in binary form must reproduce the above
14 *     copyright notice, this list of conditions and the following
15 *     disclaimer in the documentation and/or other materials provided
16 *     with the distribution.
17 *
18 *   * Neither the name of Cavium Inc. nor the names of
19 *     its contributors may be used to endorse or promote products
20 *     derived from this software without specific prior written
21 *     permission.
22 *
23 * This Software, including technical data, may be subject to U.S. export
24 * control laws, including the U.S. Export Administration Act and its
25 * associated regulations, and may be subject to export or import
26 * regulations in other countries.
27 *
28 * TO THE MAXIMUM EXTENT PERMITTED BY LAW, THE SOFTWARE IS PROVIDED "AS IS"
29 * AND WITH ALL FAULTS AND CAVIUM INC. MAKES NO PROMISES, REPRESENTATIONS OR
30 * WARRANTIES, EITHER EXPRESS, IMPLIED, STATUTORY, OR OTHERWISE, WITH RESPECT
31 * TO THE SOFTWARE, INCLUDING ITS CONDITION, ITS CONFORMITY TO ANY
32 * REPRESENTATION OR DESCRIPTION, OR THE EXISTENCE OF ANY LATENT OR PATENT
33 * DEFECTS, AND CAVIUM SPECIFICALLY DISCLAIMS ALL IMPLIED (IF ANY) WARRANTIES
34 * OF TITLE, MERCHANTABILITY, NONINFRINGEMENT, FITNESS FOR A PARTICULAR
35 * PURPOSE, LACK OF VIRUSES, ACCURACY OR COMPLETENESS, QUIET ENJOYMENT,
36 * QUIET POSSESSION OR CORRESPONDENCE TO DESCRIPTION. THE ENTIRE  RISK
37 * ARISING OUT OF USE OR PERFORMANCE OF THE SOFTWARE LIES WITH YOU.
38 ***********************license end**************************************/
39 #include <bdk.h>
40 #include <libbdk-hal/bdk-atomic.h>
41 
42 /*
43  * FIXME(dhendrix): can't include bdk-spinlock.h, compile complains:
44  * {standard input}:40: Error: selected processor does not support `ldadda x3,x5,[x2]'
45  */
46 
47 //int __bdk_numa_master_node = -1;    /* Which node is the master */
48 int __bdk_numa_master_node = 0;			/* FIXME(dhendrix): assume 0 */
49 //static int __bdk_numa_exists_mask = 0;     /* Bitmask of nodes that exist */
50 static int __bdk_numa_exists_mask = 1;		/* FIXME(dhendrix): assume 0x01 */
51 //static bdk_spinlock_t __bdk_numa_lock;
52 
53 /**
54  * Get a bitmask of the nodes that exist
55  *
56  * @return bitmask
57  */
bdk_numa_get_exists_mask(void)58 uint64_t bdk_numa_get_exists_mask(void)
59 {
60     return __bdk_numa_exists_mask;
61 }
62 
63 /**
64  * Add a node to the exists mask
65  *
66  * @param node   Node to add
67  */
bdk_numa_set_exists(bdk_node_t node)68 void bdk_numa_set_exists(bdk_node_t node)
69 {
70 	/* FIXME(dhendrix): stub. */
71 	return;
72 }
73 
74 /**
75  * Return true if a node exists
76  *
77  * @param node   Node to check
78  *
79  * @return Non zero if the node exists
80  */
bdk_numa_exists(bdk_node_t node)81 int bdk_numa_exists(bdk_node_t node)
82 {
83 	/* FIXME(dhendrix): stub */
84 	return node == 0;
85 }
86 
87 /**
88  * Return true if there is only one node
89  *
90  * @return
91  */
bdk_numa_is_only_one(void)92 extern int bdk_numa_is_only_one(void)
93 {
94 	/* FIXME(dhendrix): stub */
95 	return 1;
96 }
97 
98