qmemman: refresh domain list holding global_lock
Retrieve a domain list only after obtaining global lock. Otherwise an outdated list may be used, when a domain was introduced in the meantime (starting a new domain is done with global lock held), leading to #1389. QubesOS/qubes-issues#1389
This commit is contained in:
parent
caa75cbc18
commit
411e8b5323
@ -73,9 +73,12 @@ class XS_Watcher:
|
||||
def domain_list_changed(self, param):
|
||||
self.log.debug('domain_list_changed(param={!r})'.format(param))
|
||||
|
||||
self.log.debug('acquiring global_lock')
|
||||
global_lock.acquire()
|
||||
self.log.debug('global_lock acquired')
|
||||
try:
|
||||
curr = self.handle.ls('', '/local/domain')
|
||||
|
||||
if curr == None:
|
||||
if curr is None:
|
||||
return
|
||||
|
||||
# check if domain is really there, it may happen that some empty
|
||||
@ -87,13 +90,8 @@ class XS_Watcher:
|
||||
) is not None,
|
||||
curr
|
||||
)
|
||||
|
||||
self.log.debug('curr={!r}'.format(curr))
|
||||
|
||||
self.log.debug('acquiring global_lock')
|
||||
global_lock.acquire()
|
||||
self.log.debug('global_lock acquired')
|
||||
try:
|
||||
for i in only_in_first_list(curr, self.watch_token_dict.keys()):
|
||||
# new domain has been created
|
||||
watch = WatchType(XS_Watcher.meminfo_changed, i)
|
||||
|
Loading…
Reference in New Issue
Block a user