mirror of
https://github.com/kata-containers/kata-containers.git
synced 2025-09-04 10:24:37 +00:00
Merge pull request #957 from teawater/cache
Block: Add cache-related options for block devices
This commit is contained in:
@@ -28,6 +28,9 @@ const defaultBridgesCount uint32 = 1
|
|||||||
const defaultInterNetworkingModel = "macvtap"
|
const defaultInterNetworkingModel = "macvtap"
|
||||||
const defaultDisableBlockDeviceUse bool = false
|
const defaultDisableBlockDeviceUse bool = false
|
||||||
const defaultBlockDeviceDriver = "virtio-scsi"
|
const defaultBlockDeviceDriver = "virtio-scsi"
|
||||||
|
const defaultBlockDeviceCacheSet bool = false
|
||||||
|
const defaultBlockDeviceCacheDirect bool = false
|
||||||
|
const defaultBlockDeviceCacheNoflush bool = false
|
||||||
const defaultEnableIOThreads bool = false
|
const defaultEnableIOThreads bool = false
|
||||||
const defaultEnableMemPrealloc bool = false
|
const defaultEnableMemPrealloc bool = false
|
||||||
const defaultEnableHugePages bool = false
|
const defaultEnableHugePages bool = false
|
||||||
|
@@ -89,6 +89,9 @@ type hypervisor struct {
|
|||||||
MachineType string `toml:"machine_type"`
|
MachineType string `toml:"machine_type"`
|
||||||
BlockDeviceDriver string `toml:"block_device_driver"`
|
BlockDeviceDriver string `toml:"block_device_driver"`
|
||||||
EntropySource string `toml:"entropy_source"`
|
EntropySource string `toml:"entropy_source"`
|
||||||
|
BlockDeviceCacheSet bool `toml:"block_device_cache_set"`
|
||||||
|
BlockDeviceCacheDirect bool `toml:"block_device_cache_direct"`
|
||||||
|
BlockDeviceCacheNoflush bool `toml:"block_device_cache_noflush"`
|
||||||
NumVCPUs int32 `toml:"default_vcpus"`
|
NumVCPUs int32 `toml:"default_vcpus"`
|
||||||
DefaultMaxVCPUs uint32 `toml:"default_maxvcpus"`
|
DefaultMaxVCPUs uint32 `toml:"default_maxvcpus"`
|
||||||
MemorySize uint32 `toml:"default_memory"`
|
MemorySize uint32 `toml:"default_memory"`
|
||||||
@@ -442,6 +445,9 @@ func newQemuHypervisorConfig(h hypervisor) (vc.HypervisorConfig, error) {
|
|||||||
Debug: h.Debug,
|
Debug: h.Debug,
|
||||||
DisableNestingChecks: h.DisableNestingChecks,
|
DisableNestingChecks: h.DisableNestingChecks,
|
||||||
BlockDeviceDriver: blockDriver,
|
BlockDeviceDriver: blockDriver,
|
||||||
|
BlockDeviceCacheSet: h.BlockDeviceCacheSet,
|
||||||
|
BlockDeviceCacheDirect: h.BlockDeviceCacheDirect,
|
||||||
|
BlockDeviceCacheNoflush: h.BlockDeviceCacheNoflush,
|
||||||
EnableIOThreads: h.EnableIOThreads,
|
EnableIOThreads: h.EnableIOThreads,
|
||||||
Msize9p: h.msize9p(),
|
Msize9p: h.msize9p(),
|
||||||
UseVSock: useVSock,
|
UseVSock: useVSock,
|
||||||
@@ -561,6 +567,9 @@ func initConfig() (config oci.RuntimeConfig, err error) {
|
|||||||
Debug: defaultEnableDebug,
|
Debug: defaultEnableDebug,
|
||||||
DisableNestingChecks: defaultDisableNestingChecks,
|
DisableNestingChecks: defaultDisableNestingChecks,
|
||||||
BlockDeviceDriver: defaultBlockDeviceDriver,
|
BlockDeviceDriver: defaultBlockDeviceDriver,
|
||||||
|
BlockDeviceCacheSet: defaultBlockDeviceCacheSet,
|
||||||
|
BlockDeviceCacheDirect: defaultBlockDeviceCacheDirect,
|
||||||
|
BlockDeviceCacheNoflush: defaultBlockDeviceCacheNoflush,
|
||||||
EnableIOThreads: defaultEnableIOThreads,
|
EnableIOThreads: defaultEnableIOThreads,
|
||||||
Msize9p: defaultMsize9p,
|
Msize9p: defaultMsize9p,
|
||||||
HotplugVFIOOnRootBus: defaultHotplugVFIOOnRootBus,
|
HotplugVFIOOnRootBus: defaultHotplugVFIOOnRootBus,
|
||||||
|
@@ -206,6 +206,17 @@ type HypervisorConfig struct {
|
|||||||
// it will be used for the sandbox's kernel path instead of KernelPath.
|
// it will be used for the sandbox's kernel path instead of KernelPath.
|
||||||
customAssets map[assetType]*asset
|
customAssets map[assetType]*asset
|
||||||
|
|
||||||
|
// BlockDeviceCacheSet specifies cache-related options will be set to block devices or not.
|
||||||
|
BlockDeviceCacheSet bool
|
||||||
|
|
||||||
|
// BlockDeviceCacheDirect specifies cache-related options for block devices.
|
||||||
|
// Denotes whether use of O_DIRECT (bypass the host page cache) is enabled.
|
||||||
|
BlockDeviceCacheDirect bool
|
||||||
|
|
||||||
|
// BlockDeviceCacheNoflush specifies cache-related options for block devices.
|
||||||
|
// Denotes whether flush requests for the device are ignored.
|
||||||
|
BlockDeviceCacheNoflush bool
|
||||||
|
|
||||||
// DisableBlockDeviceUse disallows a block device from being used.
|
// DisableBlockDeviceUse disallows a block device from being used.
|
||||||
DisableBlockDeviceUse bool
|
DisableBlockDeviceUse bool
|
||||||
|
|
||||||
|
@@ -736,7 +736,12 @@ func (q *qemu) hotplugBlockDevice(drive *config.BlockDrive, op operation) error
|
|||||||
devID := "virtio-" + drive.ID
|
devID := "virtio-" + drive.ID
|
||||||
|
|
||||||
if op == addDevice {
|
if op == addDevice {
|
||||||
if err := q.qmpMonitorCh.qmp.ExecuteBlockdevAdd(q.qmpMonitorCh.ctx, drive.File, drive.ID); err != nil {
|
if q.config.BlockDeviceCacheSet {
|
||||||
|
err = q.qmpMonitorCh.qmp.ExecuteBlockdevAddWithCache(q.qmpMonitorCh.ctx, drive.File, drive.ID, q.config.BlockDeviceCacheDirect, q.config.BlockDeviceCacheNoflush)
|
||||||
|
} else {
|
||||||
|
err = q.qmpMonitorCh.qmp.ExecuteBlockdevAdd(q.qmpMonitorCh.ctx, drive.File, drive.ID)
|
||||||
|
}
|
||||||
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user