2007-02-09 14:24:33 +00:00
|
|
|
/*
|
2005-04-16 22:20:36 +00:00
|
|
|
BlueZ - Bluetooth protocol stack for Linux
|
|
|
|
Copyright (C) 2000-2001 Qualcomm Incorporated
|
|
|
|
|
|
|
|
Written 2000,2001 by Maxim Krasnyansky <maxk@qualcomm.com>
|
|
|
|
|
|
|
|
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;
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
|
|
|
OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS.
|
|
|
|
IN NO EVENT SHALL THE COPYRIGHT HOLDER(S) AND AUTHOR(S) BE LIABLE FOR ANY
|
2007-02-09 14:24:33 +00:00
|
|
|
CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES
|
|
|
|
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
|
|
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
2005-04-16 22:20:36 +00:00
|
|
|
OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
|
|
|
2007-02-09 14:24:33 +00:00
|
|
|
ALL LIABILITY, INCLUDING LIABILITY FOR INFRINGEMENT OF ANY PATENTS,
|
|
|
|
COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS, RELATING TO USE OF THIS
|
2005-04-16 22:20:36 +00:00
|
|
|
SOFTWARE IS DISCLAIMED.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Bluetooth kernel library. */
|
|
|
|
|
2012-02-17 07:32:42 +00:00
|
|
|
#define pr_fmt(fmt) "Bluetooth: " fmt
|
|
|
|
|
2012-05-23 07:04:22 +00:00
|
|
|
#include <linux/export.h>
|
2005-04-16 22:20:36 +00:00
|
|
|
|
|
|
|
#include <net/bluetooth/bluetooth.h>
|
|
|
|
|
2017-09-01 20:41:17 +00:00
|
|
|
void baswap(bdaddr_t *dst, const bdaddr_t *src)
|
2005-04-16 22:20:36 +00:00
|
|
|
{
|
2017-09-01 20:41:17 +00:00
|
|
|
const unsigned char *s = (const unsigned char *)src;
|
|
|
|
unsigned char *d = (unsigned char *)dst;
|
2005-04-16 22:20:36 +00:00
|
|
|
unsigned int i;
|
|
|
|
|
|
|
|
for (i = 0; i < 6; i++)
|
|
|
|
d[i] = s[5 - i];
|
|
|
|
}
|
|
|
|
EXPORT_SYMBOL(baswap);
|
|
|
|
|
|
|
|
/* Bluetooth error codes to Unix errno mapping */
|
2011-06-30 01:18:29 +00:00
|
|
|
int bt_to_errno(__u16 code)
|
2005-04-16 22:20:36 +00:00
|
|
|
{
|
|
|
|
switch (code) {
|
|
|
|
case 0:
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
case 0x01:
|
|
|
|
return EBADRQC;
|
|
|
|
|
|
|
|
case 0x02:
|
|
|
|
return ENOTCONN;
|
|
|
|
|
|
|
|
case 0x03:
|
|
|
|
return EIO;
|
|
|
|
|
|
|
|
case 0x04:
|
2014-03-24 18:21:52 +00:00
|
|
|
case 0x3c:
|
2005-04-16 22:20:36 +00:00
|
|
|
return EHOSTDOWN;
|
|
|
|
|
|
|
|
case 0x05:
|
|
|
|
return EACCES;
|
|
|
|
|
|
|
|
case 0x06:
|
|
|
|
return EBADE;
|
|
|
|
|
|
|
|
case 0x07:
|
|
|
|
return ENOMEM;
|
|
|
|
|
|
|
|
case 0x08:
|
|
|
|
return ETIMEDOUT;
|
|
|
|
|
|
|
|
case 0x09:
|
|
|
|
return EMLINK;
|
|
|
|
|
|
|
|
case 0x0a:
|
|
|
|
return EMLINK;
|
|
|
|
|
|
|
|
case 0x0b:
|
|
|
|
return EALREADY;
|
|
|
|
|
|
|
|
case 0x0c:
|
|
|
|
return EBUSY;
|
|
|
|
|
|
|
|
case 0x0d:
|
|
|
|
case 0x0e:
|
|
|
|
case 0x0f:
|
|
|
|
return ECONNREFUSED;
|
|
|
|
|
|
|
|
case 0x10:
|
|
|
|
return ETIMEDOUT;
|
|
|
|
|
|
|
|
case 0x11:
|
|
|
|
case 0x27:
|
|
|
|
case 0x29:
|
|
|
|
case 0x20:
|
|
|
|
return EOPNOTSUPP;
|
|
|
|
|
|
|
|
case 0x12:
|
|
|
|
return EINVAL;
|
|
|
|
|
|
|
|
case 0x13:
|
|
|
|
case 0x14:
|
|
|
|
case 0x15:
|
|
|
|
return ECONNRESET;
|
|
|
|
|
|
|
|
case 0x16:
|
|
|
|
return ECONNABORTED;
|
|
|
|
|
|
|
|
case 0x17:
|
|
|
|
return ELOOP;
|
|
|
|
|
|
|
|
case 0x18:
|
|
|
|
return EACCES;
|
|
|
|
|
|
|
|
case 0x1a:
|
|
|
|
return EPROTONOSUPPORT;
|
|
|
|
|
|
|
|
case 0x1b:
|
|
|
|
return ECONNREFUSED;
|
|
|
|
|
|
|
|
case 0x19:
|
|
|
|
case 0x1e:
|
|
|
|
case 0x23:
|
|
|
|
case 0x24:
|
|
|
|
case 0x25:
|
|
|
|
return EPROTO;
|
|
|
|
|
|
|
|
default:
|
|
|
|
return ENOSYS;
|
|
|
|
}
|
|
|
|
}
|
2011-06-30 01:18:29 +00:00
|
|
|
EXPORT_SYMBOL(bt_to_errno);
|
2011-06-30 22:15:37 +00:00
|
|
|
|
2022-04-08 22:07:44 +00:00
|
|
|
/* Unix errno to Bluetooth error codes mapping */
|
|
|
|
__u8 bt_status(int err)
|
|
|
|
{
|
|
|
|
/* Don't convert if already positive value */
|
|
|
|
if (err >= 0)
|
|
|
|
return err;
|
|
|
|
|
|
|
|
switch (err) {
|
|
|
|
case -EBADRQC:
|
|
|
|
return 0x01;
|
|
|
|
|
|
|
|
case -ENOTCONN:
|
|
|
|
return 0x02;
|
|
|
|
|
|
|
|
case -EIO:
|
|
|
|
return 0x03;
|
|
|
|
|
|
|
|
case -EHOSTDOWN:
|
|
|
|
return 0x04;
|
|
|
|
|
|
|
|
case -EACCES:
|
|
|
|
return 0x05;
|
|
|
|
|
|
|
|
case -EBADE:
|
|
|
|
return 0x06;
|
|
|
|
|
|
|
|
case -ENOMEM:
|
|
|
|
return 0x07;
|
|
|
|
|
|
|
|
case -ETIMEDOUT:
|
|
|
|
return 0x08;
|
|
|
|
|
|
|
|
case -EMLINK:
|
|
|
|
return 0x09;
|
|
|
|
|
2022-10-30 07:00:03 +00:00
|
|
|
case -EALREADY:
|
2022-04-08 22:07:44 +00:00
|
|
|
return 0x0b;
|
|
|
|
|
|
|
|
case -EBUSY:
|
|
|
|
return 0x0c;
|
|
|
|
|
|
|
|
case -ECONNREFUSED:
|
|
|
|
return 0x0d;
|
|
|
|
|
|
|
|
case -EOPNOTSUPP:
|
|
|
|
return 0x11;
|
|
|
|
|
|
|
|
case -EINVAL:
|
|
|
|
return 0x12;
|
|
|
|
|
|
|
|
case -ECONNRESET:
|
|
|
|
return 0x13;
|
|
|
|
|
|
|
|
case -ECONNABORTED:
|
|
|
|
return 0x16;
|
|
|
|
|
2022-10-30 07:00:03 +00:00
|
|
|
case -ELOOP:
|
2022-04-08 22:07:44 +00:00
|
|
|
return 0x17;
|
|
|
|
|
|
|
|
case -EPROTONOSUPPORT:
|
|
|
|
return 0x1a;
|
|
|
|
|
|
|
|
case -EPROTO:
|
|
|
|
return 0x19;
|
|
|
|
|
|
|
|
default:
|
|
|
|
return 0x1f;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
EXPORT_SYMBOL(bt_status);
|
|
|
|
|
2014-09-22 18:17:41 +00:00
|
|
|
void bt_info(const char *format, ...)
|
2012-02-17 07:32:42 +00:00
|
|
|
{
|
|
|
|
struct va_format vaf;
|
|
|
|
va_list args;
|
|
|
|
|
|
|
|
va_start(args, format);
|
|
|
|
|
|
|
|
vaf.fmt = format;
|
|
|
|
vaf.va = &args;
|
|
|
|
|
2014-09-22 18:17:41 +00:00
|
|
|
pr_info("%pV", &vaf);
|
2012-02-17 07:32:42 +00:00
|
|
|
|
|
|
|
va_end(args);
|
|
|
|
}
|
|
|
|
EXPORT_SYMBOL(bt_info);
|
|
|
|
|
2015-09-23 16:18:07 +00:00
|
|
|
void bt_warn(const char *format, ...)
|
|
|
|
{
|
|
|
|
struct va_format vaf;
|
|
|
|
va_list args;
|
|
|
|
|
|
|
|
va_start(args, format);
|
|
|
|
|
|
|
|
vaf.fmt = format;
|
|
|
|
vaf.va = &args;
|
|
|
|
|
|
|
|
pr_warn("%pV", &vaf);
|
|
|
|
|
|
|
|
va_end(args);
|
|
|
|
}
|
|
|
|
EXPORT_SYMBOL(bt_warn);
|
|
|
|
|
2014-09-22 18:17:41 +00:00
|
|
|
void bt_err(const char *format, ...)
|
2011-06-30 22:15:37 +00:00
|
|
|
{
|
|
|
|
struct va_format vaf;
|
|
|
|
va_list args;
|
|
|
|
|
|
|
|
va_start(args, format);
|
|
|
|
|
|
|
|
vaf.fmt = format;
|
|
|
|
vaf.va = &args;
|
|
|
|
|
2014-09-22 18:17:41 +00:00
|
|
|
pr_err("%pV", &vaf);
|
2011-06-30 22:15:37 +00:00
|
|
|
|
|
|
|
va_end(args);
|
|
|
|
}
|
2012-02-17 07:32:42 +00:00
|
|
|
EXPORT_SYMBOL(bt_err);
|
2015-09-16 18:21:53 +00:00
|
|
|
|
2020-05-06 07:57:52 +00:00
|
|
|
#ifdef CONFIG_BT_FEATURE_DEBUG
|
|
|
|
static bool debug_enable;
|
|
|
|
|
|
|
|
void bt_dbg_set(bool enable)
|
|
|
|
{
|
|
|
|
debug_enable = enable;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool bt_dbg_get(void)
|
|
|
|
{
|
|
|
|
return debug_enable;
|
|
|
|
}
|
|
|
|
|
|
|
|
void bt_dbg(const char *format, ...)
|
|
|
|
{
|
|
|
|
struct va_format vaf;
|
|
|
|
va_list args;
|
|
|
|
|
|
|
|
if (likely(!debug_enable))
|
|
|
|
return;
|
|
|
|
|
|
|
|
va_start(args, format);
|
|
|
|
|
|
|
|
vaf.fmt = format;
|
|
|
|
vaf.va = &args;
|
|
|
|
|
|
|
|
printk(KERN_DEBUG pr_fmt("%pV"), &vaf);
|
|
|
|
|
|
|
|
va_end(args);
|
|
|
|
}
|
|
|
|
EXPORT_SYMBOL(bt_dbg);
|
|
|
|
#endif
|
|
|
|
|
2019-12-11 01:54:43 +00:00
|
|
|
void bt_warn_ratelimited(const char *format, ...)
|
|
|
|
{
|
|
|
|
struct va_format vaf;
|
|
|
|
va_list args;
|
|
|
|
|
|
|
|
va_start(args, format);
|
|
|
|
|
|
|
|
vaf.fmt = format;
|
|
|
|
vaf.va = &args;
|
|
|
|
|
|
|
|
pr_warn_ratelimited("%pV", &vaf);
|
|
|
|
|
|
|
|
va_end(args);
|
|
|
|
}
|
|
|
|
EXPORT_SYMBOL(bt_warn_ratelimited);
|
|
|
|
|
2015-09-16 18:21:53 +00:00
|
|
|
void bt_err_ratelimited(const char *format, ...)
|
|
|
|
{
|
|
|
|
struct va_format vaf;
|
|
|
|
va_list args;
|
|
|
|
|
|
|
|
va_start(args, format);
|
|
|
|
|
|
|
|
vaf.fmt = format;
|
|
|
|
vaf.va = &args;
|
|
|
|
|
|
|
|
pr_err_ratelimited("%pV", &vaf);
|
|
|
|
|
|
|
|
va_end(args);
|
|
|
|
}
|
|
|
|
EXPORT_SYMBOL(bt_err_ratelimited);
|