Skip to content

Commit d412f18

Browse files
BibbyHsiehmbgg
authored andcommitted
soc: mediatek: cmdq: add cmdq_dev_get_client_reg function
GCE cannot know the register base address, this function can help cmdq client to get the cmdq_client_reg structure. Signed-off-by: Bibby Hsieh <[email protected]> Reviewed-by: CK Hu <[email protected]> Reviewed-by: Houlong Wei <[email protected]> Signed-off-by: Matthias Brugger <[email protected]>
1 parent b2ff235 commit d412f18

File tree

2 files changed

+50
-0
lines changed

2 files changed

+50
-0
lines changed

drivers/soc/mediatek/mtk-cmdq-helper.c

Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -28,6 +28,35 @@ struct cmdq_instruction {
2828
u8 op;
2929
};
3030

31+
int cmdq_dev_get_client_reg(struct device *dev,
32+
struct cmdq_client_reg *client_reg, int idx)
33+
{
34+
struct of_phandle_args spec;
35+
int err;
36+
37+
if (!client_reg)
38+
return -ENOENT;
39+
40+
err = of_parse_phandle_with_fixed_args(dev->of_node,
41+
"mediatek,gce-client-reg",
42+
3, idx, &spec);
43+
if (err < 0) {
44+
dev_err(dev,
45+
"error %d can't parse gce-client-reg property (%d)",
46+
err, idx);
47+
48+
return err;
49+
}
50+
51+
client_reg->subsys = (u8)spec.args[0];
52+
client_reg->offset = (u16)spec.args[1];
53+
client_reg->size = (u16)spec.args[2];
54+
of_node_put(spec.np);
55+
56+
return 0;
57+
}
58+
EXPORT_SYMBOL(cmdq_dev_get_client_reg);
59+
3160
static void cmdq_client_timeout(struct timer_list *t)
3261
{
3362
struct cmdq_client *client = from_timer(client, t, timer);

include/linux/soc/mediatek/mtk-cmdq.h

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -15,6 +15,12 @@
1515

1616
struct cmdq_pkt;
1717

18+
struct cmdq_client_reg {
19+
u8 subsys;
20+
u16 offset;
21+
u16 size;
22+
};
23+
1824
struct cmdq_client {
1925
spinlock_t lock;
2026
u32 pkt_cnt;
@@ -24,6 +30,21 @@ struct cmdq_client {
2430
u32 timeout_ms; /* in unit of microsecond */
2531
};
2632

33+
/**
34+
* cmdq_dev_get_client_reg() - parse cmdq client reg from the device
35+
* node of CMDQ client
36+
* @dev: device of CMDQ mailbox client
37+
* @client_reg: CMDQ client reg pointer
38+
* @idx: the index of desired reg
39+
*
40+
* Return: 0 for success; else the error code is returned
41+
*
42+
* Help CMDQ client parsing the cmdq client reg
43+
* from the device node of CMDQ client.
44+
*/
45+
int cmdq_dev_get_client_reg(struct device *dev,
46+
struct cmdq_client_reg *client_reg, int idx);
47+
2748
/**
2849
* cmdq_mbox_create() - create CMDQ mailbox client and channel
2950
* @dev: device of CMDQ mailbox client

0 commit comments

Comments
 (0)