Add patch to ignore wakeup device uevents
See https://bugzilla.redhat.com/show_bug.cgi?id=1790398 for more information.
This commit is contained in:
		
							parent
							
								
									693df2c87f
								
							
						
					
					
						commit
						7d206b2b80
					
				
							
								
								
									
										27
									
								
								bolt-error-typedef.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								bolt-error-typedef.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,27 @@ | ||||
| From 5a739574608e5190816b3efd22e75f214c5fe4c4 Mon Sep 17 00:00:00 2001 | ||||
| From: Christian Kellner <christian@kellner.me> | ||||
| Date: Thu, 23 Jan 2020 19:07:05 +0100 | ||||
| Subject: [PATCH] common: fix BoltError to be a typedef | ||||
| 
 | ||||
| It was always meant to be a typedef not a (tentative) definition | ||||
| of a global variable. | ||||
| ---
 | ||||
|  common/bolt-error.h | 2 +- | ||||
|  1 file changed, 1 insertion(+), 1 deletion(-) | ||||
| 
 | ||||
| diff --git a/common/bolt-error.h b/common/bolt-error.h
 | ||||
| index 569da46..0486964 100644
 | ||||
| --- a/common/bolt-error.h
 | ||||
| +++ b/common/bolt-error.h
 | ||||
| @@ -36,7 +36,7 @@ G_BEGIN_DECLS
 | ||||
|   * | ||||
|   * Error codes used inside Bolt. | ||||
|   */ | ||||
| -enum {
 | ||||
| +typedef enum {
 | ||||
|    BOLT_ERROR_FAILED = 0, | ||||
|    BOLT_ERROR_UDEV, | ||||
|    BOLT_ERROR_NOKEY, | ||||
| -- 
 | ||||
| 2.24.1 | ||||
| 
 | ||||
							
								
								
									
										11
									
								
								bolt.spec
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								bolt.spec
									
									
									
									
									
								
							| @ -1,10 +1,12 @@ | ||||
| Name:          bolt | ||||
| Version:       0.8 | ||||
| Release:       2%{?dist} | ||||
| Release:       3%{?dist} | ||||
| Summary:       Thunderbolt device manager | ||||
| License:       LGPLv2+ | ||||
| URL:           https://gitlab.freedesktop.org/bolt/bolt | ||||
| Source0:       %{url}/-/archive/%{version}/%{name}-%{version}.tar.gz | ||||
| Patch0:        wakeup-uevents.patch | ||||
| Patch1:        bolt-error-typedef.patch | ||||
| 
 | ||||
| BuildRequires: gcc | ||||
| BuildRequires: asciidoc | ||||
| @ -38,7 +40,7 @@ boltctl, can be used to control the daemon and perform all the above | ||||
| mentioned tasks. | ||||
| 
 | ||||
| %prep | ||||
| %setup -q | ||||
| %autosetup -p1 | ||||
| 
 | ||||
| %build | ||||
| %meson -Ddb-name=boltd | ||||
| @ -76,6 +78,11 @@ mentioned tasks. | ||||
| %ghost %dir %{_localstatedir}/lib/boltd | ||||
| 
 | ||||
| %changelog | ||||
| * Thu Jan 23 2020 Christian Kellner <christian@kellner.me> - 0.8-3 | ||||
| - Add patch to ignore uevents from wakeup devices. See upstream issue | ||||
|   https://gitlab.freedesktop.org/bolt/bolt/issues/156 | ||||
| - Add patch to fix BoltError not being a typedef. | ||||
| 
 | ||||
| * Wed Jul 24 2019 Fedora Release Engineering <releng@fedoraproject.org> - 0.8-2 | ||||
| - Rebuilt for https://fedoraproject.org/wiki/Fedora_31_Mass_Rebuild | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										50
									
								
								wakeup-uevents.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								wakeup-uevents.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,50 @@ | ||||
| From ea3e3e30eb3ce76f6a0ae816a0f35809872f4edf Mon Sep 17 00:00:00 2001 | ||||
| From: Christian Kellner <christian@kellner.me> | ||||
| Date: Mon, 13 Jan 2020 17:38:47 +0100 | ||||
| Subject: [PATCH] manager: ignore wakeup device uevents for probing | ||||
| 
 | ||||
| The probing detection code should ignore wakeup device uevents | ||||
| because these virtual devices can be added (and removed) without | ||||
| and correspondence to any physical thunderbolt device (un-)plug | ||||
| events. | ||||
| ---
 | ||||
|  boltd/bolt-manager.c | 16 ++++++++++++++++ | ||||
|  1 file changed, 16 insertions(+) | ||||
| 
 | ||||
| diff --git a/boltd/bolt-manager.c b/boltd/bolt-manager.c
 | ||||
| index 877c008..c8b60da 100644
 | ||||
| --- a/boltd/bolt-manager.c
 | ||||
| +++ b/boltd/bolt-manager.c
 | ||||
| @@ -2043,6 +2043,16 @@ device_is_thunderbolt_root (struct udev_device *dev)
 | ||||
|           bolt_streq (driver, "thunderbolt"); | ||||
|  } | ||||
|   | ||||
| +static gboolean
 | ||||
| +device_is_wakeup (struct udev_device *dev)
 | ||||
| +{
 | ||||
| +  const char *subsys;
 | ||||
| +
 | ||||
| +  subsys = udev_device_get_subsystem (dev);
 | ||||
| +
 | ||||
| +  return bolt_streq (subsys, "wakeup");
 | ||||
| +}
 | ||||
| +
 | ||||
|  static gboolean | ||||
|  probing_add_root (BoltManager        *mgr, | ||||
|                    struct udev_device *dev) | ||||
| @@ -2080,6 +2090,12 @@ manager_probing_device_added (BoltManager        *mgr,
 | ||||
|    if (syspath == NULL) | ||||
|      return; | ||||
|   | ||||
| +  /* ignore events for wakeup devices which get removed
 | ||||
| +   * and added at random time without any connection to
 | ||||
| +   * any physical thunderbolt device */
 | ||||
| +  if (device_is_wakeup (dev))
 | ||||
| +    return;
 | ||||
| +
 | ||||
|    roots = mgr->probing_roots; | ||||
|    for (guint i = 0; i < roots->len; i++) | ||||
|      { | ||||
| -- 
 | ||||
| 2.24.1 | ||||
| 
 | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user