Hi Charles, On Fri, Jun 30, 2017 at 8:55 PM, Charles Shapiro <shapiroc@xxxxxxxxxx> wrote: > (Removing HTML formatting on email thread so it doesn't get blocked). > > For ChromeOS, we're working towards having a single build/image based > on a reference board that then supports multiple models created by > OEMs. > > Some of the bluetooth config differs on a per model basis, so we need > to have multiple *.conf files ship on the actual image. > > We then modify the init script to check the model at runtime and pass > the appropriate *.conf file to bluetoothd when it is started. > > On Fri, Jun 30, 2017 at 11:42 AM, Marcel Holtmann <marcel@xxxxxxxxxxxx> wrote: >> Hi Shapiro, >> >>> Currently, there is an expectation of the main.conf file at a specific >>> location. This prevents system builds that support more than one >>> platform. >>> >>> This adds support so the main.conf file can be specified as a command >>> line arg instead, so systems can manage multiple conf files as necessary >>> and pass the appropriate conf file when the daemon is started. >>> >>> Signed-off-by: C Shapiro <shapiroc@xxxxxxxxxxxx> >>> --- >>> src/bluetoothd.8.in | 4 ++++ >>> src/main.c | 12 +++++++++++- >>> 2 files changed, 15 insertions(+), 1 deletion(-) >>> >>> diff --git a/src/bluetoothd.8.in b/src/bluetoothd.8.in >>> index 97ef3ec94..d61dcc5b3 100644 >>> --- a/src/bluetoothd.8.in >>> +++ b/src/bluetoothd.8.in >>> @@ -27,6 +27,10 @@ Print bluetoothd options and exit. >>> Enable logging in foreground. Directs log output to the controlling terminal \ >>> in addition to syslog. >>> .TP >>> +.B -f, --configfile >>> +Specifies an explicit config file path instead of relying on the default path \ >>> +(@CONFIGDIR@/main.conf) for the config file. >>> +.TP >>> .B -d, --debug=<file1>:<file2>:... >>> Sets how much information bluetoothd sends to the log destination (usually \ >>> syslog's "daemon" facility). If the file options are omitted, then debugging \ >>> diff --git a/src/main.c b/src/main.c >>> index bcc1e6fae..87bdb66cb 100644 >>> --- a/src/main.c >>> +++ b/src/main.c >>> @@ -490,6 +490,7 @@ static guint setup_signalfd(void) >>> static char *option_debug = NULL; >>> static char *option_plugin = NULL; >>> static char *option_noplugin = NULL; >>> +static char *option_configfile = NULL; >>> static gboolean option_compat = FALSE; >>> static gboolean option_detach = TRUE; >>> static gboolean option_version = FALSE; >>> @@ -505,6 +506,9 @@ static void free_options(void) >>> >>> g_free(option_noplugin); >>> option_noplugin = NULL; >>> + >>> + g_free(option_configfile); >>> + option_configfile = NULL; >>> } >>> >>> static void disconnect_dbus(void) >>> @@ -577,6 +581,9 @@ static GOptionEntry options[] = { >>> "Specify plugins to load", "NAME,..," }, >>> { "noplugin", 'P', 0, G_OPTION_ARG_STRING, &option_noplugin, >>> "Specify plugins not to load", "NAME,..." }, >>> + { "configfile", 'f', 0, G_OPTION_ARG_STRING, &option_configfile, >>> + "Specify an explicit path to the config file", >>> + "FILE”}, >> >> I am failing to understand why this is needed. What problem are you trying to solve here? Can you give an example. >> Btw, can't you link the main.conf with the board specific config? Still it would be good to know what is that needs changing, is this related to ControllerMode? -- Luiz Augusto von Dentz -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html