2013-10-08 15:30:18 +09:00
/*
* Koelsch board support - Reference DT implementation
*
* Copyright ( C ) 2013 Renesas Electronics Corporation
* Copyright ( C ) 2013 Renesas Solutions Corp .
* Copyright ( C ) 2013 Magnus Damm
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation ; version 2 of the License .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write to the Free Software
* Foundation , Inc . , 51 Franklin St , Fifth Floor , Boston , MA 02110 - 1301 USA
*/
2013-12-11 15:13:55 +01:00
# include <linux/clk.h>
# include <linux/clkdev.h>
2014-02-16 22:32:01 +01:00
# include <linux/dma-mapping.h>
2013-10-08 15:30:18 +09:00
# include <linux/kernel.h>
# include <linux/of_platform.h>
2014-02-16 22:32:01 +01:00
# include <linux/platform_data/rcar-du.h>
2013-11-20 12:54:34 +09:00
# include <mach/common.h>
2014-02-16 22:32:01 +01:00
# include <mach/irqs.h>
2013-10-08 15:30:18 +09:00
# include <mach/rcar-gen2.h>
# include <mach/r8a7791.h>
# include <asm/mach/arch.h>
2014-02-16 22:32:01 +01:00
/* DU */
static struct rcar_du_encoder_data koelsch_du_encoders [ ] = {
{
. type = RCAR_DU_ENCODER_NONE ,
. output = RCAR_DU_OUTPUT_LVDS0 ,
. connector . lvds . panel = {
. width_mm = 210 ,
. height_mm = 158 ,
. mode = {
. clock = 65000 ,
. hdisplay = 1024 ,
. hsync_start = 1048 ,
. hsync_end = 1184 ,
. htotal = 1344 ,
. vdisplay = 768 ,
. vsync_start = 771 ,
. vsync_end = 777 ,
. vtotal = 806 ,
. flags = 0 ,
} ,
} ,
} ,
} ;
static struct rcar_du_platform_data koelsch_du_pdata = {
. encoders = koelsch_du_encoders ,
. num_encoders = ARRAY_SIZE ( koelsch_du_encoders ) ,
} ;
static const struct resource du_resources [ ] __initconst = {
DEFINE_RES_MEM ( 0xfeb00000 , 0x40000 ) ,
DEFINE_RES_MEM_NAMED ( 0xfeb90000 , 0x1c , " lvds.0 " ) ,
DEFINE_RES_IRQ ( gic_spi ( 256 ) ) ,
DEFINE_RES_IRQ ( gic_spi ( 268 ) ) ,
} ;
static void __init koelsch_add_du_device ( void )
{
struct platform_device_info info = {
. name = " rcar-du-r8a7791 " ,
. id = - 1 ,
. res = du_resources ,
. num_res = ARRAY_SIZE ( du_resources ) ,
. data = & koelsch_du_pdata ,
. size_data = sizeof ( koelsch_du_pdata ) ,
. dma_mask = DMA_BIT_MASK ( 32 ) ,
} ;
platform_device_register_full ( & info ) ;
}
2013-10-08 15:30:18 +09:00
static void __init koelsch_add_standard_devices ( void )
{
2013-12-11 15:13:55 +01:00
# ifdef CONFIG_COMMON_CLK
/*
2014-02-16 22:32:00 +01:00
* This is a really crude hack to provide clkdev support to the CMT and
* DU devices until they get moved to DT .
2013-12-11 15:13:55 +01:00
*/
2014-02-16 22:32:00 +01:00
static const struct clk_name {
const char * clk ;
const char * con_id ;
const char * dev_id ;
} clk_names [ ] = {
{ " cmt0 " , NULL , " sh_cmt.0 " } ,
{ " scifa0 " , NULL , " sh-sci.0 " } ,
{ " scifa1 " , NULL , " sh-sci.1 " } ,
{ " scifb0 " , NULL , " sh-sci.2 " } ,
{ " scifb1 " , NULL , " sh-sci.3 " } ,
{ " scifb2 " , NULL , " sh-sci.4 " } ,
{ " scifa2 " , NULL , " sh-sci.5 " } ,
{ " scif0 " , NULL , " sh-sci.6 " } ,
{ " scif1 " , NULL , " sh-sci.7 " } ,
{ " scif2 " , NULL , " sh-sci.8 " } ,
{ " scif3 " , NULL , " sh-sci.9 " } ,
{ " scif4 " , NULL , " sh-sci.10 " } ,
{ " scif5 " , NULL , " sh-sci.11 " } ,
{ " scifa3 " , NULL , " sh-sci.12 " } ,
{ " scifa4 " , NULL , " sh-sci.13 " } ,
{ " scifa5 " , NULL , " sh-sci.14 " } ,
2014-02-16 22:32:01 +01:00
{ " du0 " , " du.0 " , " rcar-du-r8a7791 " } ,
{ " du1 " , " du.1 " , " rcar-du-r8a7791 " } ,
{ " lvds0 " , " lvds.0 " , " rcar-du-r8a7791 " } ,
2013-12-11 15:13:55 +01:00
} ;
struct clk * clk ;
unsigned int i ;
2014-02-16 22:32:00 +01:00
for ( i = 0 ; i < ARRAY_SIZE ( clk_names ) ; + + i ) {
clk = clk_get ( NULL , clk_names [ i ] . clk ) ;
2014-01-14 18:43:27 +00:00
if ( ! IS_ERR ( clk ) ) {
2014-02-16 22:32:00 +01:00
clk_register_clkdev ( clk , clk_names [ i ] . con_id ,
clk_names [ i ] . dev_id ) ;
2013-12-11 15:13:55 +01:00
clk_put ( clk ) ;
}
}
# else
2013-10-08 15:30:18 +09:00
r8a7791_clock_init ( ) ;
2013-11-06 19:40:01 +09:00
# endif
2013-10-08 15:30:18 +09:00
r8a7791_add_dt_devices ( ) ;
of_platform_populate ( NULL , of_default_bus_match_table , NULL , NULL ) ;
2014-02-16 22:32:01 +01:00
koelsch_add_du_device ( ) ;
2013-10-08 15:30:18 +09:00
}
static const char * const koelsch_boards_compat_dt [ ] __initconst = {
2013-12-11 15:13:59 +01:00
" renesas,koelsch " ,
2013-10-08 15:30:18 +09:00
" renesas,koelsch-reference " ,
NULL ,
} ;
DT_MACHINE_START ( KOELSCH_DT , " koelsch " )
. smp = smp_ops ( r8a7791_smp_ops ) ,
. init_early = r8a7791_init_early ,
. init_time = rcar_gen2_timer_init ,
. init_machine = koelsch_add_standard_devices ,
2013-11-20 12:54:34 +09:00
. init_late = shmobile_init_late ,
2013-10-08 15:30:18 +09:00
. dt_compat = koelsch_boards_compat_dt ,
MACHINE_END