video: tegra: refactor for multiple chip support
[linux-2.6.git] / drivers / video / tegra / host / t20 / cpuaccess_t20.c
1 /*
2  * drivers/video/tegra/host/cpuaccess_t20.c
3  *
4  * Tegra Graphics Host Cpu Register Access
5  *
6  * Copyright (c) 2010-2011, NVIDIA Corporation.
7  *
8  * This program is free software; you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation; either version 2 of the License, or
11  * (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful, but WITHOUT
14  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
15  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
16  * more details.
17  *
18  * You should have received a copy of the GNU General Public License along
19  * with this program; if not, write to the Free Software Foundation, Inc.,
20  * 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
21  */
22
23 #include "../nvhost_cpuaccess.h"
24 #include "../dev.h"
25
26 #include "hardware_t20.h"
27
28 static int t20_cpuaccess_mutex_try_lock(struct nvhost_cpuaccess *ctx,
29                                         unsigned int idx)
30 {
31         struct nvhost_master *dev = cpuaccess_to_dev(ctx);
32         void __iomem *sync_regs = dev->sync_aperture;
33         /* mlock registers returns 0 when the lock is aquired.
34          * writing 0 clears the lock. */
35         return !!readl(sync_regs + (HOST1X_SYNC_MLOCK_0 + idx * 4));
36 }
37
38 static void t20_cpuaccess_mutex_unlock(struct nvhost_cpuaccess *ctx,
39                                        unsigned int idx)
40 {
41         struct nvhost_master *dev = cpuaccess_to_dev(ctx);
42         void __iomem *sync_regs = dev->sync_aperture;
43
44         writel(0, sync_regs + (HOST1X_SYNC_MLOCK_0 + idx * 4));
45 }
46
47 int nvhost_init_t20_cpuaccess_support(struct nvhost_master *host)
48 {
49         host->nb_modules = NVHOST_MODULE_NUM;
50
51         host->op.cpuaccess.mutex_try_lock = t20_cpuaccess_mutex_try_lock;
52         host->op.cpuaccess.mutex_unlock = t20_cpuaccess_mutex_unlock;
53
54         return 0;
55 }