Hello, On 12/21/2011 10:16 AM, Heiko Stübner wrote: > Use the data field of of_device_id to hold the type for > s3c_cpu_type. > > Signed-off-by: Heiko Stuebner <heiko@xxxxxxxxx> > Reviewed-by: Thomas Abraham <thomas.abraham@xxxxxxxxxx> > --- > drivers/rtc/rtc-s3c.c | 31 ++++++++++++++++++++++--------- > 1 files changed, 22 insertions(+), 9 deletions(-) > > diff --git a/drivers/rtc/rtc-s3c.c b/drivers/rtc/rtc-s3c.c > index 175067a..2885b25 100644 > --- a/drivers/rtc/rtc-s3c.c > +++ b/drivers/rtc/rtc-s3c.c > @@ -428,6 +428,20 @@ static int __devexit s3c_rtc_remove(struct platform_device *dev) > return 0; > } > > +static const struct of_device_id s3c_rtc_dt_match[]; > + > +static inline int s3c_rtc_get_driver_data(struct platform_device *pdev) > +{ > +#ifdef CONFIG_OF > + if (pdev->dev.of_node) { > + const struct of_device_id *match; > + match = of_match_node(s3c_rtc_dt_match, pdev->dev.of_node); > + return match->data; > + } > +#endif > + return platform_get_device_id(pdev)->driver_data; > +} > + > static int __devinit s3c_rtc_probe(struct platform_device *pdev) > { > struct rtc_device *rtc; > @@ -508,13 +522,7 @@ static int __devinit s3c_rtc_probe(struct platform_device *pdev) > goto err_nortc; > } > > -#ifdef CONFIG_OF > - if (pdev->dev.of_node) > - s3c_rtc_cpu_type = of_device_is_compatible(pdev->dev.of_node, > - "samsung,s3c6410-rtc") ? TYPE_S3C64XX : TYPE_S3C2410; > - else > -#endif > - s3c_rtc_cpu_type = platform_get_device_id(pdev)->driver_data; > + s3c_rtc_cpu_type = s3c_rtc_get_driver_data(pdev); > > /* Check RTC Time */ > > @@ -638,8 +646,13 @@ static int s3c_rtc_resume(struct platform_device *pdev) > > #ifdef CONFIG_OF > static const struct of_device_id s3c_rtc_dt_match[] = { > - { .compatible = "samsung,s3c2410-rtc" }, > - { .compatible = "samsung,s3c6410-rtc" }, > + { > + .compatible = "samsung,s3c2410-rtc" > + .data = TYPE_S3C2410, > + }, { > + .compatible = "samsung,s3c6410-rtc" > + .data = TYPE_S3C64XX, > + }, > {}, > }; > MODULE_DEVICE_TABLE(of, s3c_rtc_dt_match); This patch makes compilation with CONFIG_OF enabled fail with errors and warnings: drivers/rtc/rtc-s3c.c: In function ‘s3c_rtc_get_driver_data’: drivers/rtc/rtc-s3c.c:454: warning: return makes integer from pointer without a cast drivers/rtc/rtc-s3c.c: At top level: drivers/rtc/rtc-s3c.c:674: error: request for member ‘data’ in something not a structure or union drivers/rtc/rtc-s3c.c:677: error: request for member ‘data’ in something not a structure or union drivers/rtc/rtc-s3c.c:680: error: request for member ‘data’ in something not a structure or union drivers/rtc/rtc-s3c.c:683: error: request for member ‘data’ in something not a structure or union make[2]: *** [drivers/rtc/rtc-s3c.o] Error 1 And the following patch fixes this: 8<------------ diff --git a/drivers/rtc/rtc-s3c.c b/drivers/rtc/rtc-s3c.c index 4498053..9a0d388 100644 --- a/drivers/rtc/rtc-s3c.c +++ b/drivers/rtc/rtc-s3c.c @@ -451,7 +451,7 @@ static inline int s3c_rtc_get_driver_data(struct platform_device *pdev) if (pdev->dev.of_node) { const struct of_device_id *match; match = of_match_node(s3c_rtc_dt_match, pdev->dev.of_node); - return match->data; + return (int)match->data; } #endif return platform_get_device_id(pdev)->driver_data; @@ -670,17 +670,17 @@ static int s3c_rtc_resume(struct platform_device *pdev) #ifdef CONFIG_OF static const struct of_device_id s3c_rtc_dt_match[] = { { - .compatible = "samsung,s3c2410-rtc" - .data = TYPE_S3C2410, + .compatible = "samsung,s3c2410-rtc", + .data = (void*)TYPE_S3C2410, }, { - .compatible = "samsung,s3c2443-rtc" - .data = TYPE_S3C2443, + .compatible = "samsung,s3c2443-rtc", + .data = (void*)TYPE_S3C2443, }, { - .compatible = "samsung,s3c2416-rtc" - .data = TYPE_S3C2416, + .compatible = "samsung,s3c2416-rtc", + .data = (void*)TYPE_S3C2416, }, { - .compatible = "samsung,s3c6410-rtc" - .data = TYPE_S3C64XX, + .compatible = "samsung,s3c6410-rtc", + .data = (void*)TYPE_S3C64XX, }, {}, }; 8<----------------- -- Regards, Sylwester -- To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html