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,36 +73,34 @@ class XS_Watcher:
|
|||||||
def domain_list_changed(self, param):
|
def domain_list_changed(self, param):
|
||||||
self.log.debug('domain_list_changed(param={!r})'.format(param))
|
self.log.debug('domain_list_changed(param={!r})'.format(param))
|
||||||
|
|
||||||
curr = self.handle.ls('', '/local/domain')
|
|
||||||
|
|
||||||
if curr == None:
|
|
||||||
return
|
|
||||||
|
|
||||||
# check if domain is really there, it may happen that some empty
|
|
||||||
# directories are left in xenstore
|
|
||||||
curr = filter(
|
|
||||||
lambda x:
|
|
||||||
self.handle.read('',
|
|
||||||
'/local/domain/{}/domid'.format(x)
|
|
||||||
) is not None,
|
|
||||||
curr
|
|
||||||
)
|
|
||||||
|
|
||||||
self.log.debug('curr={!r}'.format(curr))
|
|
||||||
|
|
||||||
self.log.debug('acquiring global_lock')
|
self.log.debug('acquiring global_lock')
|
||||||
global_lock.acquire()
|
global_lock.acquire()
|
||||||
self.log.debug('global_lock acquired')
|
self.log.debug('global_lock acquired')
|
||||||
try:
|
try:
|
||||||
|
curr = self.handle.ls('', '/local/domain')
|
||||||
|
if curr is None:
|
||||||
|
return
|
||||||
|
|
||||||
|
# check if domain is really there, it may happen that some empty
|
||||||
|
# directories are left in xenstore
|
||||||
|
curr = filter(
|
||||||
|
lambda x:
|
||||||
|
self.handle.read('',
|
||||||
|
'/local/domain/{}/domid'.format(x)
|
||||||
|
) is not None,
|
||||||
|
curr
|
||||||
|
)
|
||||||
|
self.log.debug('curr={!r}'.format(curr))
|
||||||
|
|
||||||
for i in only_in_first_list(curr, self.watch_token_dict.keys()):
|
for i in only_in_first_list(curr, self.watch_token_dict.keys()):
|
||||||
#new domain has been created
|
# new domain has been created
|
||||||
watch = WatchType(XS_Watcher.meminfo_changed, i)
|
watch = WatchType(XS_Watcher.meminfo_changed, i)
|
||||||
self.watch_token_dict[i] = watch
|
self.watch_token_dict[i] = watch
|
||||||
self.handle.watch(get_domain_meminfo_key(i), watch)
|
self.handle.watch(get_domain_meminfo_key(i), watch)
|
||||||
system_state.add_domain(i)
|
system_state.add_domain(i)
|
||||||
|
|
||||||
for i in only_in_first_list(self.watch_token_dict.keys(), curr):
|
for i in only_in_first_list(self.watch_token_dict.keys(), curr):
|
||||||
#domain destroyed
|
# domain destroyed
|
||||||
self.handle.unwatch(get_domain_meminfo_key(i), self.watch_token_dict[i])
|
self.handle.unwatch(get_domain_meminfo_key(i), self.watch_token_dict[i])
|
||||||
self.watch_token_dict.pop(i)
|
self.watch_token_dict.pop(i)
|
||||||
system_state.del_domain(i)
|
system_state.del_domain(i)
|
||||||
|
Loading…
Reference in New Issue
Block a user