2008-09-17 19:34:06 +04:00
/*
* UWB PAL support .
*
* Copyright ( C ) 2008 Cambridge Silicon Radio Ltd .
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public License version
* 2 as published by the Free Software Foundation .
*
* 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 , see < http : //www.gnu.org/licenses/>.
*/
# include <linux/kernel.h>
2008-11-26 16:36:59 +03:00
# include <linux/debugfs.h>
2008-09-17 19:34:06 +04:00
# include <linux/uwb.h>
2011-07-10 21:18:02 +04:00
# include <linux/export.h>
2008-09-17 19:34:06 +04:00
# include "uwb-internal.h"
/**
* uwb_pal_init - initialize a UWB PAL
* @ pal : the PAL to initialize
*/
void uwb_pal_init ( struct uwb_pal * pal )
{
INIT_LIST_HEAD ( & pal - > node ) ;
}
EXPORT_SYMBOL_GPL ( uwb_pal_init ) ;
/**
* uwb_pal_register - register a UWB PAL
* @ pal : the PAL
*
* The PAL must be initialized with uwb_pal_init ( ) .
*/
2008-11-17 18:53:42 +03:00
int uwb_pal_register ( struct uwb_pal * pal )
2008-09-17 19:34:06 +04:00
{
2008-11-17 18:53:42 +03:00
struct uwb_rc * rc = pal - > rc ;
2008-09-17 19:34:40 +04:00
int ret ;
if ( pal - > device ) {
2013-06-24 23:26:35 +04:00
/* create a link to the uwb_rc in the PAL device's directory. */
2008-09-17 19:34:40 +04:00
ret = sysfs_create_link ( & pal - > device - > kobj ,
& rc - > uwb_dev . dev . kobj , " uwb_rc " ) ;
if ( ret < 0 )
return ret ;
2013-06-24 23:26:35 +04:00
/* create a link to the PAL in the UWB device's directory. */
2008-09-17 19:34:40 +04:00
ret = sysfs_create_link ( & rc - > uwb_dev . dev . kobj ,
& pal - > device - > kobj , pal - > name ) ;
if ( ret < 0 ) {
sysfs_remove_link ( & pal - > device - > kobj , " uwb_rc " ) ;
return ret ;
}
}
2008-11-26 16:36:59 +03:00
pal - > debugfs_dir = uwb_dbg_create_pal_dir ( pal ) ;
2008-11-17 18:53:42 +03:00
mutex_lock ( & rc - > uwb_dev . mutex ) ;
2008-09-17 19:34:06 +04:00
list_add ( & pal - > node , & rc - > pals ) ;
2008-11-17 18:53:42 +03:00
mutex_unlock ( & rc - > uwb_dev . mutex ) ;
2008-09-17 19:34:06 +04:00
return 0 ;
}
EXPORT_SYMBOL_GPL ( uwb_pal_register ) ;
2013-08-08 18:38:23 +04:00
static int find_rc ( struct device * dev , const void * data )
{
const struct uwb_rc * target_rc = data ;
struct uwb_rc * rc = dev_get_drvdata ( dev ) ;
if ( rc = = NULL ) {
WARN_ON ( 1 ) ;
return 0 ;
}
if ( rc = = target_rc ) {
if ( rc - > ready = = 0 )
return 0 ;
else
return 1 ;
}
return 0 ;
}
/**
* Given a radio controller descriptor see if it is registered .
*
* @ returns false if the rc does not exist or is quiescing ; true otherwise .
*/
static bool uwb_rc_class_device_exists ( struct uwb_rc * target_rc )
{
struct device * dev ;
dev = class_find_device ( & uwb_rc_class , NULL , target_rc , find_rc ) ;
2016-11-01 14:13:31 +03:00
put_device ( dev ) ;
2013-08-08 18:38:23 +04:00
return ( dev ! = NULL ) ;
}
2008-09-17 19:34:06 +04:00
/**
2013-08-08 18:38:23 +04:00
* uwb_pal_unregister - unregister a UWB PAL
2008-09-17 19:34:06 +04:00
* @ pal : the PAL
*/
2008-11-17 18:53:42 +03:00
void uwb_pal_unregister ( struct uwb_pal * pal )
2008-09-17 19:34:06 +04:00
{
2008-11-17 18:53:42 +03:00
struct uwb_rc * rc = pal - > rc ;
uwb_radio_stop ( pal ) ;
mutex_lock ( & rc - > uwb_dev . mutex ) ;
2008-09-17 19:34:06 +04:00
list_del ( & pal - > node ) ;
2008-11-17 18:53:42 +03:00
mutex_unlock ( & rc - > uwb_dev . mutex ) ;
2008-09-17 19:34:40 +04:00
2008-11-26 16:36:59 +03:00
debugfs_remove ( pal - > debugfs_dir ) ;
2008-09-17 19:34:40 +04:00
if ( pal - > device ) {
2013-08-08 18:38:23 +04:00
/* remove link to the PAL in the UWB device's directory. */
if ( uwb_rc_class_device_exists ( rc ) )
sysfs_remove_link ( & rc - > uwb_dev . dev . kobj , pal - > name ) ;
/* remove link to uwb_rc in the PAL device's directory. */
2008-09-17 19:34:40 +04:00
sysfs_remove_link ( & pal - > device - > kobj , " uwb_rc " ) ;
}
2008-09-17 19:34:06 +04:00
}
EXPORT_SYMBOL_GPL ( uwb_pal_unregister ) ;
/**
* uwb_rc_pal_init - initialize the PAL related parts of a radio controller
* @ rc : the radio controller
*/
void uwb_rc_pal_init ( struct uwb_rc * rc )
{
INIT_LIST_HEAD ( & rc - > pals ) ;
}