diff options
Diffstat (limited to 'arch/arm/plat-s3c24xx')
-rw-r--r-- | arch/arm/plat-s3c24xx/dma.c | 3 | ||||
-rw-r--r-- | arch/arm/plat-s3c24xx/s3c2443-clock.c | 16 |
2 files changed, 11 insertions, 8 deletions
diff --git a/arch/arm/plat-s3c24xx/dma.c b/arch/arm/plat-s3c24xx/dma.c index 53754bcf15a7..9fe35348e03b 100644 --- a/arch/arm/plat-s3c24xx/dma.c +++ b/arch/arm/plat-s3c24xx/dma.c | |||
@@ -1437,11 +1437,10 @@ int __init s3c24xx_dma_init_map(struct s3c24xx_dma_selection *sel) | |||
1437 | size_t map_sz = sizeof(*nmap) * sel->map_size; | 1437 | size_t map_sz = sizeof(*nmap) * sel->map_size; |
1438 | int ptr; | 1438 | int ptr; |
1439 | 1439 | ||
1440 | nmap = kmalloc(map_sz, GFP_KERNEL); | 1440 | nmap = kmemdup(sel->map, map_sz, GFP_KERNEL); |
1441 | if (nmap == NULL) | 1441 | if (nmap == NULL) |
1442 | return -ENOMEM; | 1442 | return -ENOMEM; |
1443 | 1443 | ||
1444 | memcpy(nmap, sel->map, map_sz); | ||
1445 | memcpy(&dma_sel, sel, sizeof(*sel)); | 1444 | memcpy(&dma_sel, sel, sizeof(*sel)); |
1446 | 1445 | ||
1447 | dma_sel.map = nmap; | 1446 | dma_sel.map = nmap; |
diff --git a/arch/arm/plat-s3c24xx/s3c2443-clock.c b/arch/arm/plat-s3c24xx/s3c2443-clock.c index 4eab2cca2d92..95e68190d593 100644 --- a/arch/arm/plat-s3c24xx/s3c2443-clock.c +++ b/arch/arm/plat-s3c24xx/s3c2443-clock.c | |||
@@ -427,12 +427,6 @@ static struct clk init_clocks[] = { | |||
427 | .enable = s3c2443_clkcon_enable_h, | 427 | .enable = s3c2443_clkcon_enable_h, |
428 | .ctrlbit = S3C2443_HCLKCON_DMA5, | 428 | .ctrlbit = S3C2443_HCLKCON_DMA5, |
429 | }, { | 429 | }, { |
430 | .name = "hsmmc", | ||
431 | .devname = "s3c-sdhci.1", | ||
432 | .parent = &clk_h, | ||
433 | .enable = s3c2443_clkcon_enable_h, | ||
434 | .ctrlbit = S3C2443_HCLKCON_HSMMC, | ||
435 | }, { | ||
436 | .name = "gpio", | 430 | .name = "gpio", |
437 | .parent = &clk_p, | 431 | .parent = &clk_p, |
438 | .enable = s3c2443_clkcon_enable_p, | 432 | .enable = s3c2443_clkcon_enable_p, |
@@ -514,6 +508,14 @@ static struct clk init_clocks[] = { | |||
514 | } | 508 | } |
515 | }; | 509 | }; |
516 | 510 | ||
511 | static struct clk hsmmc1_clk = { | ||
512 | .name = "hsmmc", | ||
513 | .devname = "s3c-sdhci.1", | ||
514 | .parent = &clk_h, | ||
515 | .enable = s3c2443_clkcon_enable_h, | ||
516 | .ctrlbit = S3C2443_HCLKCON_HSMMC, | ||
517 | }; | ||
518 | |||
517 | static inline unsigned long s3c2443_get_hdiv(unsigned long clkcon0) | 519 | static inline unsigned long s3c2443_get_hdiv(unsigned long clkcon0) |
518 | { | 520 | { |
519 | clkcon0 &= S3C2443_CLKDIV0_HCLKDIV_MASK; | 521 | clkcon0 &= S3C2443_CLKDIV0_HCLKDIV_MASK; |
@@ -579,6 +581,7 @@ static struct clk *clks[] __initdata = { | |||
579 | &clk_epll, | 581 | &clk_epll, |
580 | &clk_usb_bus, | 582 | &clk_usb_bus, |
581 | &clk_armdiv, | 583 | &clk_armdiv, |
584 | &hsmmc1_clk, | ||
582 | }; | 585 | }; |
583 | 586 | ||
584 | static struct clksrc_clk *clksrcs[] __initdata = { | 587 | static struct clksrc_clk *clksrcs[] __initdata = { |
@@ -595,6 +598,7 @@ static struct clk_lookup s3c2443_clk_lookup[] = { | |||
595 | CLKDEV_INIT(NULL, "clk_uart_baud1", &s3c24xx_uclk), | 598 | CLKDEV_INIT(NULL, "clk_uart_baud1", &s3c24xx_uclk), |
596 | CLKDEV_INIT(NULL, "clk_uart_baud2", &clk_p), | 599 | CLKDEV_INIT(NULL, "clk_uart_baud2", &clk_p), |
597 | CLKDEV_INIT(NULL, "clk_uart_baud3", &clk_esys_uart.clk), | 600 | CLKDEV_INIT(NULL, "clk_uart_baud3", &clk_esys_uart.clk), |
601 | CLKDEV_INIT("s3c-sdhci.1", "mmc_busclk.0", &hsmmc1_clk), | ||
598 | }; | 602 | }; |
599 | 603 | ||
600 | void __init s3c2443_common_init_clocks(int xtal, pll_fn get_mpll, | 604 | void __init s3c2443_common_init_clocks(int xtal, pll_fn get_mpll, |