On Mon, 2010-09-06 at 14:30 +0300, Johan Hedberg wrote: > Hi Bastien, > > On Mon, Sep 06, 2010, Bastien Nocera wrote: > > > Previously it was possible to --disable-hal and be sure that whatever is > > > defined in main.conf gets used (this is e.g. something that has been > > > important for us in Maemo/MeeGo). Your patch seems to make one of the > > > two automated adapter class sources always be used and so potentially > > > overriding what main.conf says. So I'd prefer to keep the possibility of > > > disably any such plugins completely. > > > > Take a look at the code, there's no ways to disable the HAL plugin right > > now. If you want a separate patch for that, I can certainly cook one up. > > Yep, my memory was playing tricks on me here. We're actually using > DisablePlugins=hal in main.conf to avoid interference from this code. > The same would also work for your new plugin so build-time disabling > isn't strictly necessary then (but might be nice to have for some > platforms). OK. Patch that actually applies to master attached. Was conflicting with another non-upstreamed patch. Cheers
>From 6921ff03adcaea6e10dd926b8c9e3b9ec8842334 Mon Sep 17 00:00:00 2001 From: Bastien Nocera <hadess@xxxxxxxxxx> Date: Mon, 6 Sep 2010 11:44:31 +0100 Subject: [PATCH] Add new plugin to set adapter class This time based on the kernel exported DMI, rather than calling out to HAL. The HAL plugin can still be preferred with --enable-hal=yes passed to configure. --- Makefile.am | 7 ++ acinclude.m4 | 7 ++- plugins/formfactor.c | 151 ++++++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 164 insertions(+), 1 deletions(-) create mode 100644 plugins/formfactor.c diff --git a/Makefile.am b/Makefile.am index 9043d25..9a78780 100644 --- a/Makefile.am +++ b/Makefile.am @@ -194,8 +194,15 @@ endif builtin_modules += hciops builtin_sources += plugins/hciops.c +if HAL builtin_modules += hal builtin_sources += plugins/hal.c +else +builtin_modules += formfactor +builtin_sources += plugins/formfactor.c +endif + +EXTRA_DIST += plugins/hal.c plugins/formfactor.c builtin_modules += storage builtin_sources += plugins/storage.c diff --git a/acinclude.m4 b/acinclude.m4 index dda965e..b34f08d 100644 --- a/acinclude.m4 +++ b/acinclude.m4 @@ -158,7 +158,7 @@ AC_DEFUN([AC_ARG_BLUEZ], [ fortify_enable=yes pie_enable=yes sndfile_enable=${sndfile_found} - hal_enable=${hal_found} + hal_enable=no usb_enable=${usb_found} alsa_enable=${alsa_found} gstreamer_enable=${gstreamer_found} @@ -308,6 +308,10 @@ AC_DEFUN([AC_ARG_BLUEZ], [ maemo6_enable=${enableval} ]) + AC_ARG_ENABLE(hal, AC_HELP_STRING([--enable-hal], [Use HAL to determine adapter class]), [ + hal_enable=${enableval} + ]) + if (test "${fortify_enable}" = "yes"); then CFLAGS="$CFLAGS -D_FORTIFY_SOURCE=2" fi @@ -341,6 +345,7 @@ AC_DEFUN([AC_ARG_BLUEZ], [ AM_CONDITIONAL(NETWORKPLUGIN, test "${network_enable}" = "yes") AM_CONDITIONAL(SERVICEPLUGIN, test "${service_enable}" = "yes") AM_CONDITIONAL(MCAP, test "${mcap_enable}" = "yes") + AM_CONDITIONAL(HAL, test "${hal_enable}" = "yes") AM_CONDITIONAL(ATTRIBPLUGIN, test "${attrib_enable}" = "yes") AM_CONDITIONAL(ECHOPLUGIN, test "no" = "yes") AM_CONDITIONAL(PNATPLUGIN, test "${pnat_enable}" = "yes") diff --git a/plugins/formfactor.c b/plugins/formfactor.c new file mode 100644 index 0000000..037a768 --- /dev/null +++ b/plugins/formfactor.c @@ -0,0 +1,151 @@ +/* + * + * BlueZ - Bluetooth protocol stack for Linux + * + * Copyright (C) 2004-2010 Marcel Holtmann <marcel@xxxxxxxxxxxx> + * + * + * 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., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + * + */ + +#ifdef HAVE_CONFIG_H +#include <config.h> +#endif + +#include <stdlib.h> +#include <errno.h> + +#include <bluetooth/bluetooth.h> +#include <bluetooth/hci.h> +#include <bluetooth/hci_lib.h> + +#include "plugin.h" +#include "adapter.h" +#include "log.h" +#include "dbus-hci.h" + +#define DMI_CHASSIS_FILE "/sys/class/dmi/id/chassis_type" +#define DMI_CHASSIS_FILE_FALLBACK "/sys/devices/virtual/dmi/id/chassis_type" + +/* Map the chassis type from chassis_type to a sensible type used in hal + * + * See also 3.3.4.1 of the "System Management BIOS Reference Specification, + * Version 2.6.1" (Preliminary Standard) document, available from + * http://www.dmtf.org/standards/smbios. + * + * TODO: figure out WTF the mapping should be; "Lunch Box"? Give me a break :-) + * + * Copied from hal/hald/linux/osspec.c + */ +static const char *chassis_map[] = { + "Other", "unknown", /* 0x01 */ + "Unknown", "unknown", + "Desktop", "desktop", + "Low Profile Desktop", "desktop", + "Pizza Box", "server", + "Mini Tower", "desktop", + "Tower", "desktop", + "Portable", "laptop", + "Laptop", "laptop", + "Notebook", "laptop", + "Hand Held", "handheld", + "Docking Station", "laptop", + "All In One", "unknown", + "Sub Notebook", "laptop", + "Space-saving", "desktop", + "Lunch Box", "unknown", + "Main Server Chassis", "server", + "Expansion Chassis", "unknown", + "Sub Chassis", "unknown", + "Bus Expansion Chassis", "unknown", + "Peripheral Chassis", "unknown", + "RAID Chassis", "unknown", + "Rack Mount Chassis", "unknown", + "Sealed-case PC", "unknown", + "Multi-system", "unknown", + "CompactPCI", "unknonw", + "AdvancedTCA", "unknown", + "Blade", "server", + "Blade Enclosure" "unknown", /* 0x1D */ + NULL +}; + +static int formfactor_probe(struct btd_adapter *adapter) +{ + int chassis_type; + uint8_t minor = 0; + const char *formfactor; + char *contents; + + if (g_file_get_contents(DMI_CHASSIS_FILE, + &contents, NULL, NULL) == FALSE) { + if (g_file_get_contents(DMI_CHASSIS_FILE_FALLBACK, + &contents, NULL, NULL) == FALSE) { + error("Could not get the contents of DMI chassis type"); + return 0; + } + } + + chassis_type = atoi(contents); + g_free (contents); + + if (chassis_type > 0x1D || chassis_type <= 0) { + error ("Chassis type is not a known chassis type"); + return 0; + } + + formfactor = chassis_map[chassis_type * 2]; + if (formfactor != NULL) { + if (g_str_equal(formfactor, "laptop") == TRUE) + minor |= (1 << 2) | (1 << 3); + else if (g_str_equal(formfactor, "desktop") == TRUE) + minor |= 1 << 2; + else if (g_str_equal(formfactor, "server") == TRUE) + minor |= 1 << 3; + else if (g_str_equal(formfactor, "handheld") == TRUE) + minor += 1 << 4; + } + + /* Computer major class */ + DBG("Setting 0x%06x for major/minor device class", (1 << 8) | minor); + + btd_adapter_set_class(adapter, 0x01, minor); + + return 0; +} + +static void formfactor_remove(struct btd_adapter *adapter) +{ +} + +static struct btd_adapter_driver formfactor_driver = { + .name = "formfactor", + .probe = formfactor_probe, + .remove = formfactor_remove, +}; + +static int formfactor_init(void) +{ + return btd_register_adapter_driver(&formfactor_driver); +} + +static void formfactor_exit(void) +{ + btd_unregister_adapter_driver(&formfactor_driver); +} + +BLUETOOTH_PLUGIN_DEFINE(formfactor, VERSION, + BLUETOOTH_PLUGIN_PRIORITY_LOW, formfactor_init, formfactor_exit) -- 1.7.0.1