mirror of
				https://github.com/kata-containers/kata-containers.git
				synced 2025-10-24 21:51:37 +00:00 
			
		
		
		
	config: Add NetRateLimiter* to Cloud Hypervisor
Let's add the newly added network rate limiter configurations to the Cloud Hypervisor's hypervisor configuration. Right now those are not used anywhere, and there's absolutely no way the users can set those up. That's coming later in this very same series. Signed-off-by: Fabiano Fidêncio <fabiano.fidencio@intel.com>
This commit is contained in:
		| @@ -860,52 +860,56 @@ func newClhHypervisorConfig(h hypervisor) (vc.HypervisorConfig, error) { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	return vc.HypervisorConfig{ | 	return vc.HypervisorConfig{ | ||||||
| 		HypervisorPath:          hypervisor, | 		HypervisorPath:                hypervisor, | ||||||
| 		HypervisorPathList:      h.HypervisorPathList, | 		HypervisorPathList:            h.HypervisorPathList, | ||||||
| 		KernelPath:              kernel, | 		KernelPath:                    kernel, | ||||||
| 		InitrdPath:              initrd, | 		InitrdPath:                    initrd, | ||||||
| 		ImagePath:               image, | 		ImagePath:                     image, | ||||||
| 		FirmwarePath:            firmware, | 		FirmwarePath:                  firmware, | ||||||
| 		MachineAccelerators:     machineAccelerators, | 		MachineAccelerators:           machineAccelerators, | ||||||
| 		KernelParams:            vc.DeserializeParams(strings.Fields(kernelParams)), | 		KernelParams:                  vc.DeserializeParams(strings.Fields(kernelParams)), | ||||||
| 		HypervisorMachineType:   machineType, | 		HypervisorMachineType:         machineType, | ||||||
| 		NumVCPUs:                h.defaultVCPUs(), | 		NumVCPUs:                      h.defaultVCPUs(), | ||||||
| 		DefaultMaxVCPUs:         h.defaultMaxVCPUs(), | 		DefaultMaxVCPUs:               h.defaultMaxVCPUs(), | ||||||
| 		MemorySize:              h.defaultMemSz(), | 		MemorySize:                    h.defaultMemSz(), | ||||||
| 		MemSlots:                h.defaultMemSlots(), | 		MemSlots:                      h.defaultMemSlots(), | ||||||
| 		MemOffset:               h.defaultMemOffset(), | 		MemOffset:                     h.defaultMemOffset(), | ||||||
| 		VirtioMem:               h.VirtioMem, | 		VirtioMem:                     h.VirtioMem, | ||||||
| 		EntropySource:           h.GetEntropySource(), | 		EntropySource:                 h.GetEntropySource(), | ||||||
| 		EntropySourceList:       h.EntropySourceList, | 		EntropySourceList:             h.EntropySourceList, | ||||||
| 		DefaultBridges:          h.defaultBridges(), | 		DefaultBridges:                h.defaultBridges(), | ||||||
| 		DisableBlockDeviceUse:   h.DisableBlockDeviceUse, | 		DisableBlockDeviceUse:         h.DisableBlockDeviceUse, | ||||||
| 		SharedFS:                sharedFS, | 		SharedFS:                      sharedFS, | ||||||
| 		VirtioFSDaemon:          h.VirtioFSDaemon, | 		VirtioFSDaemon:                h.VirtioFSDaemon, | ||||||
| 		VirtioFSDaemonList:      h.VirtioFSDaemonList, | 		VirtioFSDaemonList:            h.VirtioFSDaemonList, | ||||||
| 		VirtioFSCacheSize:       h.VirtioFSCacheSize, | 		VirtioFSCacheSize:             h.VirtioFSCacheSize, | ||||||
| 		VirtioFSCache:           h.VirtioFSCache, | 		VirtioFSCache:                 h.VirtioFSCache, | ||||||
| 		MemPrealloc:             h.MemPrealloc, | 		MemPrealloc:                   h.MemPrealloc, | ||||||
| 		HugePages:               h.HugePages, | 		HugePages:                     h.HugePages, | ||||||
| 		FileBackedMemRootDir:    h.FileBackedMemRootDir, | 		FileBackedMemRootDir:          h.FileBackedMemRootDir, | ||||||
| 		FileBackedMemRootList:   h.FileBackedMemRootList, | 		FileBackedMemRootList:         h.FileBackedMemRootList, | ||||||
| 		Debug:                   h.Debug, | 		Debug:                         h.Debug, | ||||||
| 		DisableNestingChecks:    h.DisableNestingChecks, | 		DisableNestingChecks:          h.DisableNestingChecks, | ||||||
| 		BlockDeviceDriver:       blockDriver, | 		BlockDeviceDriver:             blockDriver, | ||||||
| 		BlockDeviceCacheSet:     h.BlockDeviceCacheSet, | 		BlockDeviceCacheSet:           h.BlockDeviceCacheSet, | ||||||
| 		BlockDeviceCacheDirect:  h.BlockDeviceCacheDirect, | 		BlockDeviceCacheDirect:        h.BlockDeviceCacheDirect, | ||||||
| 		BlockDeviceCacheNoflush: h.BlockDeviceCacheNoflush, | 		BlockDeviceCacheNoflush:       h.BlockDeviceCacheNoflush, | ||||||
| 		EnableIOThreads:         h.EnableIOThreads, | 		EnableIOThreads:               h.EnableIOThreads, | ||||||
| 		Msize9p:                 h.msize9p(), | 		Msize9p:                       h.msize9p(), | ||||||
| 		HotplugVFIOOnRootBus:    h.HotplugVFIOOnRootBus, | 		HotplugVFIOOnRootBus:          h.HotplugVFIOOnRootBus, | ||||||
| 		PCIeRootPort:            h.PCIeRootPort, | 		PCIeRootPort:                  h.PCIeRootPort, | ||||||
| 		DisableVhostNet:         true, | 		DisableVhostNet:               true, | ||||||
| 		GuestHookPath:           h.guestHookPath(), | 		GuestHookPath:                 h.guestHookPath(), | ||||||
| 		VirtioFSExtraArgs:       h.VirtioFSExtraArgs, | 		VirtioFSExtraArgs:             h.VirtioFSExtraArgs, | ||||||
| 		SGXEPCSize:              defaultSGXEPCSize, | 		SGXEPCSize:                    defaultSGXEPCSize, | ||||||
| 		EnableAnnotations:       h.EnableAnnotations, | 		EnableAnnotations:             h.EnableAnnotations, | ||||||
| 		DisableSeccomp:          h.DisableSeccomp, | 		DisableSeccomp:                h.DisableSeccomp, | ||||||
| 		ConfidentialGuest:       h.ConfidentialGuest, | 		ConfidentialGuest:             h.ConfidentialGuest, | ||||||
| 		DisableSeLinux:          h.DisableSeLinux, | 		DisableSeLinux:                h.DisableSeLinux, | ||||||
|  | 		NetRateLimiterBwMaxRate:       h.getNetRateLimiterBwMaxRate(), | ||||||
|  | 		NetRateLimiterBwOneTimeBurst:  h.getNetRateLimiterBwOneTimeBurst(), | ||||||
|  | 		NetRateLimiterOpsMaxRate:      h.getNetRateLimiterOpsMaxRate(), | ||||||
|  | 		NetRateLimiterOpsOneTimeBurst: h.getNetRateLimiterOpsOneTimeBurst(), | ||||||
| 	}, nil | 	}, nil | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -810,6 +810,10 @@ func TestNewClhHypervisorConfig(t *testing.T) { | |||||||
| 	kernelPath := path.Join(tmpdir, "kernel") | 	kernelPath := path.Join(tmpdir, "kernel") | ||||||
| 	imagePath := path.Join(tmpdir, "image") | 	imagePath := path.Join(tmpdir, "image") | ||||||
| 	virtioFsDaemon := path.Join(tmpdir, "virtiofsd") | 	virtioFsDaemon := path.Join(tmpdir, "virtiofsd") | ||||||
|  | 	netRateLimiterBwMaxRate := int64(1000) | ||||||
|  | 	netRateLimiterBwOneTimeBurst := int64(1000) | ||||||
|  | 	netRateLimiterOpsMaxRate := int64(0) | ||||||
|  | 	netRateLimiterOpsOneTimeBurst := int64(1000) | ||||||
|  |  | ||||||
| 	for _, file := range []string{imagePath, hypervisorPath, kernelPath, virtioFsDaemon} { | 	for _, file := range []string{imagePath, hypervisorPath, kernelPath, virtioFsDaemon} { | ||||||
| 		err := createEmptyFile(file) | 		err := createEmptyFile(file) | ||||||
| @@ -817,11 +821,15 @@ func TestNewClhHypervisorConfig(t *testing.T) { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	hypervisor := hypervisor{ | 	hypervisor := hypervisor{ | ||||||
| 		Path:           hypervisorPath, | 		Path:                          hypervisorPath, | ||||||
| 		Kernel:         kernelPath, | 		Kernel:                        kernelPath, | ||||||
| 		Image:          imagePath, | 		Image:                         imagePath, | ||||||
| 		VirtioFSDaemon: virtioFsDaemon, | 		VirtioFSDaemon:                virtioFsDaemon, | ||||||
| 		VirtioFSCache:  "always", | 		VirtioFSCache:                 "always", | ||||||
|  | 		NetRateLimiterBwMaxRate:       netRateLimiterBwMaxRate, | ||||||
|  | 		NetRateLimiterBwOneTimeBurst:  netRateLimiterBwOneTimeBurst, | ||||||
|  | 		NetRateLimiterOpsMaxRate:      netRateLimiterOpsMaxRate, | ||||||
|  | 		NetRateLimiterOpsOneTimeBurst: netRateLimiterOpsOneTimeBurst, | ||||||
| 	} | 	} | ||||||
| 	config, err := newClhHypervisorConfig(hypervisor) | 	config, err := newClhHypervisorConfig(hypervisor) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| @@ -852,6 +860,22 @@ func TestNewClhHypervisorConfig(t *testing.T) { | |||||||
| 		t.Errorf("Expected VirtioFSCache %v, got %v", true, config.VirtioFSCache) | 		t.Errorf("Expected VirtioFSCache %v, got %v", true, config.VirtioFSCache) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	if config.NetRateLimiterBwMaxRate != netRateLimiterBwMaxRate { | ||||||
|  | 		t.Errorf("Expected value for network bandwidth rate limiter %v, got %v", netRateLimiterBwMaxRate, config.NetRateLimiterBwMaxRate) | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if config.NetRateLimiterBwOneTimeBurst != netRateLimiterBwOneTimeBurst { | ||||||
|  | 		t.Errorf("Expected value for network bandwidth one time burst %v, got %v", netRateLimiterBwOneTimeBurst, config.NetRateLimiterBwOneTimeBurst) | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if config.NetRateLimiterOpsMaxRate != netRateLimiterOpsMaxRate { | ||||||
|  | 		t.Errorf("Expected value for network operations rate limiter %v, got %v", netRateLimiterOpsMaxRate, config.NetRateLimiterOpsMaxRate) | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	// We expect 0 (zero) here as netRateLimiterOpsMaxRate is not set (set to zero). | ||||||
|  | 	if config.NetRateLimiterOpsOneTimeBurst != 0 { | ||||||
|  | 		t.Errorf("Expected value for network operations one time burst %v, got %v", netRateLimiterOpsOneTimeBurst, config.NetRateLimiterOpsOneTimeBurst) | ||||||
|  | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| func TestHypervisorDefaults(t *testing.T) { | func TestHypervisorDefaults(t *testing.T) { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user