xref: /aosp_15_r20/external/coreboot/src/vendorcode/cavium/bdk/libdram/dram-l2c.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 "dram-internal.h"
41 
42 /* FIXME(dhendrix): added */
43 #include <libbdk-hal/bdk-l2c.h>
44 #include <libbdk-hal/bdk-utils.h>
45 
limit_l2_ways(bdk_node_t node,int ways,int verbose)46 int limit_l2_ways(bdk_node_t node, int ways, int verbose)
47 {
48     int ways_max = bdk_l2c_get_num_assoc(node);
49     int ways_min = 0;
50     int errors = 0;
51 
52     if (ways >= ways_min && ways <= ways_max)
53     {
54         uint32_t valid_mask = (0x1 << ways_max) - 1;
55         uint32_t mask = (valid_mask << ways) & valid_mask;
56         if (verbose)
57             printf("Limiting L2 to %d ways\n", ways);
58         for (int i = 0; i < (int)bdk_get_num_cores(node); i++)
59             errors += bdk_l2c_set_core_way_partition(node, i, mask);
60         errors += bdk_l2c_set_hw_way_partition(node, mask);
61     }
62     else
63     {
64         errors++;
65         printf("ERROR: invalid limit_l2_ways %d, must be between %d and %d\n",
66                ways, ways_min, ways_max);
67     }
68     if (errors)
69         puts("ERROR limiting L2 cache ways\n");
70 
71     return errors;
72 }
73 
74