diff options
| -rw-r--r-- | sound/sparc/cs4231.c | 342 |
1 files changed, 168 insertions, 174 deletions
diff --git a/sound/sparc/cs4231.c b/sound/sparc/cs4231.c index 14b1277bc83a..e9086e95a31f 100644 --- a/sound/sparc/cs4231.c +++ b/sound/sparc/cs4231.c | |||
| @@ -62,49 +62,47 @@ MODULE_LICENSE("GPL"); | |||
| 62 | MODULE_SUPPORTED_DEVICE("{{Sun,CS4231}}"); | 62 | MODULE_SUPPORTED_DEVICE("{{Sun,CS4231}}"); |
| 63 | 63 | ||
| 64 | #ifdef SBUS_SUPPORT | 64 | #ifdef SBUS_SUPPORT |
| 65 | typedef struct sbus_dma_info { | 65 | struct sbus_dma_info { |
| 66 | spinlock_t lock; | 66 | spinlock_t lock; |
| 67 | int dir; | 67 | int dir; |
| 68 | void __iomem *regs; | 68 | void __iomem *regs; |
| 69 | } sbus_dma_info_t; | 69 | }; |
| 70 | #endif | 70 | #endif |
| 71 | 71 | ||
| 72 | typedef struct snd_cs4231 cs4231_t; | 72 | struct cs4231_dma_control { |
| 73 | |||
| 74 | typedef struct cs4231_dma_control { | ||
| 75 | void (*prepare)(struct cs4231_dma_control *dma_cont, int dir); | 73 | void (*prepare)(struct cs4231_dma_control *dma_cont, int dir); |
| 76 | void (*enable)(struct cs4231_dma_control *dma_cont, int on); | 74 | void (*enable)(struct cs4231_dma_control *dma_cont, int on); |
| 77 | int (*request)(struct cs4231_dma_control *dma_cont, dma_addr_t bus_addr, size_t len); | 75 | int (*request)(struct cs4231_dma_control *dma_cont, dma_addr_t bus_addr, size_t len); |
| 78 | unsigned int (*address)(struct cs4231_dma_control *dma_cont); | 76 | unsigned int (*address)(struct cs4231_dma_control *dma_cont); |
| 79 | void (*reset)(cs4231_t *chip); | 77 | void (*reset)(struct snd_cs4231 *chip); |
| 80 | void (*preallocate)(cs4231_t *chip, snd_pcm_t *pcm); | 78 | void (*preallocate)(struct snd_cs4231 *chip, struct snd_snd_pcm *pcm); |
| 81 | #ifdef EBUS_SUPPORT | 79 | #ifdef EBUS_SUPPORT |
| 82 | struct ebus_dma_info ebus_info; | 80 | struct ebus_dma_info ebus_info; |
| 83 | #endif | 81 | #endif |
| 84 | #ifdef SBUS_SUPPORT | 82 | #ifdef SBUS_SUPPORT |
| 85 | struct sbus_dma_info sbus_info; | 83 | struct sbus_dma_info sbus_info; |
| 86 | #endif | 84 | #endif |
| 87 | } cs4231_dma_control_t; | 85 | }; |
| 88 | 86 | ||
| 89 | struct snd_cs4231 { | 87 | struct snd_cs4231 { |
| 90 | spinlock_t lock; | 88 | spinlock_t lock; |
| 91 | void __iomem *port; | 89 | void __iomem *port; |
| 92 | 90 | ||
| 93 | cs4231_dma_control_t p_dma; | 91 | struct cs4231_dma_control p_dma; |
| 94 | cs4231_dma_control_t c_dma; | 92 | struct cs4231_dma_control c_dma; |
| 95 | 93 | ||
| 96 | u32 flags; | 94 | u32 flags; |
| 97 | #define CS4231_FLAG_EBUS 0x00000001 | 95 | #define CS4231_FLAG_EBUS 0x00000001 |
| 98 | #define CS4231_FLAG_PLAYBACK 0x00000002 | 96 | #define CS4231_FLAG_PLAYBACK 0x00000002 |
| 99 | #define CS4231_FLAG_CAPTURE 0x00000004 | 97 | #define CS4231_FLAG_CAPTURE 0x00000004 |
| 100 | 98 | ||
| 101 | snd_card_t *card; | 99 | struct snd_card *card; |
| 102 | snd_pcm_t *pcm; | 100 | struct snd_pcm *pcm; |
| 103 | snd_pcm_substream_t *playback_substream; | 101 | struct snd_pcm_substream *playback_substream; |
| 104 | unsigned int p_periods_sent; | 102 | unsigned int p_periods_sent; |
| 105 | snd_pcm_substream_t *capture_substream; | 103 | struct snd_pcm_substream *capture_substream; |
| 106 | unsigned int c_periods_sent; | 104 | unsigned int c_periods_sent; |
| 107 | snd_timer_t *timer; | 105 | struct snd_timer *timer; |
| 108 | 106 | ||
| 109 | unsigned short mode; | 107 | unsigned short mode; |
| 110 | #define CS4231_MODE_NONE 0x0000 | 108 | #define CS4231_MODE_NONE 0x0000 |
| @@ -132,7 +130,7 @@ struct snd_cs4231 { | |||
| 132 | struct snd_cs4231 *next; | 130 | struct snd_cs4231 *next; |
| 133 | }; | 131 | }; |
| 134 | 132 | ||
| 135 | static cs4231_t *cs4231_list; | 133 | static struct snd_cs4231 *cs4231_list; |
| 136 | 134 | ||
| 137 | /* Eventually we can use sound/isa/cs423x/cs4231_lib.c directly, but for | 135 | /* Eventually we can use sound/isa/cs423x/cs4231_lib.c directly, but for |
| 138 | * now.... -DaveM | 136 | * now.... -DaveM |
| @@ -341,12 +339,12 @@ static unsigned int rates[14] = { | |||
| 341 | 27042, 32000, 33075, 37800, 44100, 48000 | 339 | 27042, 32000, 33075, 37800, 44100, 48000 |
| 342 | }; | 340 | }; |
| 343 | 341 | ||
| 344 | static snd_pcm_hw_constraint_list_t hw_constraints_rates = { | 342 | static struct snd_pcm_hw_constraint_list hw_constraints_rates = { |
| 345 | .count = 14, | 343 | .count = 14, |
| 346 | .list = rates, | 344 | .list = rates, |
| 347 | }; | 345 | }; |
| 348 | 346 | ||
| 349 | static int snd_cs4231_xrate(snd_pcm_runtime_t *runtime) | 347 | static int snd_cs4231_xrate(struct snd_pcm_runtime *runtime) |
| 350 | { | 348 | { |
| 351 | return snd_pcm_hw_constraint_list(runtime, 0, | 349 | return snd_pcm_hw_constraint_list(runtime, 0, |
| 352 | SNDRV_PCM_HW_PARAM_RATE, | 350 | SNDRV_PCM_HW_PARAM_RATE, |
| @@ -389,7 +387,7 @@ static unsigned char snd_cs4231_original_image[32] = | |||
| 389 | 0x00, /* 1f/31 - cbrl */ | 387 | 0x00, /* 1f/31 - cbrl */ |
| 390 | }; | 388 | }; |
| 391 | 389 | ||
| 392 | static u8 __cs4231_readb(cs4231_t *cp, void __iomem *reg_addr) | 390 | static u8 __cs4231_readb(struct snd_cs4231 *cp, void __iomem *reg_addr) |
| 393 | { | 391 | { |
| 394 | #ifdef EBUS_SUPPORT | 392 | #ifdef EBUS_SUPPORT |
| 395 | if (cp->flags & CS4231_FLAG_EBUS) { | 393 | if (cp->flags & CS4231_FLAG_EBUS) { |
| @@ -404,7 +402,7 @@ static u8 __cs4231_readb(cs4231_t *cp, void __iomem *reg_addr) | |||
| 404 | #endif | 402 | #endif |
| 405 | } | 403 | } |
| 406 | 404 | ||
| 407 | static void __cs4231_writeb(cs4231_t *cp, u8 val, void __iomem *reg_addr) | 405 | static void __cs4231_writeb(struct snd_cs4231 *cp, u8 val, void __iomem *reg_addr) |
| 408 | { | 406 | { |
| 409 | #ifdef EBUS_SUPPORT | 407 | #ifdef EBUS_SUPPORT |
| 410 | if (cp->flags & CS4231_FLAG_EBUS) { | 408 | if (cp->flags & CS4231_FLAG_EBUS) { |
| @@ -423,7 +421,7 @@ static void __cs4231_writeb(cs4231_t *cp, u8 val, void __iomem *reg_addr) | |||
| 423 | * Basic I/O functions | 421 | * Basic I/O functions |
| 424 | */ | 422 | */ |
| 425 | 423 | ||
| 426 | static void snd_cs4231_outm(cs4231_t *chip, unsigned char reg, | 424 | static void snd_cs4231_outm(struct snd_cs4231 *chip, unsigned char reg, |
| 427 | unsigned char mask, unsigned char value) | 425 | unsigned char mask, unsigned char value) |
| 428 | { | 426 | { |
| 429 | int timeout; | 427 | int timeout; |
| @@ -450,7 +448,7 @@ static void snd_cs4231_outm(cs4231_t *chip, unsigned char reg, | |||
| 450 | } | 448 | } |
| 451 | } | 449 | } |
| 452 | 450 | ||
| 453 | static void snd_cs4231_dout(cs4231_t *chip, unsigned char reg, unsigned char value) | 451 | static void snd_cs4231_dout(struct snd_cs4231 *chip, unsigned char reg, unsigned char value) |
| 454 | { | 452 | { |
| 455 | int timeout; | 453 | int timeout; |
| 456 | 454 | ||
| @@ -467,7 +465,7 @@ static void snd_cs4231_dout(cs4231_t *chip, unsigned char reg, unsigned char val | |||
| 467 | mb(); | 465 | mb(); |
| 468 | } | 466 | } |
| 469 | 467 | ||
| 470 | static void snd_cs4231_out(cs4231_t *chip, unsigned char reg, unsigned char value) | 468 | static void snd_cs4231_out(struct snd_cs4231 *chip, unsigned char reg, unsigned char value) |
| 471 | { | 469 | { |
| 472 | int timeout; | 470 | int timeout; |
| 473 | 471 | ||
| @@ -485,7 +483,7 @@ static void snd_cs4231_out(cs4231_t *chip, unsigned char reg, unsigned char valu | |||
| 485 | mb(); | 483 | mb(); |
| 486 | } | 484 | } |
| 487 | 485 | ||
| 488 | static unsigned char snd_cs4231_in(cs4231_t *chip, unsigned char reg) | 486 | static unsigned char snd_cs4231_in(struct snd_cs4231 *chip, unsigned char reg) |
| 489 | { | 487 | { |
| 490 | int timeout; | 488 | int timeout; |
| 491 | unsigned char ret; | 489 | unsigned char ret; |
| @@ -508,7 +506,7 @@ static unsigned char snd_cs4231_in(cs4231_t *chip, unsigned char reg) | |||
| 508 | * CS4231 detection / MCE routines | 506 | * CS4231 detection / MCE routines |
| 509 | */ | 507 | */ |
| 510 | 508 | ||
| 511 | static void snd_cs4231_busy_wait(cs4231_t *chip) | 509 | static void snd_cs4231_busy_wait(struct snd_cs4231 *chip) |
| 512 | { | 510 | { |
| 513 | int timeout; | 511 | int timeout; |
| 514 | 512 | ||
| @@ -523,7 +521,7 @@ static void snd_cs4231_busy_wait(cs4231_t *chip) | |||
| 523 | udelay(1000); | 521 | udelay(1000); |
| 524 | } | 522 | } |
| 525 | 523 | ||
| 526 | static void snd_cs4231_mce_up(cs4231_t *chip) | 524 | static void snd_cs4231_mce_up(struct snd_cs4231 *chip) |
| 527 | { | 525 | { |
| 528 | unsigned long flags; | 526 | unsigned long flags; |
| 529 | int timeout; | 527 | int timeout; |
| @@ -544,7 +542,7 @@ static void snd_cs4231_mce_up(cs4231_t *chip) | |||
| 544 | spin_unlock_irqrestore(&chip->lock, flags); | 542 | spin_unlock_irqrestore(&chip->lock, flags); |
| 545 | } | 543 | } |
| 546 | 544 | ||
| 547 | static void snd_cs4231_mce_down(cs4231_t *chip) | 545 | static void snd_cs4231_mce_down(struct snd_cs4231 *chip) |
| 548 | { | 546 | { |
| 549 | unsigned long flags; | 547 | unsigned long flags; |
| 550 | int timeout; | 548 | int timeout; |
| @@ -602,9 +600,11 @@ static void snd_cs4231_mce_down(cs4231_t *chip) | |||
| 602 | spin_unlock_irqrestore(&chip->lock, flags); | 600 | spin_unlock_irqrestore(&chip->lock, flags); |
| 603 | } | 601 | } |
| 604 | 602 | ||
| 605 | static void snd_cs4231_advance_dma(struct cs4231_dma_control *dma_cont, snd_pcm_substream_t *substream, unsigned int *periods_sent) | 603 | static void snd_cs4231_advance_dma(struct cs4231_dma_control *dma_cont, |
| 604 | struct snd_pcm_substream *substream, | ||
| 605 | unsigned int *periods_sent) | ||
| 606 | { | 606 | { |
| 607 | snd_pcm_runtime_t *runtime = substream->runtime; | 607 | struct snd_pcm_runtime *runtime = substream->runtime; |
| 608 | 608 | ||
| 609 | while (1) { | 609 | while (1) { |
| 610 | unsigned int period_size = snd_pcm_lib_period_bytes(substream); | 610 | unsigned int period_size = snd_pcm_lib_period_bytes(substream); |
| @@ -619,10 +619,11 @@ static void snd_cs4231_advance_dma(struct cs4231_dma_control *dma_cont, snd_pcm_ | |||
| 619 | } | 619 | } |
| 620 | } | 620 | } |
| 621 | 621 | ||
| 622 | static void cs4231_dma_trigger(snd_pcm_substream_t *substream, unsigned int what, int on) | 622 | static void cs4231_dma_trigger(struct snd_pcm_substream *substream, |
| 623 | unsigned int what, int on) | ||
| 623 | { | 624 | { |
| 624 | cs4231_t *chip = snd_pcm_substream_chip(substream); | 625 | struct snd_cs4231 *chip = snd_pcm_substream_chip(substream); |
| 625 | cs4231_dma_control_t *dma_cont; | 626 | struct cs4231_dma_control *dma_cont; |
| 626 | 627 | ||
| 627 | if (what & CS4231_PLAYBACK_ENABLE) { | 628 | if (what & CS4231_PLAYBACK_ENABLE) { |
| 628 | dma_cont = &chip->p_dma; | 629 | dma_cont = &chip->p_dma; |
| @@ -650,9 +651,9 @@ static void cs4231_dma_trigger(snd_pcm_substream_t *substream, unsigned int what | |||
| 650 | } | 651 | } |
| 651 | } | 652 | } |
| 652 | 653 | ||
| 653 | static int snd_cs4231_trigger(snd_pcm_substream_t *substream, int cmd) | 654 | static int snd_cs4231_trigger(struct snd_pcm_substream *substream, int cmd) |
| 654 | { | 655 | { |
| 655 | cs4231_t *chip = snd_pcm_substream_chip(substream); | 656 | struct snd_cs4231 *chip = snd_pcm_substream_chip(substream); |
| 656 | int result = 0; | 657 | int result = 0; |
| 657 | 658 | ||
| 658 | switch (cmd) { | 659 | switch (cmd) { |
| @@ -660,7 +661,7 @@ static int snd_cs4231_trigger(snd_pcm_substream_t *substream, int cmd) | |||
| 660 | case SNDRV_PCM_TRIGGER_STOP: | 661 | case SNDRV_PCM_TRIGGER_STOP: |
| 661 | { | 662 | { |
| 662 | unsigned int what = 0; | 663 | unsigned int what = 0; |
| 663 | snd_pcm_substream_t *s; | 664 | struct snd_pcm_substream *s; |
| 664 | struct list_head *pos; | 665 | struct list_head *pos; |
| 665 | unsigned long flags; | 666 | unsigned long flags; |
| 666 | 667 | ||
| @@ -711,7 +712,7 @@ static unsigned char snd_cs4231_get_rate(unsigned int rate) | |||
| 711 | return freq_bits[13]; | 712 | return freq_bits[13]; |
| 712 | } | 713 | } |
| 713 | 714 | ||
| 714 | static unsigned char snd_cs4231_get_format(cs4231_t *chip, int format, int channels) | 715 | static unsigned char snd_cs4231_get_format(struct snd_cs4231 *chip, int format, int channels) |
| 715 | { | 716 | { |
| 716 | unsigned char rformat; | 717 | unsigned char rformat; |
| 717 | 718 | ||
| @@ -728,7 +729,7 @@ static unsigned char snd_cs4231_get_format(cs4231_t *chip, int format, int chann | |||
| 728 | return rformat; | 729 | return rformat; |
| 729 | } | 730 | } |
| 730 | 731 | ||
| 731 | static void snd_cs4231_calibrate_mute(cs4231_t *chip, int mute) | 732 | static void snd_cs4231_calibrate_mute(struct snd_cs4231 *chip, int mute) |
| 732 | { | 733 | { |
| 733 | unsigned long flags; | 734 | unsigned long flags; |
| 734 | 735 | ||
| @@ -768,7 +769,7 @@ static void snd_cs4231_calibrate_mute(cs4231_t *chip, int mute) | |||
| 768 | spin_unlock_irqrestore(&chip->lock, flags); | 769 | spin_unlock_irqrestore(&chip->lock, flags); |
| 769 | } | 770 | } |
| 770 | 771 | ||
| 771 | static void snd_cs4231_playback_format(cs4231_t *chip, snd_pcm_hw_params_t *params, | 772 | static void snd_cs4231_playback_format(struct snd_cs4231 *chip, struct snd_pcm_hw_params *params, |
| 772 | unsigned char pdfr) | 773 | unsigned char pdfr) |
| 773 | { | 774 | { |
| 774 | unsigned long flags; | 775 | unsigned long flags; |
| @@ -791,7 +792,7 @@ static void snd_cs4231_playback_format(cs4231_t *chip, snd_pcm_hw_params_t *para | |||
| 791 | up(&chip->mce_mutex); | 792 | up(&chip->mce_mutex); |
| 792 | } | 793 | } |
| 793 | 794 | ||
| 794 | static void snd_cs4231_capture_format(cs4231_t *chip, snd_pcm_hw_params_t *params, | 795 | static void snd_cs4231_capture_format(struct snd_cs4231 *chip, struct snd_pcm_hw_params *params, |
| 795 | unsigned char cdfr) | 796 | unsigned char cdfr) |
| 796 | { | 797 | { |
| 797 | unsigned long flags; | 798 | unsigned long flags; |
| @@ -824,18 +825,18 @@ static void snd_cs4231_capture_format(cs4231_t *chip, snd_pcm_hw_params_t *param | |||
| 824 | * Timer interface | 825 | * Timer interface |
| 825 | */ | 826 | */ |
| 826 | 827 | ||
| 827 | static unsigned long snd_cs4231_timer_resolution(snd_timer_t *timer) | 828 | static unsigned long snd_cs4231_timer_resolution(struct snd_timer *timer) |
| 828 | { | 829 | { |
| 829 | cs4231_t *chip = snd_timer_chip(timer); | 830 | struct snd_cs4231 *chip = snd_timer_chip(timer); |
| 830 | 831 | ||
| 831 | return chip->image[CS4231_PLAYBK_FORMAT] & 1 ? 9969 : 9920; | 832 | return chip->image[CS4231_PLAYBK_FORMAT] & 1 ? 9969 : 9920; |
| 832 | } | 833 | } |
| 833 | 834 | ||
| 834 | static int snd_cs4231_timer_start(snd_timer_t *timer) | 835 | static int snd_cs4231_timer_start(struct snd_timer *timer) |
| 835 | { | 836 | { |
| 836 | unsigned long flags; | 837 | unsigned long flags; |
| 837 | unsigned int ticks; | 838 | unsigned int ticks; |
| 838 | cs4231_t *chip = snd_timer_chip(timer); | 839 | struct snd_cs4231 *chip = snd_timer_chip(timer); |
| 839 | 840 | ||
| 840 | spin_lock_irqsave(&chip->lock, flags); | 841 | spin_lock_irqsave(&chip->lock, flags); |
| 841 | ticks = timer->sticks; | 842 | ticks = timer->sticks; |
| @@ -856,10 +857,10 @@ static int snd_cs4231_timer_start(snd_timer_t *timer) | |||
| 856 | return 0; | 857 | return 0; |
| 857 | } | 858 | } |
| 858 | 859 | ||
| 859 | static int snd_cs4231_timer_stop(snd_timer_t *timer) | 860 | static int snd_cs4231_timer_stop(struct snd_timer *timer) |
| 860 | { | 861 | { |
| 861 | unsigned long flags; | 862 | unsigned long flags; |
| 862 | cs4231_t *chip = snd_timer_chip(timer); | 863 | struct snd_cs4231 *chip = snd_timer_chip(timer); |
| 863 | 864 | ||
| 864 | spin_lock_irqsave(&chip->lock, flags); | 865 | spin_lock_irqsave(&chip->lock, flags); |
| 865 | snd_cs4231_out(chip, CS4231_ALT_FEATURE_1, | 866 | snd_cs4231_out(chip, CS4231_ALT_FEATURE_1, |
| @@ -869,7 +870,7 @@ static int snd_cs4231_timer_stop(snd_timer_t *timer) | |||
| 869 | return 0; | 870 | return 0; |
| 870 | } | 871 | } |
| 871 | 872 | ||
| 872 | static void snd_cs4231_init(cs4231_t *chip) | 873 | static void __init snd_cs4231_init(struct snd_cs4231 *chip) |
| 873 | { | 874 | { |
| 874 | unsigned long flags; | 875 | unsigned long flags; |
| 875 | 876 | ||
| @@ -927,7 +928,7 @@ static void snd_cs4231_init(cs4231_t *chip) | |||
| 927 | #endif | 928 | #endif |
| 928 | } | 929 | } |
| 929 | 930 | ||
| 930 | static int snd_cs4231_open(cs4231_t *chip, unsigned int mode) | 931 | static int snd_cs4231_open(struct snd_cs4231 *chip, unsigned int mode) |
| 931 | { | 932 | { |
| 932 | unsigned long flags; | 933 | unsigned long flags; |
| 933 | 934 | ||
| @@ -962,7 +963,7 @@ static int snd_cs4231_open(cs4231_t *chip, unsigned int mode) | |||
| 962 | return 0; | 963 | return 0; |
| 963 | } | 964 | } |
| 964 | 965 | ||
| 965 | static void snd_cs4231_close(cs4231_t *chip, unsigned int mode) | 966 | static void snd_cs4231_close(struct snd_cs4231 *chip, unsigned int mode) |
| 966 | { | 967 | { |
| 967 | unsigned long flags; | 968 | unsigned long flags; |
| 968 | 969 | ||
| @@ -1013,21 +1014,21 @@ static void snd_cs4231_close(cs4231_t *chip, unsigned int mode) | |||
| 1013 | * timer open/close | 1014 | * timer open/close |
| 1014 | */ | 1015 | */ |
| 1015 | 1016 | ||
| 1016 | static int snd_cs4231_timer_open(snd_timer_t *timer) | 1017 | static int snd_cs4231_timer_open(struct snd_timer *timer) |
| 1017 | { | 1018 | { |
| 1018 | cs4231_t *chip = snd_timer_chip(timer); | 1019 | struct snd_cs4231 *chip = snd_timer_chip(timer); |
| 1019 | snd_cs4231_open(chip, CS4231_MODE_TIMER); | 1020 | snd_cs4231_open(chip, CS4231_MODE_TIMER); |
| 1020 | return 0; | 1021 | return 0; |
| 1021 | } | 1022 | } |
| 1022 | 1023 | ||
| 1023 | static int snd_cs4231_timer_close(snd_timer_t * timer) | 1024 | static int snd_cs4231_timer_close(struct snd_timer * timer) |
| 1024 | { | 1025 | { |
| 1025 | cs4231_t *chip = snd_timer_chip(timer); | 1026 | struct snd_cs4231 *chip = snd_timer_chip(timer); |
| 1026 | snd_cs4231_close(chip, CS4231_MODE_TIMER); | 1027 | snd_cs4231_close(chip, CS4231_MODE_TIMER); |
| 1027 | return 0; | 1028 | return 0; |
| 1028 | } | 1029 | } |
| 1029 | 1030 | ||
| 1030 | static struct _snd_timer_hardware snd_cs4231_timer_table = | 1031 | static struct snd_timer_hardware snd_cs4231_timer_table = |
| 1031 | { | 1032 | { |
| 1032 | .flags = SNDRV_TIMER_HW_AUTO, | 1033 | .flags = SNDRV_TIMER_HW_AUTO, |
| 1033 | .resolution = 9945, | 1034 | .resolution = 9945, |
| @@ -1043,10 +1044,10 @@ static struct _snd_timer_hardware snd_cs4231_timer_table = | |||
| 1043 | * ok.. exported functions.. | 1044 | * ok.. exported functions.. |
| 1044 | */ | 1045 | */ |
| 1045 | 1046 | ||
| 1046 | static int snd_cs4231_playback_hw_params(snd_pcm_substream_t *substream, | 1047 | static int snd_cs4231_playback_hw_params(struct snd_pcm_substream *substream, |
| 1047 | snd_pcm_hw_params_t *hw_params) | 1048 | struct snd_pcm_hw_params *hw_params) |
| 1048 | { | 1049 | { |
| 1049 | cs4231_t *chip = snd_pcm_substream_chip(substream); | 1050 | struct snd_cs4231 *chip = snd_pcm_substream_chip(substream); |
| 1050 | unsigned char new_pdfr; | 1051 | unsigned char new_pdfr; |
| 1051 | int err; | 1052 | int err; |
| 1052 | 1053 | ||
| @@ -1061,15 +1062,15 @@ static int snd_cs4231_playback_hw_params(snd_pcm_substream_t *substream, | |||
| 1061 | return 0; | 1062 | return 0; |
| 1062 | } | 1063 | } |
| 1063 | 1064 | ||
| 1064 | static int snd_cs4231_playback_hw_free(snd_pcm_substream_t *substream) | 1065 | static int snd_cs4231_playback_hw_free(struct snd_pcm_substream *substream) |
| 1065 | { | 1066 | { |
| 1066 | return snd_pcm_lib_free_pages(substream); | 1067 | return snd_pcm_lib_free_pages(substream); |
| 1067 | } | 1068 | } |
| 1068 | 1069 | ||
| 1069 | static int snd_cs4231_playback_prepare(snd_pcm_substream_t *substream) | 1070 | static int snd_cs4231_playback_prepare(struct snd_pcm_substream *substream) |
| 1070 | { | 1071 | { |
| 1071 | cs4231_t *chip = snd_pcm_substream_chip(substream); | 1072 | struct snd_cs4231 *chip = snd_pcm_substream_chip(substream); |
| 1072 | snd_pcm_runtime_t *runtime = substream->runtime; | 1073 | struct snd_pcm_runtime *runtime = substream->runtime; |
| 1073 | unsigned long flags; | 1074 | unsigned long flags; |
| 1074 | 1075 | ||
| 1075 | spin_lock_irqsave(&chip->lock, flags); | 1076 | spin_lock_irqsave(&chip->lock, flags); |
| @@ -1086,10 +1087,10 @@ static int snd_cs4231_playback_prepare(snd_pcm_substream_t *substream) | |||
| 1086 | return 0; | 1087 | return 0; |
| 1087 | } | 1088 | } |
| 1088 | 1089 | ||
| 1089 | static int snd_cs4231_capture_hw_params(snd_pcm_substream_t *substream, | 1090 | static int snd_cs4231_capture_hw_params(struct snd_pcm_substream *substream, |
| 1090 | snd_pcm_hw_params_t *hw_params) | 1091 | struct snd_pcm_hw_params *hw_params) |
| 1091 | { | 1092 | { |
| 1092 | cs4231_t *chip = snd_pcm_substream_chip(substream); | 1093 | struct snd_cs4231 *chip = snd_pcm_substream_chip(substream); |
| 1093 | unsigned char new_cdfr; | 1094 | unsigned char new_cdfr; |
| 1094 | int err; | 1095 | int err; |
| 1095 | 1096 | ||
| @@ -1104,14 +1105,14 @@ static int snd_cs4231_capture_hw_params(snd_pcm_substream_t *substream, | |||
| 1104 | return 0; | 1105 | return 0; |
| 1105 | } | 1106 | } |
| 1106 | 1107 | ||
| 1107 | static int snd_cs4231_capture_hw_free(snd_pcm_substream_t *substream) | 1108 | static int snd_cs4231_capture_hw_free(struct snd_pcm_substream *substream) |
| 1108 | { | 1109 | { |
| 1109 | return snd_pcm_lib_free_pages(substream); | 1110 | return snd_pcm_lib_free_pages(substream); |
| 1110 | } | 1111 | } |
| 1111 | 1112 | ||
| 1112 | static int snd_cs4231_capture_prepare(snd_pcm_substream_t *substream) | 1113 | static int snd_cs4231_capture_prepare(struct snd_pcm_substream *substream) |
| 1113 | { | 1114 | { |
| 1114 | cs4231_t *chip = snd_pcm_substream_chip(substream); | 1115 | struct snd_cs4231 *chip = snd_pcm_substream_chip(substream); |
| 1115 | unsigned long flags; | 1116 | unsigned long flags; |
| 1116 | 1117 | ||
| 1117 | spin_lock_irqsave(&chip->lock, flags); | 1118 | spin_lock_irqsave(&chip->lock, flags); |
| @@ -1125,7 +1126,7 @@ static int snd_cs4231_capture_prepare(snd_pcm_substream_t *substream) | |||
| 1125 | return 0; | 1126 | return 0; |
| 1126 | } | 1127 | } |
| 1127 | 1128 | ||
| 1128 | static void snd_cs4231_overrange(cs4231_t *chip) | 1129 | static void snd_cs4231_overrange(struct snd_cs4231 *chip) |
| 1129 | { | 1130 | { |
| 1130 | unsigned long flags; | 1131 | unsigned long flags; |
| 1131 | unsigned char res; | 1132 | unsigned char res; |
| @@ -1138,10 +1139,8 @@ static void snd_cs4231_overrange(cs4231_t *chip) | |||
| 1138 | chip->capture_substream->runtime->overrange++; | 1139 | chip->capture_substream->runtime->overrange++; |
| 1139 | } | 1140 | } |
| 1140 | 1141 | ||
| 1141 | static void snd_cs4231_play_callback(cs4231_t *cookie) | 1142 | static void snd_cs4231_play_callback(struct snd_cs4231 *chip) |
| 1142 | { | 1143 | { |
| 1143 | cs4231_t *chip = cookie; | ||
| 1144 | |||
| 1145 | if (chip->image[CS4231_IFACE_CTRL] & CS4231_PLAYBACK_ENABLE) { | 1144 | if (chip->image[CS4231_IFACE_CTRL] & CS4231_PLAYBACK_ENABLE) { |
| 1146 | snd_pcm_period_elapsed(chip->playback_substream); | 1145 | snd_pcm_period_elapsed(chip->playback_substream); |
| 1147 | snd_cs4231_advance_dma(&chip->p_dma, chip->playback_substream, | 1146 | snd_cs4231_advance_dma(&chip->p_dma, chip->playback_substream, |
| @@ -1149,10 +1148,8 @@ static void snd_cs4231_play_callback(cs4231_t *cookie) | |||
| 1149 | } | 1148 | } |
| 1150 | } | 1149 | } |
| 1151 | 1150 | ||
| 1152 | static void snd_cs4231_capture_callback(cs4231_t *cookie) | 1151 | static void snd_cs4231_capture_callback(struct snd_cs4231 *chip) |
| 1153 | { | 1152 | { |
| 1154 | cs4231_t *chip = cookie; | ||
| 1155 | |||
| 1156 | if (chip->image[CS4231_IFACE_CTRL] & CS4231_RECORD_ENABLE) { | 1153 | if (chip->image[CS4231_IFACE_CTRL] & CS4231_RECORD_ENABLE) { |
| 1157 | snd_pcm_period_elapsed(chip->capture_substream); | 1154 | snd_pcm_period_elapsed(chip->capture_substream); |
| 1158 | snd_cs4231_advance_dma(&chip->c_dma, chip->capture_substream, | 1155 | snd_cs4231_advance_dma(&chip->c_dma, chip->capture_substream, |
| @@ -1160,10 +1157,10 @@ static void snd_cs4231_capture_callback(cs4231_t *cookie) | |||
| 1160 | } | 1157 | } |
| 1161 | } | 1158 | } |
| 1162 | 1159 | ||
| 1163 | static snd_pcm_uframes_t snd_cs4231_playback_pointer(snd_pcm_substream_t *substream) | 1160 | static snd_pcm_uframes_t snd_cs4231_playback_pointer(struct snd_pcm_substream *substream) |
| 1164 | { | 1161 | { |
| 1165 | cs4231_t *chip = snd_pcm_substream_chip(substream); | 1162 | struct snd_cs4231 *chip = snd_pcm_substream_chip(substream); |
| 1166 | cs4231_dma_control_t *dma_cont = &chip->p_dma; | 1163 | struct cs4231_dma_control *dma_cont = &chip->p_dma; |
| 1167 | size_t ptr; | 1164 | size_t ptr; |
| 1168 | 1165 | ||
| 1169 | if (!(chip->image[CS4231_IFACE_CTRL] & CS4231_PLAYBACK_ENABLE)) | 1166 | if (!(chip->image[CS4231_IFACE_CTRL] & CS4231_PLAYBACK_ENABLE)) |
| @@ -1175,10 +1172,10 @@ static snd_pcm_uframes_t snd_cs4231_playback_pointer(snd_pcm_substream_t *substr | |||
| 1175 | return bytes_to_frames(substream->runtime, ptr); | 1172 | return bytes_to_frames(substream->runtime, ptr); |
| 1176 | } | 1173 | } |
| 1177 | 1174 | ||
| 1178 | static snd_pcm_uframes_t snd_cs4231_capture_pointer(snd_pcm_substream_t * substream) | 1175 | static snd_pcm_uframes_t snd_cs4231_capture_pointer(struct snd_pcm_substream *substream) |
| 1179 | { | 1176 | { |
| 1180 | cs4231_t *chip = snd_pcm_substream_chip(substream); | 1177 | struct snd_cs4231 *chip = snd_pcm_substream_chip(substream); |
| 1181 | cs4231_dma_control_t *dma_cont = &chip->c_dma; | 1178 | struct cs4231_dma_control *dma_cont = &chip->c_dma; |
| 1182 | size_t ptr; | 1179 | size_t ptr; |
| 1183 | 1180 | ||
| 1184 | if (!(chip->image[CS4231_IFACE_CTRL] & CS4231_RECORD_ENABLE)) | 1181 | if (!(chip->image[CS4231_IFACE_CTRL] & CS4231_RECORD_ENABLE)) |
| @@ -1194,7 +1191,7 @@ static snd_pcm_uframes_t snd_cs4231_capture_pointer(snd_pcm_substream_t * substr | |||
| 1194 | 1191 | ||
| 1195 | */ | 1192 | */ |
| 1196 | 1193 | ||
| 1197 | static int snd_cs4231_probe(cs4231_t *chip) | 1194 | static int __init snd_cs4231_probe(struct snd_cs4231 *chip) |
| 1198 | { | 1195 | { |
| 1199 | unsigned long flags; | 1196 | unsigned long flags; |
| 1200 | int i, id, vers; | 1197 | int i, id, vers; |
| @@ -1259,7 +1256,7 @@ static int snd_cs4231_probe(cs4231_t *chip) | |||
| 1259 | return 0; /* all things are ok.. */ | 1256 | return 0; /* all things are ok.. */ |
| 1260 | } | 1257 | } |
| 1261 | 1258 | ||
| 1262 | static snd_pcm_hardware_t snd_cs4231_playback = | 1259 | static struct snd_pcm_hardware snd_cs4231_playback = |
| 1263 | { | 1260 | { |
| 1264 | .info = (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED | | 1261 | .info = (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED | |
| 1265 | SNDRV_PCM_INFO_MMAP_VALID | SNDRV_PCM_INFO_SYNC_START), | 1262 | SNDRV_PCM_INFO_MMAP_VALID | SNDRV_PCM_INFO_SYNC_START), |
| @@ -1279,7 +1276,7 @@ static snd_pcm_hardware_t snd_cs4231_playback = | |||
| 1279 | .periods_max = 1024, | 1276 | .periods_max = 1024, |
| 1280 | }; | 1277 | }; |
| 1281 | 1278 | ||
| 1282 | static snd_pcm_hardware_t snd_cs4231_capture = | 1279 | static struct snd_pcm_hardware snd_cs4231_capture = |
| 1283 | { | 1280 | { |
| 1284 | .info = (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED | | 1281 | .info = (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED | |
| 1285 | SNDRV_PCM_INFO_MMAP_VALID | SNDRV_PCM_INFO_SYNC_START), | 1282 | SNDRV_PCM_INFO_MMAP_VALID | SNDRV_PCM_INFO_SYNC_START), |
| @@ -1299,10 +1296,10 @@ static snd_pcm_hardware_t snd_cs4231_capture = | |||
| 1299 | .periods_max = 1024, | 1296 | .periods_max = 1024, |
| 1300 | }; | 1297 | }; |
| 1301 | 1298 | ||
| 1302 | static int snd_cs4231_playback_open(snd_pcm_substream_t *substream) | 1299 | static int snd_cs4231_playback_open(struct snd_pcm_substream *substream) |
| 1303 | { | 1300 | { |
| 1304 | cs4231_t *chip = snd_pcm_substream_chip(substream); | 1301 | struct snd_cs4231 *chip = snd_pcm_substream_chip(substream); |
| 1305 | snd_pcm_runtime_t *runtime = substream->runtime; | 1302 | struct snd_pcm_runtime *runtime = substream->runtime; |
| 1306 | int err; | 1303 | int err; |
| 1307 | 1304 | ||
| 1308 | runtime->hw = snd_cs4231_playback; | 1305 | runtime->hw = snd_cs4231_playback; |
| @@ -1319,10 +1316,10 @@ static int snd_cs4231_playback_open(snd_pcm_substream_t *substream) | |||
| 1319 | return 0; | 1316 | return 0; |
| 1320 | } | 1317 | } |
| 1321 | 1318 | ||
| 1322 | static int snd_cs4231_capture_open(snd_pcm_substream_t *substream) | 1319 | static int snd_cs4231_capture_open(struct snd_pcm_substream *substream) |
| 1323 | { | 1320 | { |
| 1324 | cs4231_t *chip = snd_pcm_substream_chip(substream); | 1321 | struct snd_cs4231 *chip = snd_pcm_substream_chip(substream); |
| 1325 | snd_pcm_runtime_t *runtime = substream->runtime; | 1322 | struct snd_pcm_runtime *runtime = substream->runtime; |
| 1326 | int err; | 1323 | int err; |
| 1327 | 1324 | ||
| 1328 | runtime->hw = snd_cs4231_capture; | 1325 | runtime->hw = snd_cs4231_capture; |
| @@ -1339,9 +1336,9 @@ static int snd_cs4231_capture_open(snd_pcm_substream_t *substream) | |||
| 1339 | return 0; | 1336 | return 0; |
| 1340 | } | 1337 | } |
| 1341 | 1338 | ||
| 1342 | static int snd_cs4231_playback_close(snd_pcm_substream_t *substream) | 1339 | static int snd_cs4231_playback_close(struct snd_pcm_substream *substream) |
| 1343 | { | 1340 | { |
| 1344 | cs4231_t *chip = snd_pcm_substream_chip(substream); | 1341 | struct snd_cs4231 *chip = snd_pcm_substream_chip(substream); |
| 1345 | 1342 | ||
| 1346 | snd_cs4231_close(chip, CS4231_MODE_PLAY); | 1343 | snd_cs4231_close(chip, CS4231_MODE_PLAY); |
| 1347 | chip->playback_substream = NULL; | 1344 | chip->playback_substream = NULL; |
| @@ -1349,9 +1346,9 @@ static int snd_cs4231_playback_close(snd_pcm_substream_t *substream) | |||
| 1349 | return 0; | 1346 | return 0; |
| 1350 | } | 1347 | } |
| 1351 | 1348 | ||
| 1352 | static int snd_cs4231_capture_close(snd_pcm_substream_t *substream) | 1349 | static int snd_cs4231_capture_close(struct snd_pcm_substream *substream) |
| 1353 | { | 1350 | { |
| 1354 | cs4231_t *chip = snd_pcm_substream_chip(substream); | 1351 | struct snd_cs4231 *chip = snd_pcm_substream_chip(substream); |
| 1355 | 1352 | ||
| 1356 | snd_cs4231_close(chip, CS4231_MODE_RECORD); | 1353 | snd_cs4231_close(chip, CS4231_MODE_RECORD); |
| 1357 | chip->capture_substream = NULL; | 1354 | chip->capture_substream = NULL; |
| @@ -1363,7 +1360,7 @@ static int snd_cs4231_capture_close(snd_pcm_substream_t *substream) | |||
| 1363 | * XXX the audio AUXIO register... | 1360 | * XXX the audio AUXIO register... |
| 1364 | */ | 1361 | */ |
| 1365 | 1362 | ||
| 1366 | static snd_pcm_ops_t snd_cs4231_playback_ops = { | 1363 | static struct snd_pcm_ops snd_cs4231_playback_ops = { |
| 1367 | .open = snd_cs4231_playback_open, | 1364 | .open = snd_cs4231_playback_open, |
| 1368 | .close = snd_cs4231_playback_close, | 1365 | .close = snd_cs4231_playback_close, |
| 1369 | .ioctl = snd_pcm_lib_ioctl, | 1366 | .ioctl = snd_pcm_lib_ioctl, |
| @@ -1374,7 +1371,7 @@ static snd_pcm_ops_t snd_cs4231_playback_ops = { | |||
| 1374 | .pointer = snd_cs4231_playback_pointer, | 1371 | .pointer = snd_cs4231_playback_pointer, |
| 1375 | }; | 1372 | }; |
| 1376 | 1373 | ||
| 1377 | static snd_pcm_ops_t snd_cs4231_capture_ops = { | 1374 | static struct snd_pcm_ops snd_cs4231_capture_ops = { |
| 1378 | .open = snd_cs4231_capture_open, | 1375 | .open = snd_cs4231_capture_open, |
| 1379 | .close = snd_cs4231_capture_close, | 1376 | .close = snd_cs4231_capture_close, |
| 1380 | .ioctl = snd_pcm_lib_ioctl, | 1377 | .ioctl = snd_pcm_lib_ioctl, |
| @@ -1385,9 +1382,9 @@ static snd_pcm_ops_t snd_cs4231_capture_ops = { | |||
| 1385 | .pointer = snd_cs4231_capture_pointer, | 1382 | .pointer = snd_cs4231_capture_pointer, |
| 1386 | }; | 1383 | }; |
| 1387 | 1384 | ||
| 1388 | int snd_cs4231_pcm(cs4231_t *chip) | 1385 | static int __init snd_cs4231_pcm(struct snd_cs4231 *chip) |
| 1389 | { | 1386 | { |
| 1390 | snd_pcm_t *pcm; | 1387 | struct snd_pcm *pcm; |
| 1391 | int err; | 1388 | int err; |
| 1392 | 1389 | ||
| 1393 | if ((err = snd_pcm_new(chip->card, "CS4231", 0, 1, 1, &pcm)) < 0) | 1390 | if ((err = snd_pcm_new(chip->card, "CS4231", 0, 1, 1, &pcm)) < 0) |
| @@ -1408,16 +1405,10 @@ int snd_cs4231_pcm(cs4231_t *chip) | |||
| 1408 | return 0; | 1405 | return 0; |
| 1409 | } | 1406 | } |
| 1410 | 1407 | ||
| 1411 | static void snd_cs4231_timer_free(snd_timer_t *timer) | 1408 | static int __init snd_cs4231_timer(struct snd_cs4231 *chip) |
| 1412 | { | 1409 | { |
| 1413 | cs4231_t *chip = timer->private_data; | 1410 | struct snd_timer *timer; |
| 1414 | chip->timer = NULL; | 1411 | struct snd_timer_id tid; |
| 1415 | } | ||
| 1416 | |||
| 1417 | int snd_cs4231_timer(cs4231_t *chip) | ||
| 1418 | { | ||
| 1419 | snd_timer_t *timer; | ||
| 1420 | snd_timer_id_t tid; | ||
| 1421 | int err; | 1412 | int err; |
| 1422 | 1413 | ||
| 1423 | /* Timer initialization */ | 1414 | /* Timer initialization */ |
| @@ -1430,7 +1421,6 @@ int snd_cs4231_timer(cs4231_t *chip) | |||
| 1430 | return err; | 1421 | return err; |
| 1431 | strcpy(timer->name, "CS4231"); | 1422 | strcpy(timer->name, "CS4231"); |
| 1432 | timer->private_data = chip; | 1423 | timer->private_data = chip; |
| 1433 | timer->private_free = snd_cs4231_timer_free; | ||
| 1434 | timer->hw = snd_cs4231_timer_table; | 1424 | timer->hw = snd_cs4231_timer_table; |
| 1435 | chip->timer = timer; | 1425 | chip->timer = timer; |
| 1436 | 1426 | ||
| @@ -1441,12 +1431,13 @@ int snd_cs4231_timer(cs4231_t *chip) | |||
| 1441 | * MIXER part | 1431 | * MIXER part |
| 1442 | */ | 1432 | */ |
| 1443 | 1433 | ||
| 1444 | static int snd_cs4231_info_mux(snd_kcontrol_t *kcontrol, snd_ctl_elem_info_t *uinfo) | 1434 | static int snd_cs4231_info_mux(struct snd_kcontrol *kcontrol, |
| 1435 | struct snd_ctl_elem_info *uinfo) | ||
| 1445 | { | 1436 | { |
| 1446 | static char *texts[4] = { | 1437 | static char *texts[4] = { |
| 1447 | "Line", "CD", "Mic", "Mix" | 1438 | "Line", "CD", "Mic", "Mix" |
| 1448 | }; | 1439 | }; |
| 1449 | cs4231_t *chip = snd_kcontrol_chip(kcontrol); | 1440 | struct snd_cs4231 *chip = snd_kcontrol_chip(kcontrol); |
| 1450 | 1441 | ||
| 1451 | snd_assert(chip->card != NULL, return -EINVAL); | 1442 | snd_assert(chip->card != NULL, return -EINVAL); |
| 1452 | uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED; | 1443 | uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED; |
| @@ -1459,9 +1450,10 @@ static int snd_cs4231_info_mux(snd_kcontrol_t *kcontrol, snd_ctl_elem_info_t *ui | |||
| 1459 | return 0; | 1450 | return 0; |
| 1460 | } | 1451 | } |
| 1461 | 1452 | ||
| 1462 | static int snd_cs4231_get_mux(snd_kcontrol_t *kcontrol, snd_ctl_elem_value_t *ucontrol) | 1453 | static int snd_cs4231_get_mux(struct snd_kcontrol *kcontrol, |
| 1454 | struct snd_ctl_elem_value *ucontrol) | ||
| 1463 | { | 1455 | { |
| 1464 | cs4231_t *chip = snd_kcontrol_chip(kcontrol); | 1456 | struct snd_cs4231 *chip = snd_kcontrol_chip(kcontrol); |
| 1465 | unsigned long flags; | 1457 | unsigned long flags; |
| 1466 | 1458 | ||
| 1467 | spin_lock_irqsave(&chip->lock, flags); | 1459 | spin_lock_irqsave(&chip->lock, flags); |
| @@ -1474,9 +1466,10 @@ static int snd_cs4231_get_mux(snd_kcontrol_t *kcontrol, snd_ctl_elem_value_t *uc | |||
| 1474 | return 0; | 1466 | return 0; |
| 1475 | } | 1467 | } |
| 1476 | 1468 | ||
| 1477 | static int snd_cs4231_put_mux(snd_kcontrol_t *kcontrol, snd_ctl_elem_value_t *ucontrol) | 1469 | static int snd_cs4231_put_mux(struct snd_kcontrol *kcontrol, |
| 1470 | struct snd_ctl_elem_value *ucontrol) | ||
| 1478 | { | 1471 | { |
| 1479 | cs4231_t *chip = snd_kcontrol_chip(kcontrol); | 1472 | struct snd_cs4231 *chip = snd_kcontrol_chip(kcontrol); |
| 1480 | unsigned long flags; | 1473 | unsigned long flags; |
| 1481 | unsigned short left, right; | 1474 | unsigned short left, right; |
| 1482 | int change; | 1475 | int change; |
| @@ -1501,7 +1494,8 @@ static int snd_cs4231_put_mux(snd_kcontrol_t *kcontrol, snd_ctl_elem_value_t *uc | |||
| 1501 | return change; | 1494 | return change; |
| 1502 | } | 1495 | } |
| 1503 | 1496 | ||
| 1504 | int snd_cs4231_info_single(snd_kcontrol_t *kcontrol, snd_ctl_elem_info_t *uinfo) | 1497 | static int snd_cs4231_info_single(struct snd_kcontrol *kcontrol, |
| 1498 | struct snd_ctl_elem_info *uinfo) | ||
| 1505 | { | 1499 | { |
| 1506 | int mask = (kcontrol->private_value >> 16) & 0xff; | 1500 | int mask = (kcontrol->private_value >> 16) & 0xff; |
| 1507 | 1501 | ||
| @@ -1514,9 +1508,10 @@ int snd_cs4231_info_single(snd_kcontrol_t *kcontrol, snd_ctl_elem_info_t *uinfo) | |||
| 1514 | return 0; | 1508 | return 0; |
| 1515 | } | 1509 | } |
| 1516 | 1510 | ||
| 1517 | int snd_cs4231_get_single(snd_kcontrol_t *kcontrol, snd_ctl_elem_value_t *ucontrol) | 1511 | static int snd_cs4231_get_single(struct snd_kcontrol *kcontrol, |
| 1512 | struct snd_ctl_elem_value *ucontrol) | ||
| 1518 | { | 1513 | { |
| 1519 | cs4231_t *chip = snd_kcontrol_chip(kcontrol); | 1514 | struct snd_cs4231 *chip = snd_kcontrol_chip(kcontrol); |
| 1520 | unsigned long flags; | 1515 | unsigned long flags; |
| 1521 | int reg = kcontrol->private_value & 0xff; | 1516 | int reg = kcontrol->private_value & 0xff; |
| 1522 | int shift = (kcontrol->private_value >> 8) & 0xff; | 1517 | int shift = (kcontrol->private_value >> 8) & 0xff; |
| @@ -1536,9 +1531,10 @@ int snd_cs4231_get_single(snd_kcontrol_t *kcontrol, snd_ctl_elem_value_t *ucontr | |||
| 1536 | return 0; | 1531 | return 0; |
| 1537 | } | 1532 | } |
| 1538 | 1533 | ||
| 1539 | int snd_cs4231_put_single(snd_kcontrol_t *kcontrol, snd_ctl_elem_value_t *ucontrol) | 1534 | static int snd_cs4231_put_single(struct snd_kcontrol *kcontrol, |
| 1535 | struct snd_ctl_elem_value *ucontrol) | ||
| 1540 | { | 1536 | { |
| 1541 | cs4231_t *chip = snd_kcontrol_chip(kcontrol); | 1537 | struct snd_cs4231 *chip = snd_kcontrol_chip(kcontrol); |
| 1542 | unsigned long flags; | 1538 | unsigned long flags; |
| 1543 | int reg = kcontrol->private_value & 0xff; | 1539 | int reg = kcontrol->private_value & 0xff; |
| 1544 | int shift = (kcontrol->private_value >> 8) & 0xff; | 1540 | int shift = (kcontrol->private_value >> 8) & 0xff; |
| @@ -1563,7 +1559,8 @@ int snd_cs4231_put_single(snd_kcontrol_t *kcontrol, snd_ctl_elem_value_t *ucontr | |||
| 1563 | return change; | 1559 | return change; |
| 1564 | } | 1560 | } |
| 1565 | 1561 | ||
| 1566 | int snd_cs4231_info_double(snd_kcontrol_t *kcontrol, snd_ctl_elem_info_t *uinfo) | 1562 | static int snd_cs4231_info_double(struct snd_kcontrol *kcontrol, |
| 1563 | struct snd_ctl_elem_info *uinfo) | ||
| 1567 | { | 1564 | { |
| 1568 | int mask = (kcontrol->private_value >> 24) & 0xff; | 1565 | int mask = (kcontrol->private_value >> 24) & 0xff; |
| 1569 | 1566 | ||
| @@ -1576,9 +1573,10 @@ int snd_cs4231_info_double(snd_kcontrol_t *kcontrol, snd_ctl_elem_info_t *uinfo) | |||
| 1576 | return 0; | 1573 | return 0; |
| 1577 | } | 1574 | } |
| 1578 | 1575 | ||
| 1579 | int snd_cs4231_get_double(snd_kcontrol_t *kcontrol, snd_ctl_elem_value_t *ucontrol) | 1576 | static int snd_cs4231_get_double(struct snd_kcontrol *kcontrol, |
| 1577 | struct snd_ctl_elem_value *ucontrol) | ||
| 1580 | { | 1578 | { |
| 1581 | cs4231_t *chip = snd_kcontrol_chip(kcontrol); | 1579 | struct snd_cs4231 *chip = snd_kcontrol_chip(kcontrol); |
| 1582 | unsigned long flags; | 1580 | unsigned long flags; |
| 1583 | int left_reg = kcontrol->private_value & 0xff; | 1581 | int left_reg = kcontrol->private_value & 0xff; |
| 1584 | int right_reg = (kcontrol->private_value >> 8) & 0xff; | 1582 | int right_reg = (kcontrol->private_value >> 8) & 0xff; |
| @@ -1604,9 +1602,10 @@ int snd_cs4231_get_double(snd_kcontrol_t *kcontrol, snd_ctl_elem_value_t *ucontr | |||
| 1604 | return 0; | 1602 | return 0; |
| 1605 | } | 1603 | } |
| 1606 | 1604 | ||
| 1607 | int snd_cs4231_put_double(snd_kcontrol_t *kcontrol, snd_ctl_elem_value_t *ucontrol) | 1605 | static int snd_cs4231_put_double(struct snd_kcontrol *kcontrol, |
| 1606 | struct snd_ctl_elem_value *ucontrol) | ||
| 1608 | { | 1607 | { |
| 1609 | cs4231_t *chip = snd_kcontrol_chip(kcontrol); | 1608 | struct snd_cs4231 *chip = snd_kcontrol_chip(kcontrol); |
| 1610 | unsigned long flags; | 1609 | unsigned long flags; |
| 1611 | int left_reg = kcontrol->private_value & 0xff; | 1610 | int left_reg = kcontrol->private_value & 0xff; |
| 1612 | int right_reg = (kcontrol->private_value >> 8) & 0xff; | 1611 | int right_reg = (kcontrol->private_value >> 8) & 0xff; |
| @@ -1651,7 +1650,7 @@ int snd_cs4231_put_double(snd_kcontrol_t *kcontrol, snd_ctl_elem_value_t *ucontr | |||
| 1651 | .get = snd_cs4231_get_double, .put = snd_cs4231_put_double, \ | 1650 | .get = snd_cs4231_get_double, .put = snd_cs4231_put_double, \ |
| 1652 | .private_value = left_reg | (right_reg << 8) | (shift_left << 16) | (shift_right << 19) | (mask << 24) | (invert << 22) } | 1651 | .private_value = left_reg | (right_reg << 8) | (shift_left << 16) | (shift_right << 19) | (mask << 24) | (invert << 22) } |
| 1653 | 1652 | ||
| 1654 | static snd_kcontrol_new_t snd_cs4231_controls[] = { | 1653 | static struct snd_kcontrol_new snd_cs4231_controls[] __initdata = { |
| 1655 | CS4231_DOUBLE("PCM Playback Switch", 0, CS4231_LEFT_OUTPUT, CS4231_RIGHT_OUTPUT, 7, 7, 1, 1), | 1654 | CS4231_DOUBLE("PCM Playback Switch", 0, CS4231_LEFT_OUTPUT, CS4231_RIGHT_OUTPUT, 7, 7, 1, 1), |
| 1656 | CS4231_DOUBLE("PCM Playback Volume", 0, CS4231_LEFT_OUTPUT, CS4231_RIGHT_OUTPUT, 0, 0, 63, 1), | 1655 | CS4231_DOUBLE("PCM Playback Volume", 0, CS4231_LEFT_OUTPUT, CS4231_RIGHT_OUTPUT, 0, 0, 63, 1), |
| 1657 | CS4231_DOUBLE("Line Playback Switch", 0, CS4231_LEFT_LINE_IN, CS4231_RIGHT_LINE_IN, 7, 7, 1, 1), | 1656 | CS4231_DOUBLE("Line Playback Switch", 0, CS4231_LEFT_LINE_IN, CS4231_RIGHT_LINE_IN, 7, 7, 1, 1), |
| @@ -1680,9 +1679,9 @@ CS4231_SINGLE("Line Out Switch", 0, CS4231_PIN_CTRL, 6, 1, 1), | |||
| 1680 | CS4231_SINGLE("Headphone Out Switch", 0, CS4231_PIN_CTRL, 7, 1, 1) | 1679 | CS4231_SINGLE("Headphone Out Switch", 0, CS4231_PIN_CTRL, 7, 1, 1) |
| 1681 | }; | 1680 | }; |
| 1682 | 1681 | ||
| 1683 | int snd_cs4231_mixer(cs4231_t *chip) | 1682 | static int __init snd_cs4231_mixer(struct snd_cs4231 *chip) |
| 1684 | { | 1683 | { |
| 1685 | snd_card_t *card; | 1684 | struct snd_card *card; |
| 1686 | int err, idx; | 1685 | int err, idx; |
| 1687 | 1686 | ||
| 1688 | snd_assert(chip != NULL && chip->pcm != NULL, return -EINVAL); | 1687 | snd_assert(chip != NULL && chip->pcm != NULL, return -EINVAL); |
| @@ -1702,9 +1701,9 @@ int snd_cs4231_mixer(cs4231_t *chip) | |||
| 1702 | 1701 | ||
| 1703 | static int dev; | 1702 | static int dev; |
| 1704 | 1703 | ||
| 1705 | static int cs4231_attach_begin(snd_card_t **rcard) | 1704 | static int __init cs4231_attach_begin(struct snd_card **rcard) |
| 1706 | { | 1705 | { |
| 1707 | snd_card_t *card; | 1706 | struct snd_card *card; |
| 1708 | 1707 | ||
| 1709 | *rcard = NULL; | 1708 | *rcard = NULL; |
| 1710 | 1709 | ||
| @@ -1727,7 +1726,7 @@ static int cs4231_attach_begin(snd_card_t **rcard) | |||
| 1727 | return 0; | 1726 | return 0; |
| 1728 | } | 1727 | } |
| 1729 | 1728 | ||
| 1730 | static int cs4231_attach_finish(snd_card_t *card, cs4231_t *chip) | 1729 | static int __init cs4231_attach_finish(struct snd_card *card, struct snd_cs4231 *chip) |
| 1731 | { | 1730 | { |
| 1732 | int err; | 1731 | int err; |
| 1733 | 1732 | ||
| @@ -1761,7 +1760,7 @@ static irqreturn_t snd_cs4231_sbus_interrupt(int irq, void *dev_id, struct pt_re | |||
| 1761 | unsigned long flags; | 1760 | unsigned long flags; |
| 1762 | unsigned char status; | 1761 | unsigned char status; |
| 1763 | u32 csr; | 1762 | u32 csr; |
| 1764 | cs4231_t *chip = dev_id; | 1763 | struct snd_cs4231 *chip = dev_id; |
| 1765 | 1764 | ||
| 1766 | /*This is IRQ is not raised by the cs4231*/ | 1765 | /*This is IRQ is not raised by the cs4231*/ |
| 1767 | if (!(__cs4231_readb(chip, CS4231P(chip, STATUS)) & CS4231_GLOBALIRQ)) | 1766 | if (!(__cs4231_readb(chip, CS4231P(chip, STATUS)) & CS4231_GLOBALIRQ)) |
| @@ -1806,12 +1805,12 @@ static irqreturn_t snd_cs4231_sbus_interrupt(int irq, void *dev_id, struct pt_re | |||
| 1806 | * SBUS DMA routines | 1805 | * SBUS DMA routines |
| 1807 | */ | 1806 | */ |
| 1808 | 1807 | ||
| 1809 | int sbus_dma_request(struct cs4231_dma_control *dma_cont, dma_addr_t bus_addr, size_t len) | 1808 | static int sbus_dma_request(struct cs4231_dma_control *dma_cont, dma_addr_t bus_addr, size_t len) |
| 1810 | { | 1809 | { |
| 1811 | unsigned long flags; | 1810 | unsigned long flags; |
| 1812 | u32 test, csr; | 1811 | u32 test, csr; |
| 1813 | int err; | 1812 | int err; |
| 1814 | sbus_dma_info_t *base = &dma_cont->sbus_info; | 1813 | struct sbus_dma_info *base = &dma_cont->sbus_info; |
| 1815 | 1814 | ||
| 1816 | if (len >= (1 << 24)) | 1815 | if (len >= (1 << 24)) |
| 1817 | return -EINVAL; | 1816 | return -EINVAL; |
| @@ -1838,11 +1837,11 @@ out: | |||
| 1838 | return err; | 1837 | return err; |
| 1839 | } | 1838 | } |
| 1840 | 1839 | ||
| 1841 | void sbus_dma_prepare(struct cs4231_dma_control *dma_cont, int d) | 1840 | static void sbus_dma_prepare(struct cs4231_dma_control *dma_cont, int d) |
| 1842 | { | 1841 | { |
| 1843 | unsigned long flags; | 1842 | unsigned long flags; |
| 1844 | u32 csr, test; | 1843 | u32 csr, test; |
| 1845 | sbus_dma_info_t *base = &dma_cont->sbus_info; | 1844 | struct sbus_dma_info *base = &dma_cont->sbus_info; |
| 1846 | 1845 | ||
| 1847 | spin_lock_irqsave(&base->lock, flags); | 1846 | spin_lock_irqsave(&base->lock, flags); |
| 1848 | csr = sbus_readl(base->regs + APCCSR); | 1847 | csr = sbus_readl(base->regs + APCCSR); |
| @@ -1857,11 +1856,11 @@ void sbus_dma_prepare(struct cs4231_dma_control *dma_cont, int d) | |||
| 1857 | spin_unlock_irqrestore(&base->lock, flags); | 1856 | spin_unlock_irqrestore(&base->lock, flags); |
| 1858 | } | 1857 | } |
| 1859 | 1858 | ||
| 1860 | void sbus_dma_enable(struct cs4231_dma_control *dma_cont, int on) | 1859 | static void sbus_dma_enable(struct cs4231_dma_control *dma_cont, int on) |
| 1861 | { | 1860 | { |
| 1862 | unsigned long flags; | 1861 | unsigned long flags; |
| 1863 | u32 csr, shift; | 1862 | u32 csr, shift; |
| 1864 | sbus_dma_info_t *base = &dma_cont->sbus_info; | 1863 | struct sbus_dma_info *base = &dma_cont->sbus_info; |
| 1865 | 1864 | ||
| 1866 | spin_lock_irqsave(&base->lock, flags); | 1865 | spin_lock_irqsave(&base->lock, flags); |
| 1867 | if (!on) { | 1866 | if (!on) { |
| @@ -1894,14 +1893,14 @@ void sbus_dma_enable(struct cs4231_dma_control *dma_cont, int on) | |||
| 1894 | spin_unlock_irqrestore(&base->lock, flags); | 1893 | spin_unlock_irqrestore(&base->lock, flags); |
| 1895 | } | 1894 | } |
| 1896 | 1895 | ||
| 1897 | unsigned int sbus_dma_addr(struct cs4231_dma_control *dma_cont) | 1896 | static unsigned int sbus_dma_addr(struct cs4231_dma_control *dma_cont) |
| 1898 | { | 1897 | { |
| 1899 | sbus_dma_info_t *base = &dma_cont->sbus_info; | 1898 | struct sbus_dma_info *base = &dma_cont->sbus_info; |
| 1900 | 1899 | ||
| 1901 | return sbus_readl(base->regs + base->dir + APCVA); | 1900 | return sbus_readl(base->regs + base->dir + APCVA); |
| 1902 | } | 1901 | } |
| 1903 | 1902 | ||
| 1904 | void sbus_dma_reset(cs4231_t *chip) | 1903 | static void sbus_dma_reset(struct snd_cs4231 *chip) |
| 1905 | { | 1904 | { |
| 1906 | sbus_writel(APC_CHIP_RESET, chip->port + APCCSR); | 1905 | sbus_writel(APC_CHIP_RESET, chip->port + APCCSR); |
| 1907 | sbus_writel(0x00, chip->port + APCCSR); | 1906 | sbus_writel(0x00, chip->port + APCCSR); |
| @@ -1918,7 +1917,7 @@ void sbus_dma_reset(cs4231_t *chip) | |||
| 1918 | chip->port + APCCSR); | 1917 | chip->port + APCCSR); |
| 1919 | } | 1918 | } |
| 1920 | 1919 | ||
| 1921 | void sbus_dma_preallocate(cs4231_t *chip, snd_pcm_t *pcm) | 1920 | static void sbus_dma_preallocate(struct snd_cs4231 *chip, struct snd_pcm *pcm) |
| 1922 | { | 1921 | { |
| 1923 | snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_SBUS, | 1922 | snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_SBUS, |
| 1924 | snd_dma_sbus_data(chip->dev_u.sdev), | 1923 | snd_dma_sbus_data(chip->dev_u.sdev), |
| @@ -1929,7 +1928,7 @@ void sbus_dma_preallocate(cs4231_t *chip, snd_pcm_t *pcm) | |||
| 1929 | * Init and exit routines | 1928 | * Init and exit routines |
| 1930 | */ | 1929 | */ |
| 1931 | 1930 | ||
| 1932 | static int snd_cs4231_sbus_free(cs4231_t *chip) | 1931 | static int snd_cs4231_sbus_free(struct snd_cs4231 *chip) |
| 1933 | { | 1932 | { |
| 1934 | if (chip->irq[0]) | 1933 | if (chip->irq[0]) |
| 1935 | free_irq(chip->irq[0], chip); | 1934 | free_irq(chip->irq[0], chip); |
| @@ -1937,31 +1936,28 @@ static int snd_cs4231_sbus_free(cs4231_t *chip) | |||
| 1937 | if (chip->port) | 1936 | if (chip->port) |
| 1938 | sbus_iounmap(chip->port, chip->regs_size); | 1937 | sbus_iounmap(chip->port, chip->regs_size); |
| 1939 | 1938 | ||
| 1940 | if (chip->timer) | ||
| 1941 | snd_device_free(chip->card, chip->timer); | ||
| 1942 | |||
| 1943 | kfree(chip); | 1939 | kfree(chip); |
| 1944 | 1940 | ||
| 1945 | return 0; | 1941 | return 0; |
| 1946 | } | 1942 | } |
| 1947 | 1943 | ||
| 1948 | static int snd_cs4231_sbus_dev_free(snd_device_t *device) | 1944 | static int snd_cs4231_sbus_dev_free(struct snd_device *device) |
| 1949 | { | 1945 | { |
| 1950 | cs4231_t *cp = device->device_data; | 1946 | struct snd_cs4231 *cp = device->device_data; |
| 1951 | 1947 | ||
| 1952 | return snd_cs4231_sbus_free(cp); | 1948 | return snd_cs4231_sbus_free(cp); |
| 1953 | } | 1949 | } |
| 1954 | 1950 | ||
| 1955 | static snd_device_ops_t snd_cs4231_sbus_dev_ops = { | 1951 | static struct snd_device_ops snd_cs4231_sbus_dev_ops = { |
| 1956 | .dev_free = snd_cs4231_sbus_dev_free, | 1952 | .dev_free = snd_cs4231_sbus_dev_free, |
| 1957 | }; | 1953 | }; |
| 1958 | 1954 | ||
| 1959 | static int __init snd_cs4231_sbus_create(snd_card_t *card, | 1955 | static int __init snd_cs4231_sbus_create(struct snd_card *card, |
| 1960 | struct sbus_dev *sdev, | 1956 | struct sbus_dev *sdev, |
| 1961 | int dev, | 1957 | int dev, |
| 1962 | cs4231_t **rchip) | 1958 | struct snd_cs4231 **rchip) |
| 1963 | { | 1959 | { |
| 1964 | cs4231_t *chip; | 1960 | struct snd_cs4231 *chip; |
| 1965 | int err; | 1961 | int err; |
| 1966 | 1962 | ||
| 1967 | *rchip = NULL; | 1963 | *rchip = NULL; |
| @@ -2032,11 +2028,11 @@ static int __init snd_cs4231_sbus_create(snd_card_t *card, | |||
| 2032 | return 0; | 2028 | return 0; |
| 2033 | } | 2029 | } |
| 2034 | 2030 | ||
| 2035 | static int cs4231_sbus_attach(struct sbus_dev *sdev) | 2031 | static int __init cs4231_sbus_attach(struct sbus_dev *sdev) |
| 2036 | { | 2032 | { |
| 2037 | struct resource *rp = &sdev->resource[0]; | 2033 | struct resource *rp = &sdev->resource[0]; |
| 2038 | cs4231_t *cp; | 2034 | struct snd_cs4231 *cp; |
| 2039 | snd_card_t *card; | 2035 | struct snd_card *card; |
| 2040 | int err; | 2036 | int err; |
| 2041 | 2037 | ||
| 2042 | err = cs4231_attach_begin(&card); | 2038 | err = cs4231_attach_begin(&card); |
| @@ -2062,14 +2058,14 @@ static int cs4231_sbus_attach(struct sbus_dev *sdev) | |||
| 2062 | 2058 | ||
| 2063 | static void snd_cs4231_ebus_play_callback(struct ebus_dma_info *p, int event, void *cookie) | 2059 | static void snd_cs4231_ebus_play_callback(struct ebus_dma_info *p, int event, void *cookie) |
| 2064 | { | 2060 | { |
| 2065 | cs4231_t *chip = cookie; | 2061 | struct snd_cs4231 *chip = cookie; |
| 2066 | 2062 | ||
| 2067 | snd_cs4231_play_callback(chip); | 2063 | snd_cs4231_play_callback(chip); |
| 2068 | } | 2064 | } |
| 2069 | 2065 | ||
| 2070 | static void snd_cs4231_ebus_capture_callback(struct ebus_dma_info *p, int event, void *cookie) | 2066 | static void snd_cs4231_ebus_capture_callback(struct ebus_dma_info *p, int event, void *cookie) |
| 2071 | { | 2067 | { |
| 2072 | cs4231_t *chip = cookie; | 2068 | struct snd_cs4231 *chip = cookie; |
| 2073 | 2069 | ||
| 2074 | snd_cs4231_capture_callback(chip); | 2070 | snd_cs4231_capture_callback(chip); |
| 2075 | } | 2071 | } |
| @@ -2078,32 +2074,32 @@ static void snd_cs4231_ebus_capture_callback(struct ebus_dma_info *p, int event, | |||
| 2078 | * EBUS DMA wrappers | 2074 | * EBUS DMA wrappers |
| 2079 | */ | 2075 | */ |
| 2080 | 2076 | ||
| 2081 | int _ebus_dma_request(struct cs4231_dma_control *dma_cont, dma_addr_t bus_addr, size_t len) | 2077 | static int _ebus_dma_request(struct cs4231_dma_control *dma_cont, dma_addr_t bus_addr, size_t len) |
| 2082 | { | 2078 | { |
| 2083 | return ebus_dma_request(&dma_cont->ebus_info, bus_addr, len); | 2079 | return ebus_dma_request(&dma_cont->ebus_info, bus_addr, len); |
| 2084 | } | 2080 | } |
| 2085 | 2081 | ||
| 2086 | void _ebus_dma_enable(struct cs4231_dma_control *dma_cont, int on) | 2082 | static void _ebus_dma_enable(struct cs4231_dma_control *dma_cont, int on) |
| 2087 | { | 2083 | { |
| 2088 | ebus_dma_enable(&dma_cont->ebus_info, on); | 2084 | ebus_dma_enable(&dma_cont->ebus_info, on); |
| 2089 | } | 2085 | } |
| 2090 | 2086 | ||
| 2091 | void _ebus_dma_prepare(struct cs4231_dma_control *dma_cont, int dir) | 2087 | static void _ebus_dma_prepare(struct cs4231_dma_control *dma_cont, int dir) |
| 2092 | { | 2088 | { |
| 2093 | ebus_dma_prepare(&dma_cont->ebus_info, dir); | 2089 | ebus_dma_prepare(&dma_cont->ebus_info, dir); |
| 2094 | } | 2090 | } |
| 2095 | 2091 | ||
| 2096 | unsigned int _ebus_dma_addr(struct cs4231_dma_control *dma_cont) | 2092 | static unsigned int _ebus_dma_addr(struct cs4231_dma_control *dma_cont) |
| 2097 | { | 2093 | { |
| 2098 | return ebus_dma_addr(&dma_cont->ebus_info); | 2094 | return ebus_dma_addr(&dma_cont->ebus_info); |
| 2099 | } | 2095 | } |
| 2100 | 2096 | ||
| 2101 | void _ebus_dma_reset(cs4231_t *chip) | 2097 | static void _ebus_dma_reset(struct snd_cs4231 *chip) |
| 2102 | { | 2098 | { |
| 2103 | return; | 2099 | return; |
| 2104 | } | 2100 | } |
| 2105 | 2101 | ||
| 2106 | void _ebus_dma_preallocate(cs4231_t *chip, snd_pcm_t *pcm) | 2102 | static void _ebus_dma_preallocate(struct snd_cs4231 *chip, struct snd_pcm *pcm) |
| 2107 | { | 2103 | { |
| 2108 | snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV, | 2104 | snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV, |
| 2109 | snd_dma_pci_data(chip->dev_u.pdev), | 2105 | snd_dma_pci_data(chip->dev_u.pdev), |
| @@ -2114,7 +2110,7 @@ void _ebus_dma_preallocate(cs4231_t *chip, snd_pcm_t *pcm) | |||
| 2114 | * Init and exit routines | 2110 | * Init and exit routines |
| 2115 | */ | 2111 | */ |
| 2116 | 2112 | ||
| 2117 | static int snd_cs4231_ebus_free(cs4231_t *chip) | 2113 | static int snd_cs4231_ebus_free(struct snd_cs4231 *chip) |
| 2118 | { | 2114 | { |
| 2119 | if (chip->c_dma.ebus_info.regs) { | 2115 | if (chip->c_dma.ebus_info.regs) { |
| 2120 | ebus_dma_unregister(&chip->c_dma.ebus_info); | 2116 | ebus_dma_unregister(&chip->c_dma.ebus_info); |
| @@ -2127,31 +2123,29 @@ static int snd_cs4231_ebus_free(cs4231_t *chip) | |||
| 2127 | 2123 | ||
| 2128 | if (chip->port) | 2124 | if (chip->port) |
| 2129 | iounmap(chip->port); | 2125 | iounmap(chip->port); |
| 2130 | if (chip->timer) | ||
| 2131 | snd_device_free(chip->card, chip->timer); | ||
| 2132 | 2126 | ||
| 2133 | kfree(chip); | 2127 | kfree(chip); |
| 2134 | 2128 | ||
| 2135 | return 0; | 2129 | return 0; |
| 2136 | } | 2130 | } |
| 2137 | 2131 | ||
| 2138 | static int snd_cs4231_ebus_dev_free(snd_device_t *device) | 2132 | static int snd_cs4231_ebus_dev_free(struct snd_device *device) |
| 2139 | { | 2133 | { |
| 2140 | cs4231_t *cp = device->device_data; | 2134 | struct snd_cs4231 *cp = device->device_data; |
| 2141 | 2135 | ||
| 2142 | return snd_cs4231_ebus_free(cp); | 2136 | return snd_cs4231_ebus_free(cp); |
| 2143 | } | 2137 | } |
| 2144 | 2138 | ||
| 2145 | static snd_device_ops_t snd_cs4231_ebus_dev_ops = { | 2139 | static struct snd_device_ops snd_cs4231_ebus_dev_ops = { |
| 2146 | .dev_free = snd_cs4231_ebus_dev_free, | 2140 | .dev_free = snd_cs4231_ebus_dev_free, |
| 2147 | }; | 2141 | }; |
| 2148 | 2142 | ||
| 2149 | static int __init snd_cs4231_ebus_create(snd_card_t *card, | 2143 | static int __init snd_cs4231_ebus_create(struct snd_card *card, |
| 2150 | struct linux_ebus_device *edev, | 2144 | struct linux_ebus_device *edev, |
| 2151 | int dev, | 2145 | int dev, |
| 2152 | cs4231_t **rchip) | 2146 | struct snd_cs4231 **rchip) |
| 2153 | { | 2147 | { |
| 2154 | cs4231_t *chip; | 2148 | struct snd_cs4231 *chip; |
| 2155 | int err; | 2149 | int err; |
| 2156 | 2150 | ||
| 2157 | *rchip = NULL; | 2151 | *rchip = NULL; |
| @@ -2241,10 +2235,10 @@ static int __init snd_cs4231_ebus_create(snd_card_t *card, | |||
| 2241 | return 0; | 2235 | return 0; |
| 2242 | } | 2236 | } |
| 2243 | 2237 | ||
| 2244 | static int cs4231_ebus_attach(struct linux_ebus_device *edev) | 2238 | static int __init cs4231_ebus_attach(struct linux_ebus_device *edev) |
| 2245 | { | 2239 | { |
| 2246 | snd_card_t *card; | 2240 | struct snd_card *card; |
| 2247 | cs4231_t *chip; | 2241 | struct snd_cs4231 *chip; |
| 2248 | int err; | 2242 | int err; |
| 2249 | 2243 | ||
| 2250 | err = cs4231_attach_begin(&card); | 2244 | err = cs4231_attach_begin(&card); |
| @@ -2317,10 +2311,10 @@ static int __init cs4231_init(void) | |||
| 2317 | 2311 | ||
| 2318 | static void __exit cs4231_exit(void) | 2312 | static void __exit cs4231_exit(void) |
| 2319 | { | 2313 | { |
| 2320 | cs4231_t *p = cs4231_list; | 2314 | struct snd_cs4231 *p = cs4231_list; |
| 2321 | 2315 | ||
| 2322 | while (p != NULL) { | 2316 | while (p != NULL) { |
| 2323 | cs4231_t *next = p->next; | 2317 | struct snd_cs4231 *next = p->next; |
| 2324 | 2318 | ||
| 2325 | snd_card_free(p->card); | 2319 | snd_card_free(p->card); |
| 2326 | 2320 | ||
