dom0/qmemman: different approach of mem-set and maxmem (libxl way)

Libxl stores maxmem in xenstore (/local/domain/X/memory/static-max) and sets
maxmem and target_mem to actual memory. So qmemman should use xenstore entry as
memory_maximum (when exists) and also adjust maxmem when changing domain memory.
This commit is contained in:
Marek Marczykowski 2011-06-07 16:19:52 +02:00
parent 50a910362d
commit c444ebc5f8

View File

@ -44,7 +44,9 @@ class SystemState:
id = str(domain['domid']) id = str(domain['domid'])
if self.domdict.has_key(id): if self.domdict.has_key(id):
self.domdict[id].memory_actual = domain['mem_kb']*1024 self.domdict[id].memory_actual = domain['mem_kb']*1024
self.domdict[id].memory_maximum = domain['maxmem_kb']*1024 self.domdict[id].memory_maximum = self.xs.read('', '/local/domain/%s/memory/static-max' % str(id))
if not self.domdict[id].memory_maximum:
self.domdict[id].memory_maximum = domain['maxmem_kb']*1024
#the below works (and is fast), but then 'xm list' shows unchanged memory value #the below works (and is fast), but then 'xm list' shows unchanged memory value
def mem_set(self, id, val): def mem_set(self, id, val):
@ -54,6 +56,7 @@ class SystemState:
#can happen in the middle of domain shutdown #can happen in the middle of domain shutdown
#apparently xc.lowlevel throws exceptions too #apparently xc.lowlevel throws exceptions too
try: try:
self.xc.domain_setmaxmem(int(id), val/1024 + 1024) # LIBXL_MAXMEM_CONSTANT=1024
self.xc.domain_set_target_mem(int(id), val/1024) self.xc.domain_set_target_mem(int(id), val/1024)
except: except:
pass pass