Skip to content

Commit b894685

Browse files
spandruvadarafaeljw
authored andcommitted
thermal: int340x: processor_thermal: Move mailbox code to common module
The processor thermal mailbox is used for workload type request and also in the processor thermal RFIM module. So, move the workload type request code to its own module from the current processor thermal mailbox module. processor_thermal_mailbox.c contains only mailbox read/write related source code. The source related to workload_types requests is moved to a module processor_thermal_wt_req.c. In addition - Rename PROC_THERMAL_FEATURE_MBOX to PROC_THERMAL_FEATURE_WT_REQ. - proc_thermal_mbox_add(), which adds workload type sysfs attribute group is renamed to proc_thermal_wt_req_add(). - proc_thermal_mbox_remove() is renamed to proc_thermal_wt_req_remove(). While here, resolve check patch warnings for 100 columns for only modified lines. No functional changes are expected. Signed-off-by: Srinivas Pandruvada <[email protected]> Reviewed-by: Zhang Rui <[email protected]> Signed-off-by: Rafael J. Wysocki <[email protected]>
1 parent fb2c102 commit b894685

File tree

7 files changed

+159
-141
lines changed

7 files changed

+159
-141
lines changed

drivers/thermal/intel/int340x_thermal/Makefile

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -10,5 +10,6 @@ obj-$(CONFIG_INT340X_THERMAL) += processor_thermal_device_pci.o
1010
obj-$(CONFIG_PROC_THERMAL_MMIO_RAPL) += processor_thermal_rapl.o
1111
obj-$(CONFIG_INT340X_THERMAL) += processor_thermal_rfim.o
1212
obj-$(CONFIG_INT340X_THERMAL) += processor_thermal_mbox.o
13+
obj-$(CONFIG_INT340X_THERMAL) += processor_thermal_wt_req.o
1314
obj-$(CONFIG_INT3406_THERMAL) += int3406_thermal.o
1415
obj-$(CONFIG_ACPI_THERMAL_REL) += acpi_thermal_rel.o

drivers/thermal/intel/int340x_thermal/processor_thermal_device.c

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -346,8 +346,8 @@ int proc_thermal_mmio_add(struct pci_dev *pdev,
346346
}
347347
}
348348

349-
if (feature_mask & PROC_THERMAL_FEATURE_MBOX) {
350-
ret = proc_thermal_mbox_add(pdev, proc_priv);
349+
if (feature_mask & PROC_THERMAL_FEATURE_WT_REQ) {
350+
ret = proc_thermal_wt_req_add(pdev, proc_priv);
351351
if (ret) {
352352
dev_err(&pdev->dev, "failed to add MBOX interface\n");
353353
goto err_rem_rfim;
@@ -374,8 +374,8 @@ void proc_thermal_mmio_remove(struct pci_dev *pdev, struct proc_thermal_device *
374374
proc_priv->mmio_feature_mask & PROC_THERMAL_FEATURE_DVFS)
375375
proc_thermal_rfim_remove(pdev);
376376

377-
if (proc_priv->mmio_feature_mask & PROC_THERMAL_FEATURE_MBOX)
378-
proc_thermal_mbox_remove(pdev);
377+
if (proc_priv->mmio_feature_mask & PROC_THERMAL_FEATURE_WT_REQ)
378+
proc_thermal_wt_req_remove(pdev);
379379
}
380380
EXPORT_SYMBOL_GPL(proc_thermal_mmio_remove);
381381

drivers/thermal/intel/int340x_thermal/processor_thermal_device.h

Lines changed: 9 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -59,7 +59,7 @@ struct rapl_mmio_regs {
5959
#define PROC_THERMAL_FEATURE_RAPL 0x01
6060
#define PROC_THERMAL_FEATURE_FIVR 0x02
6161
#define PROC_THERMAL_FEATURE_DVFS 0x04
62-
#define PROC_THERMAL_FEATURE_MBOX 0x08
62+
#define PROC_THERMAL_FEATURE_WT_REQ 0x08
6363
#define PROC_THERMAL_FEATURE_DLVR 0x10
6464

6565
#if IS_ENABLED(CONFIG_PROC_THERMAL_MMIO_RAPL)
@@ -80,8 +80,14 @@ static void __maybe_unused proc_thermal_rapl_remove(void)
8080
int proc_thermal_rfim_add(struct pci_dev *pdev, struct proc_thermal_device *proc_priv);
8181
void proc_thermal_rfim_remove(struct pci_dev *pdev);
8282

83-
int proc_thermal_mbox_add(struct pci_dev *pdev, struct proc_thermal_device *proc_priv);
84-
void proc_thermal_mbox_remove(struct pci_dev *pdev);
83+
int proc_thermal_wt_req_add(struct pci_dev *pdev, struct proc_thermal_device *proc_priv);
84+
void proc_thermal_wt_req_remove(struct pci_dev *pdev);
85+
86+
#define MBOX_CMD_WORKLOAD_TYPE_READ 0x0E
87+
#define MBOX_CMD_WORKLOAD_TYPE_WRITE 0x0F
88+
89+
#define MBOX_DATA_BIT_AC_DC 30
90+
#define MBOX_DATA_BIT_VALID 31
8591

8692
int processor_thermal_send_mbox_read_cmd(struct pci_dev *pdev, u16 id, u64 *resp);
8793
int processor_thermal_send_mbox_write_cmd(struct pci_dev *pdev, u16 id, u32 data);

drivers/thermal/intel/int340x_thermal/processor_thermal_device_pci.c

Lines changed: 7 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -350,9 +350,13 @@ static SIMPLE_DEV_PM_OPS(proc_thermal_pci_pm, proc_thermal_pci_suspend,
350350
proc_thermal_pci_resume);
351351

352352
static const struct pci_device_id proc_thermal_pci_ids[] = {
353-
{ PCI_DEVICE_DATA(INTEL, ADL_THERMAL, PROC_THERMAL_FEATURE_RAPL | PROC_THERMAL_FEATURE_FIVR | PROC_THERMAL_FEATURE_DVFS | PROC_THERMAL_FEATURE_MBOX) },
354-
{ PCI_DEVICE_DATA(INTEL, MTLP_THERMAL, PROC_THERMAL_FEATURE_RAPL | PROC_THERMAL_FEATURE_FIVR | PROC_THERMAL_FEATURE_DVFS | PROC_THERMAL_FEATURE_MBOX | PROC_THERMAL_FEATURE_DLVR) },
355-
{ PCI_DEVICE_DATA(INTEL, RPL_THERMAL, PROC_THERMAL_FEATURE_RAPL | PROC_THERMAL_FEATURE_FIVR | PROC_THERMAL_FEATURE_DVFS | PROC_THERMAL_FEATURE_MBOX) },
353+
{ PCI_DEVICE_DATA(INTEL, ADL_THERMAL, PROC_THERMAL_FEATURE_RAPL |
354+
PROC_THERMAL_FEATURE_FIVR | PROC_THERMAL_FEATURE_DVFS | PROC_THERMAL_FEATURE_WT_REQ) },
355+
{ PCI_DEVICE_DATA(INTEL, MTLP_THERMAL, PROC_THERMAL_FEATURE_RAPL |
356+
PROC_THERMAL_FEATURE_FIVR | PROC_THERMAL_FEATURE_DVFS | PROC_THERMAL_FEATURE_WT_REQ |
357+
PROC_THERMAL_FEATURE_DLVR) },
358+
{ PCI_DEVICE_DATA(INTEL, RPL_THERMAL, PROC_THERMAL_FEATURE_RAPL |
359+
PROC_THERMAL_FEATURE_FIVR | PROC_THERMAL_FEATURE_DVFS | PROC_THERMAL_FEATURE_WT_REQ) },
356360
{ },
357361
};
358362

drivers/thermal/intel/int340x_thermal/processor_thermal_device_pci_legacy.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -137,7 +137,8 @@ static const struct pci_device_id proc_thermal_pci_ids[] = {
137137
{ PCI_DEVICE_DATA(INTEL, ICL_THERMAL, PROC_THERMAL_FEATURE_RAPL) },
138138
{ PCI_DEVICE_DATA(INTEL, JSL_THERMAL, 0) },
139139
{ PCI_DEVICE_DATA(INTEL, SKL_THERMAL, PROC_THERMAL_FEATURE_RAPL) },
140-
{ PCI_DEVICE_DATA(INTEL, TGL_THERMAL, PROC_THERMAL_FEATURE_RAPL | PROC_THERMAL_FEATURE_FIVR | PROC_THERMAL_FEATURE_MBOX) },
140+
{ PCI_DEVICE_DATA(INTEL, TGL_THERMAL, PROC_THERMAL_FEATURE_RAPL |
141+
PROC_THERMAL_FEATURE_FIVR | PROC_THERMAL_FEATURE_WT_REQ) },
141142
{ },
142143
};
143144

drivers/thermal/intel/int340x_thermal/processor_thermal_mbox.c

Lines changed: 0 additions & 130 deletions
Original file line numberDiff line numberDiff line change
@@ -10,18 +10,12 @@
1010
#include <linux/io-64-nonatomic-lo-hi.h>
1111
#include "processor_thermal_device.h"
1212

13-
#define MBOX_CMD_WORKLOAD_TYPE_READ 0x0E
14-
#define MBOX_CMD_WORKLOAD_TYPE_WRITE 0x0F
15-
1613
#define MBOX_OFFSET_DATA 0x5810
1714
#define MBOX_OFFSET_INTERFACE 0x5818
1815

1916
#define MBOX_BUSY_BIT 31
2017
#define MBOX_RETRY_COUNT 100
2118

22-
#define MBOX_DATA_BIT_VALID 31
23-
#define MBOX_DATA_BIT_AC_DC 30
24-
2519
static DEFINE_MUTEX(mbox_lock);
2620

2721
static int wait_for_mbox_ready(struct proc_thermal_device *proc_priv)
@@ -114,128 +108,4 @@ int processor_thermal_send_mbox_write_cmd(struct pci_dev *pdev, u16 id, u32 data
114108
}
115109
EXPORT_SYMBOL_NS_GPL(processor_thermal_send_mbox_write_cmd, INT340X_THERMAL);
116110

117-
/* List of workload types */
118-
static const char * const workload_types[] = {
119-
"none",
120-
"idle",
121-
"semi_active",
122-
"bursty",
123-
"sustained",
124-
"battery_life",
125-
NULL
126-
};
127-
128-
static ssize_t workload_available_types_show(struct device *dev,
129-
struct device_attribute *attr,
130-
char *buf)
131-
{
132-
int i = 0;
133-
int ret = 0;
134-
135-
while (workload_types[i] != NULL)
136-
ret += sprintf(&buf[ret], "%s ", workload_types[i++]);
137-
138-
ret += sprintf(&buf[ret], "\n");
139-
140-
return ret;
141-
}
142-
143-
static DEVICE_ATTR_RO(workload_available_types);
144-
145-
static ssize_t workload_type_store(struct device *dev,
146-
struct device_attribute *attr,
147-
const char *buf, size_t count)
148-
{
149-
struct pci_dev *pdev = to_pci_dev(dev);
150-
char str_preference[15];
151-
u32 data = 0;
152-
ssize_t ret;
153-
154-
ret = sscanf(buf, "%14s", str_preference);
155-
if (ret != 1)
156-
return -EINVAL;
157-
158-
ret = match_string(workload_types, -1, str_preference);
159-
if (ret < 0)
160-
return ret;
161-
162-
ret &= 0xff;
163-
164-
if (ret)
165-
data = BIT(MBOX_DATA_BIT_VALID) | BIT(MBOX_DATA_BIT_AC_DC);
166-
167-
data |= ret;
168-
169-
ret = send_mbox_write_cmd(pdev, MBOX_CMD_WORKLOAD_TYPE_WRITE, data);
170-
if (ret)
171-
return false;
172-
173-
return count;
174-
}
175-
176-
static ssize_t workload_type_show(struct device *dev,
177-
struct device_attribute *attr,
178-
char *buf)
179-
{
180-
struct pci_dev *pdev = to_pci_dev(dev);
181-
u64 cmd_resp;
182-
int ret;
183-
184-
ret = send_mbox_read_cmd(pdev, MBOX_CMD_WORKLOAD_TYPE_READ, &cmd_resp);
185-
if (ret)
186-
return false;
187-
188-
cmd_resp &= 0xff;
189-
190-
if (cmd_resp > ARRAY_SIZE(workload_types) - 1)
191-
return -EINVAL;
192-
193-
return sprintf(buf, "%s\n", workload_types[cmd_resp]);
194-
}
195-
196-
static DEVICE_ATTR_RW(workload_type);
197-
198-
static struct attribute *workload_req_attrs[] = {
199-
&dev_attr_workload_available_types.attr,
200-
&dev_attr_workload_type.attr,
201-
NULL
202-
};
203-
204-
static const struct attribute_group workload_req_attribute_group = {
205-
.attrs = workload_req_attrs,
206-
.name = "workload_request"
207-
};
208-
209-
static bool workload_req_created;
210-
211-
int proc_thermal_mbox_add(struct pci_dev *pdev, struct proc_thermal_device *proc_priv)
212-
{
213-
u64 cmd_resp;
214-
int ret;
215-
216-
/* Check if there is a mailbox support, if fails return success */
217-
ret = send_mbox_read_cmd(pdev, MBOX_CMD_WORKLOAD_TYPE_READ, &cmd_resp);
218-
if (ret)
219-
return 0;
220-
221-
ret = sysfs_create_group(&pdev->dev.kobj, &workload_req_attribute_group);
222-
if (ret)
223-
return ret;
224-
225-
workload_req_created = true;
226-
227-
return 0;
228-
}
229-
EXPORT_SYMBOL_GPL(proc_thermal_mbox_add);
230-
231-
void proc_thermal_mbox_remove(struct pci_dev *pdev)
232-
{
233-
if (workload_req_created)
234-
sysfs_remove_group(&pdev->dev.kobj, &workload_req_attribute_group);
235-
236-
workload_req_created = false;
237-
238-
}
239-
EXPORT_SYMBOL_GPL(proc_thermal_mbox_remove);
240-
241111
MODULE_LICENSE("GPL v2");
Lines changed: 136 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,136 @@
1+
// SPDX-License-Identifier: GPL-2.0-only
2+
/*
3+
* processor thermal device for Workload type hints
4+
* update from user space
5+
*
6+
* Copyright (c) 2020-2023, Intel Corporation.
7+
*/
8+
9+
#include <linux/pci.h>
10+
#include "processor_thermal_device.h"
11+
12+
/* List of workload types */
13+
static const char * const workload_types[] = {
14+
"none",
15+
"idle",
16+
"semi_active",
17+
"bursty",
18+
"sustained",
19+
"battery_life",
20+
NULL
21+
};
22+
23+
static ssize_t workload_available_types_show(struct device *dev,
24+
struct device_attribute *attr,
25+
char *buf)
26+
{
27+
int i = 0;
28+
int ret = 0;
29+
30+
while (workload_types[i] != NULL)
31+
ret += sprintf(&buf[ret], "%s ", workload_types[i++]);
32+
33+
ret += sprintf(&buf[ret], "\n");
34+
35+
return ret;
36+
}
37+
38+
static DEVICE_ATTR_RO(workload_available_types);
39+
40+
static ssize_t workload_type_store(struct device *dev,
41+
struct device_attribute *attr,
42+
const char *buf, size_t count)
43+
{
44+
struct pci_dev *pdev = to_pci_dev(dev);
45+
char str_preference[15];
46+
u32 data = 0;
47+
ssize_t ret;
48+
49+
ret = sscanf(buf, "%14s", str_preference);
50+
if (ret != 1)
51+
return -EINVAL;
52+
53+
ret = match_string(workload_types, -1, str_preference);
54+
if (ret < 0)
55+
return ret;
56+
57+
ret &= 0xff;
58+
59+
if (ret)
60+
data = BIT(MBOX_DATA_BIT_VALID) | BIT(MBOX_DATA_BIT_AC_DC);
61+
62+
data |= ret;
63+
64+
ret = processor_thermal_send_mbox_write_cmd(pdev, MBOX_CMD_WORKLOAD_TYPE_WRITE, data);
65+
if (ret)
66+
return false;
67+
68+
return count;
69+
}
70+
71+
static ssize_t workload_type_show(struct device *dev,
72+
struct device_attribute *attr,
73+
char *buf)
74+
{
75+
struct pci_dev *pdev = to_pci_dev(dev);
76+
u64 cmd_resp;
77+
int ret;
78+
79+
ret = processor_thermal_send_mbox_read_cmd(pdev, MBOX_CMD_WORKLOAD_TYPE_READ, &cmd_resp);
80+
if (ret)
81+
return false;
82+
83+
cmd_resp &= 0xff;
84+
85+
if (cmd_resp > ARRAY_SIZE(workload_types) - 1)
86+
return -EINVAL;
87+
88+
return sprintf(buf, "%s\n", workload_types[cmd_resp]);
89+
}
90+
91+
static DEVICE_ATTR_RW(workload_type);
92+
93+
static struct attribute *workload_req_attrs[] = {
94+
&dev_attr_workload_available_types.attr,
95+
&dev_attr_workload_type.attr,
96+
NULL
97+
};
98+
99+
static const struct attribute_group workload_req_attribute_group = {
100+
.attrs = workload_req_attrs,
101+
.name = "workload_request"
102+
};
103+
104+
static bool workload_req_created;
105+
106+
int proc_thermal_wt_req_add(struct pci_dev *pdev, struct proc_thermal_device *proc_priv)
107+
{
108+
u64 cmd_resp;
109+
int ret;
110+
111+
/* Check if there is a mailbox support, if fails return success */
112+
ret = processor_thermal_send_mbox_read_cmd(pdev, MBOX_CMD_WORKLOAD_TYPE_READ, &cmd_resp);
113+
if (ret)
114+
return 0;
115+
116+
ret = sysfs_create_group(&pdev->dev.kobj, &workload_req_attribute_group);
117+
if (ret)
118+
return ret;
119+
120+
workload_req_created = true;
121+
122+
return 0;
123+
}
124+
EXPORT_SYMBOL_GPL(proc_thermal_wt_req_add);
125+
126+
void proc_thermal_wt_req_remove(struct pci_dev *pdev)
127+
{
128+
if (workload_req_created)
129+
sysfs_remove_group(&pdev->dev.kobj, &workload_req_attribute_group);
130+
131+
workload_req_created = false;
132+
}
133+
EXPORT_SYMBOL_GPL(proc_thermal_wt_req_remove);
134+
135+
MODULE_IMPORT_NS(INT340X_THERMAL);
136+
MODULE_LICENSE("GPL");

0 commit comments

Comments
 (0)