diff options
Diffstat (limited to 'arch/sh/kernel')
-rw-r--r-- | arch/sh/kernel/cpu/sh4a/clock-sh7722.c | 47 |
1 files changed, 9 insertions, 38 deletions
diff --git a/arch/sh/kernel/cpu/sh4a/clock-sh7722.c b/arch/sh/kernel/cpu/sh4a/clock-sh7722.c index 299138ebe160..d7b14660f737 100644 --- a/arch/sh/kernel/cpu/sh4a/clock-sh7722.c +++ b/arch/sh/kernel/cpu/sh4a/clock-sh7722.c | |||
@@ -411,40 +411,16 @@ static struct clk_ops sh7722_frqcr_clk_ops = { | |||
411 | * clock ops methods for SIU A/B and IrDA clock | 411 | * clock ops methods for SIU A/B and IrDA clock |
412 | * | 412 | * |
413 | */ | 413 | */ |
414 | static int sh7722_siu_which(struct clk *clk) | ||
415 | { | ||
416 | if (!strcmp(clk->name, "siu_a_clk")) | ||
417 | return 0; | ||
418 | if (!strcmp(clk->name, "siu_b_clk")) | ||
419 | return 1; | ||
420 | #if defined(CONFIG_CPU_SUBTYPE_SH7722) | ||
421 | if (!strcmp(clk->name, "irda_clk")) | ||
422 | return 2; | ||
423 | #endif | ||
424 | return -EINVAL; | ||
425 | } | ||
426 | |||
427 | static unsigned long sh7722_siu_regs[] = { | ||
428 | [0] = SCLKACR, | ||
429 | [1] = SCLKBCR, | ||
430 | #if defined(CONFIG_CPU_SUBTYPE_SH7722) | ||
431 | [2] = IrDACLKCR, | ||
432 | #endif | ||
433 | }; | ||
434 | 414 | ||
435 | static int sh7722_siu_start_stop(struct clk *clk, int enable) | 415 | static int sh7722_siu_start_stop(struct clk *clk, int enable) |
436 | { | 416 | { |
437 | int siu = sh7722_siu_which(clk); | ||
438 | unsigned long r; | 417 | unsigned long r; |
439 | 418 | ||
440 | if (siu < 0) | 419 | r = ctrl_inl(clk->arch_flags); |
441 | return siu; | ||
442 | BUG_ON(siu > 2); | ||
443 | r = ctrl_inl(sh7722_siu_regs[siu]); | ||
444 | if (enable) | 420 | if (enable) |
445 | ctrl_outl(r & ~(1 << 8), sh7722_siu_regs[siu]); | 421 | ctrl_outl(r & ~(1 << 8), clk->arch_flags); |
446 | else | 422 | else |
447 | ctrl_outl(r | (1 << 8), sh7722_siu_regs[siu]); | 423 | ctrl_outl(r | (1 << 8), clk->arch_flags); |
448 | return 0; | 424 | return 0; |
449 | } | 425 | } |
450 | 426 | ||
@@ -496,31 +472,23 @@ static void sh7722_video_recalc(struct clk *clk) | |||
496 | 472 | ||
497 | static int sh7722_siu_set_rate(struct clk *clk, unsigned long rate, int algo_id) | 473 | static int sh7722_siu_set_rate(struct clk *clk, unsigned long rate, int algo_id) |
498 | { | 474 | { |
499 | int siu = sh7722_siu_which(clk); | ||
500 | unsigned long r; | 475 | unsigned long r; |
501 | int div; | 476 | int div; |
502 | 477 | ||
503 | if (siu < 0) | 478 | r = ctrl_inl(clk->arch_flags); |
504 | return siu; | ||
505 | BUG_ON(siu > 2); | ||
506 | r = ctrl_inl(sh7722_siu_regs[siu]); | ||
507 | div = sh7722_find_divisors(clk->parent->rate, rate); | 479 | div = sh7722_find_divisors(clk->parent->rate, rate); |
508 | if (div < 0) | 480 | if (div < 0) |
509 | return div; | 481 | return div; |
510 | r = (r & ~0xF) | div; | 482 | r = (r & ~0xF) | div; |
511 | ctrl_outl(r, sh7722_siu_regs[siu]); | 483 | ctrl_outl(r, clk->arch_flags); |
512 | return 0; | 484 | return 0; |
513 | } | 485 | } |
514 | 486 | ||
515 | static void sh7722_siu_recalc(struct clk *clk) | 487 | static void sh7722_siu_recalc(struct clk *clk) |
516 | { | 488 | { |
517 | int siu = sh7722_siu_which(clk); | ||
518 | unsigned long r; | 489 | unsigned long r; |
519 | 490 | ||
520 | if (siu < 0) | 491 | r = ctrl_inl(clk->arch_flags); |
521 | return /* siu */ ; | ||
522 | BUG_ON(siu > 2); | ||
523 | r = ctrl_inl(sh7722_siu_regs[siu]); | ||
524 | clk->rate = clk->parent->rate * 2 / divisors2[r & 0xF]; | 492 | clk->rate = clk->parent->rate * 2 / divisors2[r & 0xF]; |
525 | } | 493 | } |
526 | 494 | ||
@@ -567,17 +535,20 @@ static struct clk sh7722_sdram_clock = { | |||
567 | */ | 535 | */ |
568 | static struct clk sh7722_siu_a_clock = { | 536 | static struct clk sh7722_siu_a_clock = { |
569 | .name = "siu_a_clk", | 537 | .name = "siu_a_clk", |
538 | .arch_flags = SCLKACR, | ||
570 | .ops = &sh7722_siu_clk_ops, | 539 | .ops = &sh7722_siu_clk_ops, |
571 | }; | 540 | }; |
572 | 541 | ||
573 | static struct clk sh7722_siu_b_clock = { | 542 | static struct clk sh7722_siu_b_clock = { |
574 | .name = "siu_b_clk", | 543 | .name = "siu_b_clk", |
544 | .arch_flags = SCLKBCR, | ||
575 | .ops = &sh7722_siu_clk_ops, | 545 | .ops = &sh7722_siu_clk_ops, |
576 | }; | 546 | }; |
577 | 547 | ||
578 | #if defined(CONFIG_CPU_SUBTYPE_SH7722) | 548 | #if defined(CONFIG_CPU_SUBTYPE_SH7722) |
579 | static struct clk sh7722_irda_clock = { | 549 | static struct clk sh7722_irda_clock = { |
580 | .name = "irda_clk", | 550 | .name = "irda_clk", |
551 | .arch_flags = IrDACLKCR, | ||
581 | .ops = &sh7722_siu_clk_ops, | 552 | .ops = &sh7722_siu_clk_ops, |
582 | }; | 553 | }; |
583 | #endif | 554 | #endif |