Add a local logging function to emit bluetooth specific messages. Using vsprintf extension %pV saves code/text space. Convert the current BT_INFO and BT_ERR macros to use bt_printk. Remove __func__ from BT_ERR macro (and the uses). Prefix "Bluetooth: " to BT_ERR Remove __func__ from BT_DBG as function can be prefixed when using dynamic_debug. With allyesconfig: text data bss dec hex filename 129956 8632 36096 174684 2aa5c drivers/bluetooth/built-in.o.new2 134402 8632 36064 179098 2bb9a drivers/bluetooth/built-in.o.old 14778 1012 3408 19198 4afe net/bluetooth/bnep/built-in.o.new2 15067 1012 3408 19487 4c1f net/bluetooth/bnep/built-in.o.old 346595 19163 86080 451838 6e4fe net/bluetooth/built-in.o.new2 353751 19163 86064 458978 700e2 net/bluetooth/built-in.o.old 18483 1172 4264 23919 5d6f net/bluetooth/cmtp/built-in.o.new2 18927 1172 4264 24363 5f2b net/bluetooth/cmtp/built-in.o.old 19237 1172 5152 25561 63d9 net/bluetooth/hidp/built-in.o.new2 19581 1172 5152 25905 6531 net/bluetooth/hidp/built-in.o.old 59461 3884 14464 77809 12ff1 net/bluetooth/rfcomm/built-in.o.new2 61206 3884 14464 79554 136c2 net/bluetooth/rfcomm/built-in.o.old with x86 defconfig (and just bluetooth): $ size net/bluetooth/built-in.o.defconfig.* text data bss dec hex filename 66358 933 100 67391 1073f net/bluetooth/built-in.o.defconfig.new 66643 933 100 67676 1085c net/bluetooth/built-in.o.defconfig.old Signed-off-by: Joe Perches <joe@perches.com> Signed-off-by: Gustavo F. Padovan <padovan@profusion.mobi>
		
			
				
	
	
		
			171 lines
		
	
	
	
		
			3 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			171 lines
		
	
	
	
		
			3 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
   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
 | 
						|
   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
 | 
						|
   OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
 | 
						|
 | 
						|
   ALL LIABILITY, INCLUDING LIABILITY FOR INFRINGEMENT OF ANY PATENTS,
 | 
						|
   COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS, RELATING TO USE OF THIS
 | 
						|
   SOFTWARE IS DISCLAIMED.
 | 
						|
*/
 | 
						|
 | 
						|
/* Bluetooth kernel library. */
 | 
						|
 | 
						|
#include <linux/module.h>
 | 
						|
 | 
						|
#include <linux/kernel.h>
 | 
						|
#include <linux/stddef.h>
 | 
						|
#include <linux/string.h>
 | 
						|
#include <asm/errno.h>
 | 
						|
 | 
						|
#include <net/bluetooth/bluetooth.h>
 | 
						|
 | 
						|
void baswap(bdaddr_t *dst, bdaddr_t *src)
 | 
						|
{
 | 
						|
	unsigned char *d = (unsigned char *) dst;
 | 
						|
	unsigned char *s = (unsigned char *) src;
 | 
						|
	unsigned int i;
 | 
						|
 | 
						|
	for (i = 0; i < 6; i++)
 | 
						|
		d[i] = s[5 - i];
 | 
						|
}
 | 
						|
EXPORT_SYMBOL(baswap);
 | 
						|
 | 
						|
char *batostr(bdaddr_t *ba)
 | 
						|
{
 | 
						|
	static char str[2][18];
 | 
						|
	static int i = 1;
 | 
						|
 | 
						|
	i ^= 1;
 | 
						|
	sprintf(str[i], "%2.2X:%2.2X:%2.2X:%2.2X:%2.2X:%2.2X",
 | 
						|
		ba->b[5], ba->b[4], ba->b[3],
 | 
						|
		ba->b[2], ba->b[1], ba->b[0]);
 | 
						|
 | 
						|
	return str[i];
 | 
						|
}
 | 
						|
EXPORT_SYMBOL(batostr);
 | 
						|
 | 
						|
/* Bluetooth error codes to Unix errno mapping */
 | 
						|
int bt_to_errno(__u16 code)
 | 
						|
{
 | 
						|
	switch (code) {
 | 
						|
	case 0:
 | 
						|
		return 0;
 | 
						|
 | 
						|
	case 0x01:
 | 
						|
		return EBADRQC;
 | 
						|
 | 
						|
	case 0x02:
 | 
						|
		return ENOTCONN;
 | 
						|
 | 
						|
	case 0x03:
 | 
						|
		return EIO;
 | 
						|
 | 
						|
	case 0x04:
 | 
						|
		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;
 | 
						|
	}
 | 
						|
}
 | 
						|
EXPORT_SYMBOL(bt_to_errno);
 | 
						|
 | 
						|
int bt_printk(const char *level, const char *format, ...)
 | 
						|
{
 | 
						|
	struct va_format vaf;
 | 
						|
	va_list args;
 | 
						|
	int r;
 | 
						|
 | 
						|
	va_start(args, format);
 | 
						|
 | 
						|
	vaf.fmt = format;
 | 
						|
	vaf.va = &args;
 | 
						|
 | 
						|
	r = printk("%sBluetooth: %pV\n", level, &vaf);
 | 
						|
 | 
						|
	va_end(args);
 | 
						|
 | 
						|
	return r;
 | 
						|
}
 | 
						|
EXPORT_SYMBOL(bt_printk);
 |