]> xenbits.xensource.com Git - people/liuw/xen.git/commitdiff
golang/xenlight: define CpuidPolicyList builtin type
authorNick Rosbrook <rosbrookn@ainfosec.com>
Mon, 16 Dec 2019 18:08:05 +0000 (18:08 +0000)
committerGeorge Dunlap <george.dunlap@citrix.com>
Mon, 16 Dec 2019 18:08:05 +0000 (18:08 +0000)
Define CpuidPolicyList as a string so that libxl_cpuid_parse_config can
be used in the toC function.

For now, fromC is a no-op since libxl does not support a way to read a
policy, modify it,and then give it back to libxl.

Signed-off-by: Nick Rosbrook <rosbrookn@ainfosec.com>
Reviewed-by: George Dunlap <george.dunlap@citrix.com>
tools/golang/xenlight/xenlight.go

index c1d9fe85fd021d7284c6c44f6a284e8f3c081823..6b87bf857dd073aa54377b356a84cfb778755eb0 100644 (file)
@@ -245,6 +245,31 @@ type EvLink struct{}
 func (el *EvLink) fromC(cel *C.libxl_ev_link) error      { return nil }
 func (el *EvLink) toC() (cel C.libxl_ev_link, err error) { return }
 
+// CpuidPolicyList represents a libxl_cpuid_policy_list.
+//
+// The value of CpuidPolicyList is honored when used as input to libxl. If
+// a struct contains a field of type CpuidPolicyList, that field will be left
+// empty when it is returned from libxl.
+type CpuidPolicyList string
+
+func (cpl CpuidPolicyList) fromC(ccpl *C.libxl_cpuid_policy_list) error { return nil }
+
+func (cpl CpuidPolicyList) toC() (C.libxl_cpuid_policy_list, error) {
+       var ccpl C.libxl_cpuid_policy_list
+
+       s := C.CString(string(cpl))
+       defer C.free(unsafe.Pointer(s))
+
+       ret := C.libxl_cpuid_parse_config(&ccpl, s)
+       if ret != 0 {
+               C.libxl_cpuid_dispose(&ccpl)
+
+               return ccpl, Error(-ret)
+       }
+
+       return ccpl, nil
+}
+
 type Context struct {
        ctx    *C.libxl_ctx
        logger *C.xentoollog_logger_stdiostream