obexd fix and autoenable bluetooth devices
- obexd fixes to prevent crashes - add /etc/bluetooth/main.conf config file - set 'AutoEnable=true' in /etc/bluetooth/main.conf file
This commit is contained in:
		
							parent
							
								
									5b00702ff0
								
							
						
					
					
						commit
						dd83a2e4d7
					
				
							
								
								
									
										32
									
								
								0001-obexd-Allow-CreateFolder-to-create-a-directory.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								0001-obexd-Allow-CreateFolder-to-create-a-directory.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,32 @@ | |||||||
|  | From 16102009366f25a7ba3531c235d65461b5012372 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Marek Kasik <mkasik@redhat.com> | ||||||
|  | Date: Thu, 30 Jun 2016 17:01:27 -0400 | ||||||
|  | Subject: [PATCH 1/2] obexd: Allow CreateFolder to create a directory | ||||||
|  | 
 | ||||||
|  | When the remote device sends the 'CreateFolder' command, obexd | ||||||
|  | first tries to verify the path in ftp_setpath().  Because we are | ||||||
|  | creating a new directory, the verify_path() is expected to fail (it does | ||||||
|  | not exist yet; ENOENT). | ||||||
|  | 
 | ||||||
|  | Trap that special case and cause the function to fail directly to the | ||||||
|  | create directory path. | ||||||
|  | ---
 | ||||||
|  |  obexd/plugins/ftp.c | 2 ++ | ||||||
|  |  1 file changed, 2 insertions(+) | ||||||
|  | 
 | ||||||
|  | diff --git a/obexd/plugins/ftp.c b/obexd/plugins/ftp.c
 | ||||||
|  | index a906527..3ee18a6 100644
 | ||||||
|  | --- a/obexd/plugins/ftp.c
 | ||||||
|  | +++ b/obexd/plugins/ftp.c
 | ||||||
|  | @@ -278,6 +278,8 @@ int ftp_setpath(struct obex_session *os, void *user_data)
 | ||||||
|  |  	DBG("Fullname: %s", fullname); | ||||||
|  |   | ||||||
|  |  	err = verify_path(fullname); | ||||||
|  | +	if (err == -ENOENT)
 | ||||||
|  | +		goto not_found;
 | ||||||
|  |   | ||||||
|  |  	if (err < 0) | ||||||
|  |  		goto done; | ||||||
|  | -- 
 | ||||||
|  | 1.8.3.1 | ||||||
|  | 
 | ||||||
| @ -0,0 +1,79 @@ | |||||||
|  | From 6c75f43e50d754b4605498a8a68d2be4bc19ee37 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Marek Kasik <mkasik@redhat.com> | ||||||
|  | Date: Thu, 30 Jun 2016 17:01:28 -0400 | ||||||
|  | Subject: [PATCH 2/2] obexd: Return dummy_data instead of int in | ||||||
|  |  phonebook-dummy | ||||||
|  | 
 | ||||||
|  | There are two functions in phonebook-dummy that were returning | ||||||
|  | 'int's instead of 'struct dummy_data' | ||||||
|  | 
 | ||||||
|  | phonebook_create_cache | ||||||
|  | phonebook_get_entry | ||||||
|  | 
 | ||||||
|  | As a result, when an obex-client sends the GetSize command, the obexd | ||||||
|  | on the server segfaults. | ||||||
|  | 
 | ||||||
|  | Fix this by storing the id and returning the dummy_data struct. | ||||||
|  | 
 | ||||||
|  | The GetSize test now passes correctly. | ||||||
|  | ---
 | ||||||
|  |  obexd/plugins/phonebook-dummy.c | 15 ++++++++------- | ||||||
|  |  1 file changed, 8 insertions(+), 7 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/obexd/plugins/phonebook-dummy.c b/obexd/plugins/phonebook-dummy.c
 | ||||||
|  | index eeb078f..29ae889 100644
 | ||||||
|  | --- a/obexd/plugins/phonebook-dummy.c
 | ||||||
|  | +++ b/obexd/plugins/phonebook-dummy.c
 | ||||||
|  | @@ -520,7 +520,6 @@ void *phonebook_get_entry(const char *folder, const char *id,
 | ||||||
|  |  	struct dummy_data *dummy; | ||||||
|  |  	char *filename; | ||||||
|  |  	int fd; | ||||||
|  | -	guint ret;
 | ||||||
|  |   | ||||||
|  |  	filename = g_build_filename(root_folder, folder, id, NULL); | ||||||
|  |   | ||||||
|  | @@ -538,13 +537,13 @@ void *phonebook_get_entry(const char *folder, const char *id,
 | ||||||
|  |  	dummy->apparams = params; | ||||||
|  |  	dummy->fd = fd; | ||||||
|  |   | ||||||
|  | -	ret = g_idle_add_full(G_PRIORITY_DEFAULT_IDLE, read_entry, dummy,
 | ||||||
|  | +	dummy->id = g_idle_add_full(G_PRIORITY_DEFAULT_IDLE, read_entry, dummy,
 | ||||||
|  |  								dummy_free); | ||||||
|  |   | ||||||
|  |  	if (err) | ||||||
|  |  		*err = 0; | ||||||
|  |   | ||||||
|  | -	return GINT_TO_POINTER(ret);
 | ||||||
|  | +	return dummy;
 | ||||||
|  |  } | ||||||
|  |   | ||||||
|  |  void *phonebook_create_cache(const char *name, phonebook_entry_cb entry_cb, | ||||||
|  | @@ -553,7 +552,7 @@ void *phonebook_create_cache(const char *name, phonebook_entry_cb entry_cb,
 | ||||||
|  |  	struct cache_query *query; | ||||||
|  |  	char *foldername; | ||||||
|  |  	DIR *dp; | ||||||
|  | -	guint ret;
 | ||||||
|  | +	struct dummy_data *dummy;
 | ||||||
|  |   | ||||||
|  |  	foldername = g_build_filename(root_folder, name, NULL); | ||||||
|  |  	dp = opendir(foldername); | ||||||
|  | @@ -572,11 +571,13 @@ void *phonebook_create_cache(const char *name, phonebook_entry_cb entry_cb,
 | ||||||
|  |  	query->user_data = user_data; | ||||||
|  |  	query->dp = dp; | ||||||
|  |   | ||||||
|  | -	ret = g_idle_add_full(G_PRIORITY_DEFAULT_IDLE, create_cache, query,
 | ||||||
|  | -								query_free);
 | ||||||
|  | +	dummy = g_new0(struct dummy_data, 1);
 | ||||||
|  | +
 | ||||||
|  | +	dummy->id = g_idle_add_full(G_PRIORITY_DEFAULT_IDLE, create_cache,
 | ||||||
|  | +							query, query_free);
 | ||||||
|  |   | ||||||
|  |  	if (err) | ||||||
|  |  		*err = 0; | ||||||
|  |   | ||||||
|  | -	return GINT_TO_POINTER(ret);
 | ||||||
|  | +	return dummy;
 | ||||||
|  |  } | ||||||
|  | -- 
 | ||||||
|  | 1.8.3.1 | ||||||
|  | 
 | ||||||
							
								
								
									
										14
									
								
								bluez.spec
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								bluez.spec
									
									
									
									
									
								
							| @ -3,7 +3,7 @@ | |||||||
| Name:    bluez | Name:    bluez | ||||||
| Summary: Bluetooth utilities | Summary: Bluetooth utilities | ||||||
| Version: 5.40 | Version: 5.40 | ||||||
| Release: 1%{?dist} | Release: 2%{?dist} | ||||||
| License: GPLv2+ | License: GPLv2+ | ||||||
| Group: Applications/System | Group: Applications/System | ||||||
| URL: http://www.bluez.org/ | URL: http://www.bluez.org/ | ||||||
| @ -18,6 +18,8 @@ Patch2: 0001-Allow-using-obexd-without-systemd-in-the-user-sessio.patch | |||||||
| Patch3: 0001-obex-Use-GLib-helper-function-to-manipulate-paths.patch | Patch3: 0001-obex-Use-GLib-helper-function-to-manipulate-paths.patch | ||||||
| Patch4: 0002-autopair-Don-t-handle-the-iCade.patch | Patch4: 0002-autopair-Don-t-handle-the-iCade.patch | ||||||
| Patch5: 0004-agent-Assert-possible-infinite-loop.patch | Patch5: 0004-agent-Assert-possible-infinite-loop.patch | ||||||
|  | Patch6: 0001-obexd-Allow-CreateFolder-to-create-a-directory.patch | ||||||
|  | Patch7: 0002-obexd-Return-dummy_data-instead-of-int-in-phonebook-.patch | ||||||
| 
 | 
 | ||||||
| BuildRequires: git | BuildRequires: git | ||||||
| BuildRequires: dbus-devel >= 1.6 | BuildRequires: dbus-devel >= 1.6 | ||||||
| @ -159,6 +161,10 @@ install -d -m0755 $RPM_BUILD_ROOT/%{_localstatedir}/lib/bluetooth | |||||||
| 
 | 
 | ||||||
| mkdir -p $RPM_BUILD_ROOT/%{_libdir}/bluetooth/ | mkdir -p $RPM_BUILD_ROOT/%{_libdir}/bluetooth/ | ||||||
| 
 | 
 | ||||||
|  | #copy bluetooth config file and setup auto enable | ||||||
|  | install -D -p -m0644 src/main.conf ${RPM_BUILD_ROOT}/etc/bluetooth/main.conf | ||||||
|  | sed -i 's/#\[Policy\]$/\[Policy\]/; s/#AutoEnable=false/AutoEnable=true/' ${RPM_BUILD_ROOT}/%{_sysconfdir}/bluetooth/main.conf | ||||||
|  | 
 | ||||||
| %post libs -p /sbin/ldconfig | %post libs -p /sbin/ldconfig | ||||||
| 
 | 
 | ||||||
| %postun libs -p /sbin/ldconfig | %postun libs -p /sbin/ldconfig | ||||||
| @ -214,6 +220,7 @@ mkdir -p $RPM_BUILD_ROOT/%{_libdir}/bluetooth/ | |||||||
| %{_localstatedir}/lib/bluetooth | %{_localstatedir}/lib/bluetooth | ||||||
| %{_datadir}/dbus-1/system-services/org.bluez.service | %{_datadir}/dbus-1/system-services/org.bluez.service | ||||||
| %{_unitdir}/bluetooth.service | %{_unitdir}/bluetooth.service | ||||||
|  | %config %{_sysconfdir}/bluetooth/main.conf | ||||||
| 
 | 
 | ||||||
| %files libs | %files libs | ||||||
| %{!?_licensedir:%global license %%doc} | %{!?_licensedir:%global license %%doc} | ||||||
| @ -240,6 +247,11 @@ mkdir -p $RPM_BUILD_ROOT/%{_libdir}/bluetooth/ | |||||||
| %{_userunitdir}/obex.service | %{_userunitdir}/obex.service | ||||||
| 
 | 
 | ||||||
| %changelog | %changelog | ||||||
|  | * Thu Jul 7 2016 Don Zickus <dzickus@redhat.com> 5.40-2 | ||||||
|  | - obexd fixes to prevent crashes | ||||||
|  | - add /etc/bluetooth/main.conf config file | ||||||
|  | - set 'AutoEnable=true' in /etc/bluetooth/main.conf file | ||||||
|  | 
 | ||||||
| * Tue May 31 2016 Peter Robinson <pbrobinson@fedoraproject.org> 5.40-1 | * Tue May 31 2016 Peter Robinson <pbrobinson@fedoraproject.org> 5.40-1 | ||||||
| - Update to 5.40 bugfix relesae | - Update to 5.40 bugfix relesae | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user