2005-04-16 15:20:36 -07:00
/*
* Driver for PowerMac AWACS
* Copyright ( c ) 2001 by Takashi Iwai < tiwai @ suse . de >
* based on dmasound . c .
*
* 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 ; either version 2 of the License , or
* ( at your option ) any later version .
*
* 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 . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
*/
# include <linux/init.h>
2005-11-17 17:17:08 +01:00
# include <linux/err.h>
# include <linux/platform_device.h>
2011-07-15 13:13:37 -04:00
# include <linux/module.h>
2005-04-16 15:20:36 -07:00
# include <sound/core.h>
# include <sound/initval.h>
# include "pmac.h"
# include "awacs.h"
# include "burgundy.h"
# define CHIP_NAME "PMac"
MODULE_DESCRIPTION ( " PowerMac " ) ;
MODULE_SUPPORTED_DEVICE ( " {{Apple,PowerMac}} " ) ;
MODULE_LICENSE ( " GPL " ) ;
static int index = SNDRV_DEFAULT_IDX1 ; /* Index 0-MAX */
static char * id = SNDRV_DEFAULT_STR1 ; /* ID for this card */
2011-12-15 13:49:36 +10:30
static bool enable_beep = 1 ;
2005-04-16 15:20:36 -07:00
module_param ( index , int , 0444 ) ;
MODULE_PARM_DESC ( index , " Index value for " CHIP_NAME " soundchip. " ) ;
module_param ( id , charp , 0444 ) ;
MODULE_PARM_DESC ( id , " ID string for " CHIP_NAME " soundchip. " ) ;
module_param ( enable_beep , bool , 0444 ) ;
MODULE_PARM_DESC ( enable_beep , " Enable beep using PCM. " ) ;
2005-12-07 09:13:42 +01:00
static struct platform_device * device ;
2005-04-16 15:20:36 -07:00
/*
*/
2009-03-28 00:27:10 +01:00
static int __devinit snd_pmac_probe ( struct platform_device * devptr )
2005-04-16 15:20:36 -07:00
{
2005-11-17 15:09:46 +01:00
struct snd_card * card ;
struct snd_pmac * chip ;
2005-04-16 15:20:36 -07:00
char * name_ext ;
int err ;
2008-12-28 16:45:02 +01:00
err = snd_card_create ( index , id , THIS_MODULE , 0 , & card ) ;
if ( err < 0 )
return err ;
2005-04-16 15:20:36 -07:00
if ( ( err = snd_pmac_new ( card , & chip ) ) < 0 )
goto __error ;
2005-11-17 17:17:08 +01:00
card - > private_data = chip ;
2005-04-16 15:20:36 -07:00
switch ( chip - > model ) {
case PMAC_BURGUNDY :
strcpy ( card - > driver , " PMac Burgundy " ) ;
strcpy ( card - > shortname , " PowerMac Burgundy " ) ;
sprintf ( card - > longname , " %s (Dev %d) Sub-frame %d " ,
card - > shortname , chip - > device_id , chip - > subframe ) ;
if ( ( err = snd_pmac_burgundy_init ( chip ) ) < 0 )
goto __error ;
break ;
case PMAC_DACA :
strcpy ( card - > driver , " PMac DACA " ) ;
strcpy ( card - > shortname , " PowerMac DACA " ) ;
sprintf ( card - > longname , " %s (Dev %d) Sub-frame %d " ,
card - > shortname , chip - > device_id , chip - > subframe ) ;
if ( ( err = snd_pmac_daca_init ( chip ) ) < 0 )
goto __error ;
break ;
case PMAC_TUMBLER :
case PMAC_SNAPPER :
name_ext = chip - > model = = PMAC_TUMBLER ? " Tumbler " : " Snapper " ;
sprintf ( card - > driver , " PMac %s " , name_ext ) ;
sprintf ( card - > shortname , " PowerMac %s " , name_ext ) ;
sprintf ( card - > longname , " %s (Dev %d) Sub-frame %d " ,
card - > shortname , chip - > device_id , chip - > subframe ) ;
if ( snd_pmac_tumbler_init ( chip ) < 0 | | snd_pmac_tumbler_post_init ( ) < 0 )
goto __error ;
break ;
case PMAC_AWACS :
case PMAC_SCREAMER :
name_ext = chip - > model = = PMAC_SCREAMER ? " Screamer " : " AWACS " ;
sprintf ( card - > driver , " PMac %s " , name_ext ) ;
sprintf ( card - > shortname , " PowerMac %s " , name_ext ) ;
if ( chip - > is_pbook_3400 )
name_ext = " [PB3400] " ;
else if ( chip - > is_pbook_G3 )
name_ext = " [PBG3] " ;
else
name_ext = " " ;
sprintf ( card - > longname , " %s%s Rev %d " ,
card - > shortname , name_ext , chip - > revision ) ;
if ( ( err = snd_pmac_awacs_init ( chip ) ) < 0 )
goto __error ;
break ;
default :
2009-02-05 16:02:46 +01:00
snd_printk ( KERN_ERR " unsupported hardware %d \n " , chip - > model ) ;
2005-04-16 15:20:36 -07:00
err = - EINVAL ;
goto __error ;
}
if ( ( err = snd_pmac_pcm_new ( chip ) ) < 0 )
goto __error ;
chip - > initialized = 1 ;
if ( enable_beep )
snd_pmac_attach_beep ( chip ) ;
2005-11-17 17:17:08 +01:00
snd_card_set_dev ( card , & devptr - > dev ) ;
2005-09-05 17:17:58 +02:00
2005-04-16 15:20:36 -07:00
if ( ( err = snd_card_register ( card ) ) < 0 )
goto __error ;
2005-11-17 17:17:08 +01:00
platform_set_drvdata ( devptr , card ) ;
2005-04-16 15:20:36 -07:00
return 0 ;
__error :
snd_card_free ( card ) ;
return err ;
}
2005-11-17 17:17:08 +01:00
static int __devexit snd_pmac_remove ( struct platform_device * devptr )
{
snd_card_free ( platform_get_drvdata ( devptr ) ) ;
platform_set_drvdata ( devptr , NULL ) ;
return 0 ;
}
2012-08-09 15:47:15 +02:00
# ifdef CONFIG_PM_SLEEP
2012-07-02 11:22:40 +02:00
static int snd_pmac_driver_suspend ( struct device * dev )
2005-11-17 17:17:08 +01:00
{
2012-07-02 11:22:40 +02:00
struct snd_card * card = dev_get_drvdata ( dev ) ;
2005-11-17 17:17:08 +01:00
snd_pmac_suspend ( card - > private_data ) ;
return 0 ;
}
2012-07-02 11:22:40 +02:00
static int snd_pmac_driver_resume ( struct device * dev )
2005-11-17 17:17:08 +01:00
{
2012-07-02 11:22:40 +02:00
struct snd_card * card = dev_get_drvdata ( dev ) ;
2005-11-17 17:17:08 +01:00
snd_pmac_resume ( card - > private_data ) ;
return 0 ;
}
2012-07-02 11:22:40 +02:00
static SIMPLE_DEV_PM_OPS ( snd_pmac_pm , snd_pmac_driver_suspend , snd_pmac_driver_resume ) ;
# define SND_PMAC_PM_OPS &snd_pmac_pm
# else
# define SND_PMAC_PM_OPS NULL
2005-11-17 17:17:08 +01:00
# endif
# define SND_PMAC_DRIVER "snd_powermac"
static struct platform_driver snd_pmac_driver = {
. probe = snd_pmac_probe ,
. remove = __devexit_p ( snd_pmac_remove ) ,
. driver = {
2012-07-02 10:50:24 +02:00
. name = SND_PMAC_DRIVER ,
. owner = THIS_MODULE ,
2012-07-02 11:22:40 +02:00
. pm = SND_PMAC_PM_OPS ,
2005-11-17 17:17:08 +01:00
} ,
} ;
2005-04-16 15:20:36 -07:00
static int __init alsa_card_pmac_init ( void )
{
int err ;
2005-11-17 17:17:08 +01:00
if ( ( err = platform_driver_register ( & snd_pmac_driver ) ) < 0 )
2005-04-16 15:20:36 -07:00
return err ;
2005-11-17 17:17:08 +01:00
device = platform_device_register_simple ( SND_PMAC_DRIVER , - 1 , NULL , 0 ) ;
2006-07-25 16:14:16 +02:00
return 0 ;
2005-04-16 15:20:36 -07:00
}
static void __exit alsa_card_pmac_exit ( void )
{
2006-07-25 16:14:16 +02:00
if ( ! IS_ERR ( device ) )
platform_device_unregister ( device ) ;
2005-11-17 17:17:08 +01:00
platform_driver_unregister ( & snd_pmac_driver ) ;
2005-04-16 15:20:36 -07:00
}
module_init ( alsa_card_pmac_init )
module_exit ( alsa_card_pmac_exit )