blob: 0b04b6b0fa302f97fef4996de97efe59ca572be4 [file] [log] [blame]
Kukjin Kimd9c452f2012-04-17 20:21:30 -07001/*
Kamil Debski0f75a962011-07-21 16:42:30 +09002 * Copyright (C) 2010-2011 Samsung Electronics Co.Ltd
3 *
4 * Base S5P MFC resource and device definitions
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License version 2 as
8 * published by the Free Software Foundation.
9 */
10
Kamil Debski0f75a962011-07-21 16:42:30 +090011#include <linux/kernel.h>
12#include <linux/interrupt.h>
13#include <linux/platform_device.h>
14#include <linux/dma-mapping.h>
15#include <linux/memblock.h>
16#include <linux/ioport.h>
Arun Kumar K2eae6132012-10-23 22:51:33 +090017#include <linux/of_fdt.h>
18#include <linux/of.h>
Kamil Debski0f75a962011-07-21 16:42:30 +090019
Tomasz Figa07fbe132013-06-19 01:28:56 +090020static struct platform_device s5p_device_mfc_l;
21static struct platform_device s5p_device_mfc_r;
Tomasz Figad78c16c2014-07-02 19:40:44 +020022
23struct s5p_mfc_dt_meminfo {
24 unsigned long loff;
25 unsigned long lsize;
26 unsigned long roff;
27 unsigned long rsize;
28 char *compatible;
29};
Arnd Bergmannf76da512013-04-10 14:49:03 +020030
Kamil Debski0f75a962011-07-21 16:42:30 +090031struct s5p_mfc_reserved_mem {
32 phys_addr_t base;
33 unsigned long size;
34 struct device *dev;
35};
36
37static struct s5p_mfc_reserved_mem s5p_mfc_mem[2] __initdata;
38
Tomasz Figa07fbe132013-06-19 01:28:56 +090039
Tomasz Figad78c16c2014-07-02 19:40:44 +020040static void __init s5p_mfc_reserve_mem(phys_addr_t rbase, unsigned int rsize,
Kamil Debski0f75a962011-07-21 16:42:30 +090041 phys_addr_t lbase, unsigned int lsize)
42{
43 int i;
44
45 s5p_mfc_mem[0].dev = &s5p_device_mfc_r.dev;
46 s5p_mfc_mem[0].base = rbase;
47 s5p_mfc_mem[0].size = rsize;
48
49 s5p_mfc_mem[1].dev = &s5p_device_mfc_l.dev;
50 s5p_mfc_mem[1].base = lbase;
51 s5p_mfc_mem[1].size = lsize;
52
53 for (i = 0; i < ARRAY_SIZE(s5p_mfc_mem); i++) {
54 struct s5p_mfc_reserved_mem *area = &s5p_mfc_mem[i];
55 if (memblock_remove(area->base, area->size)) {
56 printk(KERN_ERR "Failed to reserve memory for MFC device (%ld bytes at 0x%08lx)\n",
57 area->size, (unsigned long) area->base);
58 area->base = 0;
59 }
60 }
61}
62
Tushar Behera8b3e8bb2014-03-21 01:49:24 +090063int __init s5p_fdt_alloc_mfc_mem(unsigned long node, const char *uname,
Arun Kumar K2eae6132012-10-23 22:51:33 +090064 int depth, void *data)
65{
Rob Herring9d0c4df2014-04-01 23:49:03 -050066 const __be32 *prop;
67 int len;
Tushar Behera8b3e8bb2014-03-21 01:49:24 +090068 struct s5p_mfc_dt_meminfo mfc_mem;
Arun Kumar K2eae6132012-10-23 22:51:33 +090069
70 if (!data)
71 return 0;
72
Tushar Behera8b3e8bb2014-03-21 01:49:24 +090073 if (!of_flat_dt_is_compatible(node, data))
Arun Kumar K2eae6132012-10-23 22:51:33 +090074 return 0;
75
76 prop = of_get_flat_dt_prop(node, "samsung,mfc-l", &len);
77 if (!prop || (len != 2 * sizeof(unsigned long)))
78 return 0;
79
Tushar Behera8b3e8bb2014-03-21 01:49:24 +090080 mfc_mem.loff = be32_to_cpu(prop[0]);
81 mfc_mem.lsize = be32_to_cpu(prop[1]);
Arun Kumar K2eae6132012-10-23 22:51:33 +090082
83 prop = of_get_flat_dt_prop(node, "samsung,mfc-r", &len);
84 if (!prop || (len != 2 * sizeof(unsigned long)))
85 return 0;
86
Tushar Behera8b3e8bb2014-03-21 01:49:24 +090087 mfc_mem.roff = be32_to_cpu(prop[0]);
88 mfc_mem.rsize = be32_to_cpu(prop[1]);
89
90 s5p_mfc_reserve_mem(mfc_mem.roff, mfc_mem.rsize,
91 mfc_mem.loff, mfc_mem.lsize);
Arun Kumar K2eae6132012-10-23 22:51:33 +090092
93 return 1;
94}