1a1d2a633SQiang Yu // SPDX-License-Identifier: GPL-2.0 OR MIT
2a1d2a633SQiang Yu /* Copyright 2018-2019 Qiang Yu <yuq825@gmail.com> */
3a1d2a633SQiang Yu
4a1d2a633SQiang Yu #include <linux/io.h>
5a1d2a633SQiang Yu #include <linux/device.h>
6a1d2a633SQiang Yu
7a1d2a633SQiang Yu #include "lima_device.h"
8a1d2a633SQiang Yu #include "lima_dlbu.h"
9a1d2a633SQiang Yu #include "lima_vm.h"
10a1d2a633SQiang Yu #include "lima_regs.h"
11a1d2a633SQiang Yu
12a1d2a633SQiang Yu #define dlbu_write(reg, data) writel(data, ip->iomem + reg)
13a1d2a633SQiang Yu #define dlbu_read(reg) readl(ip->iomem + reg)
14a1d2a633SQiang Yu
lima_dlbu_enable(struct lima_device * dev,int num_pp)15a1d2a633SQiang Yu void lima_dlbu_enable(struct lima_device *dev, int num_pp)
16a1d2a633SQiang Yu {
17a1d2a633SQiang Yu struct lima_sched_pipe *pipe = dev->pipe + lima_pipe_pp;
18a1d2a633SQiang Yu struct lima_ip *ip = dev->ip + lima_ip_dlbu;
19a1d2a633SQiang Yu int i, mask = 0;
20a1d2a633SQiang Yu
21a1d2a633SQiang Yu for (i = 0; i < num_pp; i++) {
22a1d2a633SQiang Yu struct lima_ip *pp = pipe->processor[i];
23a1d2a633SQiang Yu
24a1d2a633SQiang Yu mask |= 1 << (pp->id - lima_ip_pp0);
25a1d2a633SQiang Yu }
26a1d2a633SQiang Yu
27a1d2a633SQiang Yu dlbu_write(LIMA_DLBU_PP_ENABLE_MASK, mask);
28a1d2a633SQiang Yu }
29a1d2a633SQiang Yu
lima_dlbu_disable(struct lima_device * dev)30a1d2a633SQiang Yu void lima_dlbu_disable(struct lima_device *dev)
31a1d2a633SQiang Yu {
32a1d2a633SQiang Yu struct lima_ip *ip = dev->ip + lima_ip_dlbu;
33a1d2a633SQiang Yu
34a1d2a633SQiang Yu dlbu_write(LIMA_DLBU_PP_ENABLE_MASK, 0);
35a1d2a633SQiang Yu }
36a1d2a633SQiang Yu
lima_dlbu_set_reg(struct lima_ip * ip,u32 * reg)37a1d2a633SQiang Yu void lima_dlbu_set_reg(struct lima_ip *ip, u32 *reg)
38a1d2a633SQiang Yu {
39a1d2a633SQiang Yu dlbu_write(LIMA_DLBU_TLLIST_VBASEADDR, reg[0]);
40a1d2a633SQiang Yu dlbu_write(LIMA_DLBU_FB_DIM, reg[1]);
41a1d2a633SQiang Yu dlbu_write(LIMA_DLBU_TLLIST_CONF, reg[2]);
42a1d2a633SQiang Yu dlbu_write(LIMA_DLBU_START_TILE_POS, reg[3]);
43a1d2a633SQiang Yu }
44a1d2a633SQiang Yu
lima_dlbu_hw_init(struct lima_ip * ip)45*3446d7e9SQiang Yu static int lima_dlbu_hw_init(struct lima_ip *ip)
46a1d2a633SQiang Yu {
47a1d2a633SQiang Yu struct lima_device *dev = ip->dev;
48a1d2a633SQiang Yu
49a1d2a633SQiang Yu dlbu_write(LIMA_DLBU_MASTER_TLLIST_PHYS_ADDR, dev->dlbu_dma | 1);
50a1d2a633SQiang Yu dlbu_write(LIMA_DLBU_MASTER_TLLIST_VADDR, LIMA_VA_RESERVE_DLBU);
51a1d2a633SQiang Yu
52a1d2a633SQiang Yu return 0;
53a1d2a633SQiang Yu }
54a1d2a633SQiang Yu
lima_dlbu_resume(struct lima_ip * ip)55*3446d7e9SQiang Yu int lima_dlbu_resume(struct lima_ip *ip)
56*3446d7e9SQiang Yu {
57*3446d7e9SQiang Yu return lima_dlbu_hw_init(ip);
58*3446d7e9SQiang Yu }
59*3446d7e9SQiang Yu
lima_dlbu_suspend(struct lima_ip * ip)60*3446d7e9SQiang Yu void lima_dlbu_suspend(struct lima_ip *ip)
61*3446d7e9SQiang Yu {
62*3446d7e9SQiang Yu
63*3446d7e9SQiang Yu }
64*3446d7e9SQiang Yu
lima_dlbu_init(struct lima_ip * ip)65*3446d7e9SQiang Yu int lima_dlbu_init(struct lima_ip *ip)
66*3446d7e9SQiang Yu {
67*3446d7e9SQiang Yu return lima_dlbu_hw_init(ip);
68*3446d7e9SQiang Yu }
69*3446d7e9SQiang Yu
lima_dlbu_fini(struct lima_ip * ip)70a1d2a633SQiang Yu void lima_dlbu_fini(struct lima_ip *ip)
71a1d2a633SQiang Yu {
72a1d2a633SQiang Yu
73a1d2a633SQiang Yu }
74