cpufreq/amd-pstate: Fix per-policy boost flag incorrect when fail
[pf-kernel.git] / drivers / memory / tegra / tegra210-emc-table.c
blob34a8785d2861aa80216451f6bb64cbf543894888
1 // SPDX-License-Identifier: GPL-2.0
2 /*
3 * Copyright (c) 2020, NVIDIA CORPORATION. All rights reserved.
4 */
6 #include <linux/of_reserved_mem.h>
8 #include "tegra210-emc.h"
10 #define TEGRA_EMC_MAX_FREQS 16
12 static int tegra210_emc_table_device_init(struct reserved_mem *rmem,
13 struct device *dev)
15 struct tegra210_emc *emc = dev_get_drvdata(dev);
16 struct tegra210_emc_timing *timings;
17 unsigned int i, count = 0;
19 timings = memremap(rmem->base, rmem->size, MEMREMAP_WB);
20 if (!timings) {
21 dev_err(dev, "failed to map EMC table\n");
22 return -ENOMEM;
25 for (i = 0; i < TEGRA_EMC_MAX_FREQS; i++) {
26 if (timings[i].revision == 0)
27 break;
29 count++;
32 /* only the nominal and derated tables are expected */
33 if (emc->derated) {
34 dev_warn(dev, "excess EMC table '%s'\n", rmem->name);
35 goto out;
38 if (emc->nominal) {
39 if (count != emc->num_timings) {
40 dev_warn(dev, "%u derated vs. %u nominal entries\n",
41 count, emc->num_timings);
42 memunmap(timings);
43 return -EINVAL;
46 emc->derated = timings;
47 } else {
48 emc->num_timings = count;
49 emc->nominal = timings;
52 out:
53 /* keep track of which table this is */
54 rmem->priv = timings;
56 return 0;
59 static void tegra210_emc_table_device_release(struct reserved_mem *rmem,
60 struct device *dev)
62 struct tegra210_emc_timing *timings = rmem->priv;
63 struct tegra210_emc *emc = dev_get_drvdata(dev);
65 if ((emc->nominal && timings != emc->nominal) &&
66 (emc->derated && timings != emc->derated))
67 dev_warn(dev, "trying to release unassigned EMC table '%s'\n",
68 rmem->name);
70 memunmap(timings);
73 static const struct reserved_mem_ops tegra210_emc_table_ops = {
74 .device_init = tegra210_emc_table_device_init,
75 .device_release = tegra210_emc_table_device_release,
78 static int tegra210_emc_table_init(struct reserved_mem *rmem)
80 pr_debug("Tegra210 EMC table at %pa, size %lu bytes\n", &rmem->base,
81 (unsigned long)rmem->size);
83 rmem->ops = &tegra210_emc_table_ops;
85 return 0;
87 RESERVEDMEM_OF_DECLARE(tegra210_emc_table, "nvidia,tegra210-emc-table",
88 tegra210_emc_table_init);