Skip to content

Commit

Permalink
Merge pull request #996 from thaJeztah/use_the_build
Browse files Browse the repository at this point in the history
Use osversion.Build() utility, and add a sync.Once
  • Loading branch information
dcantah authored Apr 12, 2021
2 parents da33ecd + bab6498 commit 4b67ed2
Show file tree
Hide file tree
Showing 21 changed files with 53 additions and 45 deletions.
2 changes: 1 addition & 1 deletion cmd/containerd-shim-runhcs-v1/exec_hcs.go
Original file line number Diff line number Diff line change
Expand Up @@ -262,7 +262,7 @@ func (he *hcsExec) Kill(ctx context.Context, signal uint32) error {
return nil
case shimExecStateRunning:
supported := false
if osversion.Get().Build >= osversion.RS5 {
if osversion.Build() >= osversion.RS5 {
supported = he.host == nil || he.host.SignalProcessSupported()
}
var options interface{}
Expand Down
2 changes: 1 addition & 1 deletion cmd/containerd-shim-runhcs-v1/pod.go
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ type shimPod interface {
func createPod(ctx context.Context, events publisher, req *task.CreateTaskRequest, s *specs.Spec) (shimPod, error) {
log.G(ctx).WithField("tid", req.ID).Debug("createPod")

if osversion.Get().Build < osversion.RS5 {
if osversion.Build() < osversion.RS5 {
return nil, errors.Wrapf(errdefs.ErrFailedPrecondition, "pod support is not available on Windows versions previous to RS5 (%d)", osversion.RS5)
}

Expand Down
4 changes: 2 additions & 2 deletions cmd/containerd-shim-runhcs-v1/task_hcs.go
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ func newHcsStandaloneTask(ctx context.Context, events publisher, req *task.Creat
owner := filepath.Base(os.Args[0])

var parent *uvm.UtilityVM
if osversion.Get().Build >= osversion.RS5 && oci.IsIsolated(s) {
if osversion.Build() >= osversion.RS5 && oci.IsIsolated(s) {
// Create the UVM parent
opts, err := oci.SpecToUVMCreateOpts(ctx, s, fmt.Sprintf("%s@vm", req.ID), owner)
if err != nil {
Expand Down Expand Up @@ -375,7 +375,7 @@ type hcsTask struct {
// host is the hosting VM for this exec if hypervisor isolated. If
// `host==nil` this is an Argon task so no UVM cleanup is required.
//
// NOTE: if `osversion.Get().Build < osversion.RS5` this will always be
// NOTE: if `osversion.Build() < osversion.RS5` this will always be
// `nil`.
host *uvm.UtilityVM

Expand Down
2 changes: 1 addition & 1 deletion cmd/runhcs/container.go
Original file line number Diff line number Diff line change
Expand Up @@ -307,7 +307,7 @@ func createContainer(cfg *containerConfig) (_ *container, err error) {
return nil, fmt.Errorf("host container %s is not a VM host", hostID)
}
hostUniqueID = host.UniqueID
} else if vmisolated && (isSandbox || cfg.Spec.Linux != nil || osversion.Get().Build >= osversion.RS5) {
} else if vmisolated && (isSandbox || cfg.Spec.Linux != nil || osversion.Build() >= osversion.RS5) {
// This handles all LCOW, Pod Sandbox, and (Windows Xenon V2 for RS5+)
hostID = cfg.ID
newvm = true
Expand Down
2 changes: 1 addition & 1 deletion cmd/runhcs/create-scratch.go
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ var createScratchCommand = cli.Command{
return errors.New("'destpath' is required")
}

if osversion.Get().Build < osversion.RS5 {
if osversion.Build() < osversion.RS5 {
return errors.New("LCOW is not supported pre-RS5")
}

Expand Down
2 changes: 1 addition & 1 deletion cmd/runhcs/kill.go
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ signal to the init process of the "ubuntu01" container:
signalsSupported := false

// The Signal feature was added in RS5
if osversion.Get().Build >= osversion.RS5 {
if osversion.Build() >= osversion.RS5 {
if c.IsHost || c.HostID != "" {
var hostID string
if c.IsHost {
Expand Down
2 changes: 1 addition & 1 deletion cmd/runhcs/prepare-disk.go
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ var prepareDiskCommand = cli.Command{
return errors.New("'destpath' is required")
}

if osversion.Get().Build < osversion.RS5 {
if osversion.Build() < osversion.RS5 {
return errors.New("LCOW is not supported pre-RS5")
}

Expand Down
2 changes: 1 addition & 1 deletion computestorage/setup.go
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ func SetupBaseOSLayer(ctx context.Context, layerPath string, vhdHandle windows.H
//
// `options` are the options applied while processing the layer.
func SetupBaseOSVolume(ctx context.Context, layerPath, volumePath string, options OsLayerOptions) (err error) {
if osversion.Get().Build < 19645 {
if osversion.Build() < 19645 {
return errors.New("SetupBaseOSVolume is not present on builds older than 19645")
}
title := "hcsshim.SetupBaseOSVolume"
Expand Down
2 changes: 1 addition & 1 deletion internal/hcsoci/hcsdoc_wcow.go
Original file line number Diff line number Diff line change
Expand Up @@ -366,7 +366,7 @@ func createWindowsContainerDocument(ctx context.Context, coi *createOptionsInter
}
v1.MappedDirectories = mounts.mdsv1
v2Container.MappedDirectories = mounts.mdsv2
if len(mounts.mpsv1) > 0 && osversion.Get().Build < osversion.RS3 {
if len(mounts.mpsv1) > 0 && osversion.Build() < osversion.RS3 {
return nil, nil, fmt.Errorf("named pipe mounts are not supported on this version of Windows")
}
v1.MappedPipes = mounts.mpsv1
Expand Down
4 changes: 2 additions & 2 deletions internal/schemaversion/schemaversion.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ func IsSupported(sv *hcsschema.Version) error {
return nil
}
if IsV21(sv) {
if osversion.Get().Build < osversion.RS5 {
if osversion.Build() < osversion.RS5 {
return fmt.Errorf("unsupported on this Windows build")
}
return nil
Expand Down Expand Up @@ -67,7 +67,7 @@ func String(sv *hcsschema.Version) string {
// requested option.
func DetermineSchemaVersion(requestedSV *hcsschema.Version) *hcsschema.Version {
sv := SchemaV10()
if osversion.Get().Build >= osversion.RS5 {
if osversion.Build() >= osversion.RS5 {
sv = SchemaV21()
}
if requestedSV != nil {
Expand Down
4 changes: 2 additions & 2 deletions internal/uvm/create.go
Original file line number Diff line number Diff line change
Expand Up @@ -145,11 +145,11 @@ func verifyOptions(ctx context.Context, options interface{}) error {
return errors.New("PreferredRootFSTypeVHD requires at least one VPMem device")
}
}
if opts.KernelDirect && osversion.Get().Build < 18286 {
if opts.KernelDirect && osversion.Build() < 18286 {
return errors.New("KernelDirectBoot is not supported on builds older than 18286")
}

if opts.EnableColdDiscardHint && osversion.Get().Build < 18967 {
if opts.EnableColdDiscardHint && osversion.Build() < 18967 {
return errors.New("EnableColdDiscardHint is not supported on builds older than 18967")
}
case *OptionsWCOW:
Expand Down
2 changes: 1 addition & 1 deletion internal/uvm/create_lcow.go
Original file line number Diff line number Diff line change
Expand Up @@ -97,7 +97,7 @@ func defaultLCOWOSBootFilesPath() string {
// executable files name.
func NewDefaultOptionsLCOW(id, owner string) *OptionsLCOW {
// Use KernelDirect boot by default on all builds that support it.
kernelDirectSupported := osversion.Get().Build >= 18286
kernelDirectSupported := osversion.Build() >= 18286
opts := &OptionsLCOW{
Options: newDefaultOptions(id, owner),
BootFilesPath: defaultLCOWOSBootFilesPath(),
Expand Down
2 changes: 1 addition & 1 deletion internal/uvm/network.go
Original file line number Diff line number Diff line change
Expand Up @@ -512,7 +512,7 @@ func (uvm *UtilityVM) isNetworkNamespaceSupported() bool {
}

func getNetworkModifyRequest(adapterID string, requestType string, settings interface{}) interface{} {
if osversion.Get().Build >= osversion.RS5 {
if osversion.Build() >= osversion.RS5 {
return guestrequest.NetworkModifyRequest{
AdapterId: adapterID,
RequestType: requestType,
Expand Down
2 changes: 1 addition & 1 deletion internal/uvm/plan9.go
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ func (uvm *UtilityVM) AddPlan9(ctx context.Context, hostPath string, uvmPath str
if uvm.operatingSystem != "linux" {
return nil, errNotSupported
}
if restrict && osversion.Get().Build < osversion.V19H1 {
if restrict && osversion.Build() < osversion.V19H1 {
return nil, errors.New("single-file mappings are not supported on this build of Windows")
}
if uvmPath == "" {
Expand Down
2 changes: 1 addition & 1 deletion internal/uvm/vsmb.go
Original file line number Diff line number Diff line change
Expand Up @@ -134,7 +134,7 @@ func openHostPath(path string) (windows.Handle, error) {
// To work around this, we attempt to query for FileIdInfo ourselves if on an affected build. If
// the query fails, we override the specified options to force no direct map to be used.
func forceNoDirectMap(path string) (bool, error) {
if ver := osversion.Get().Build; ver < osversion.V19H1 || ver > osversion.V20H2 {
if ver := osversion.Build(); ver < osversion.V19H1 || ver > osversion.V20H2 {
return false, nil
}
h, err := openHostPath(path)
Expand Down
2 changes: 1 addition & 1 deletion internal/wclayer/expandscratchsize.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ func ExpandScratchSize(ctx context.Context, path string, size uint64) (err error

// Manually expand the volume now in order to work around bugs in 19H1 and
// prerelease versions of Vb. Remove once this is fixed in Windows.
if build := osversion.Get().Build; build >= osversion.V19H1 && build < 19020 {
if build := osversion.Build(); build >= osversion.V19H1 && build < 19020 {
err = expandSandboxVolume(ctx, path)
if err != nil {
return err
Expand Down
28 changes: 18 additions & 10 deletions osversion/osversion_windows.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ package osversion

import (
"fmt"
"sync"

"golang.org/x/sys/windows"
)
Expand All @@ -15,19 +16,26 @@ type OSVersion struct {
Build uint16
}

var (
osv OSVersion
once sync.Once
)

// Get gets the operating system version on Windows.
// The calling application must be manifested to get the correct version information.
func Get() OSVersion {
var err error
osv := OSVersion{}
osv.Version, err = windows.GetVersion()
if err != nil {
// GetVersion never fails.
panic(err)
}
osv.MajorVersion = uint8(osv.Version & 0xFF)
osv.MinorVersion = uint8(osv.Version >> 8 & 0xFF)
osv.Build = uint16(osv.Version >> 16)
once.Do(func() {
var err error
osv = OSVersion{}
osv.Version, err = windows.GetVersion()
if err != nil {
// GetVersion never fails.
panic(err)
}
osv.MajorVersion = uint8(osv.Version & 0xFF)
osv.MinorVersion = uint8(osv.Version >> 8 & 0xFF)
osv.Build = uint16(osv.Version >> 16)
})
return osv
}

Expand Down
16 changes: 8 additions & 8 deletions test/cri-containerd/container_virtual_device_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -200,7 +200,7 @@ func getGPUContainerRequestWCOW(t *testing.T, podID string, podConfig *runtime.P
func Test_RunContainer_VirtualDevice_GPU_LCOW(t *testing.T) {
requireFeatures(t, featureLCOW, featureGPU)

if osversion.Get().Build < osversion.V20H1 {
if osversion.Build() < osversion.V20H1 {
t.Skip("Requires build +20H1")
}

Expand Down Expand Up @@ -240,7 +240,7 @@ func Test_RunContainer_VirtualDevice_GPU_LCOW(t *testing.T) {
func Test_RunContainer_VirtualDevice_GPU_Multiple_LCOW(t *testing.T) {
requireFeatures(t, featureLCOW, featureGPU)

if osversion.Get().Build < osversion.V20H1 {
if osversion.Build() < osversion.V20H1 {
t.Skip("Requires build +20H1")
}

Expand Down Expand Up @@ -289,7 +289,7 @@ func Test_RunContainer_VirtualDevice_GPU_Multiple_LCOW(t *testing.T) {
func Test_RunContainer_VirtualDevice_GPU_and_NoGPU_LCOW(t *testing.T) {
requireFeatures(t, featureLCOW, featureGPU)

if osversion.Get().Build < osversion.V20H1 {
if osversion.Build() < osversion.V20H1 {
t.Skip("Requires build +20H1")
}

Expand Down Expand Up @@ -358,7 +358,7 @@ func Test_RunContainer_VirtualDevice_GPU_and_NoGPU_LCOW(t *testing.T) {
func Test_RunContainer_VirtualDevice_GPU_Multiple_Removal_LCOW(t *testing.T) {
requireFeatures(t, featureLCOW, featureGPU)

if osversion.Get().Build < osversion.V20H1 {
if osversion.Build() < osversion.V20H1 {
t.Skip("Requires build +20H1")
}

Expand Down Expand Up @@ -486,7 +486,7 @@ func Test_RunContainer_VirtualDevice_ClassGUID_WCOW_Process(t *testing.T) {
func Test_RunContainer_VirtualDevice_GPU_WCOW_Hypervisor(t *testing.T) {
requireFeatures(t, featureWCOWHypervisor, featureGPU)

if osversion.Get().Build < osversion.V20H1 {
if osversion.Build() < osversion.V20H1 {
t.Skip("Requires build +20H1")
}

Expand Down Expand Up @@ -531,7 +531,7 @@ func Test_RunContainer_VirtualDevice_GPU_WCOW_Hypervisor(t *testing.T) {
func Test_RunContainer_VirtualDevice_GPU_and_NoGPU_WCOW_Hypervisor(t *testing.T) {
requireFeatures(t, featureWCOWHypervisor, featureGPU)

if osversion.Get().Build < osversion.V20H1 {
if osversion.Build() < osversion.V20H1 {
t.Skip("Requires build +20H1")
}

Expand Down Expand Up @@ -592,7 +592,7 @@ func Test_RunContainer_VirtualDevice_GPU_and_NoGPU_WCOW_Hypervisor(t *testing.T)
func Test_RunContainer_VirtualDevice_GPU_Multiple_WCOW_Hypervisor(t *testing.T) {
requireFeatures(t, featureWCOWHypervisor, featureGPU)

if osversion.Get().Build < osversion.V20H1 {
if osversion.Build() < osversion.V20H1 {
t.Skip("Requires build +20H1")
}

Expand Down Expand Up @@ -645,7 +645,7 @@ func Test_RunContainer_VirtualDevice_GPU_Multiple_WCOW_Hypervisor(t *testing.T)
func Test_RunContainer_VirtualDevice_GPU_Multiple_Removal_WCOW_Hypervisor(t *testing.T) {
requireFeatures(t, featureWCOWHypervisor, featureGPU)

if osversion.Get().Build < osversion.V20H1 {
if osversion.Build() < osversion.V20H1 {
t.Skip("Requires build +20H1")
}

Expand Down
4 changes: 2 additions & 2 deletions test/cri-containerd/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -57,8 +57,8 @@ const (

// Image definitions
var (
imageWindowsNanoserver = getWindowsNanoserverImage(osversion.Get().Build)
imageWindowsServercore = getWindowsServerCoreImage(osversion.Get().Build)
imageWindowsNanoserver = getWindowsNanoserverImage(osversion.Build())
imageWindowsServercore = getWindowsServerCoreImage(osversion.Build())
imageWindowsNanoserver17763 = getWindowsNanoserverImage(osversion.RS5)
imageWindowsNanoserver18362 = getWindowsNanoserverImage(osversion.V19H1)
imageWindowsNanoserver19041 = getWindowsNanoserverImage(osversion.V20H1)
Expand Down
8 changes: 4 additions & 4 deletions test/cri-containerd/runpodsandbox_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -260,7 +260,7 @@ func Test_RunPodSandbox_MemorySize_LCOW(t *testing.T) {
func Test_RunPodSandbox_MMIO_WCOW_Process(t *testing.T) {
requireFeatures(t, featureWCOWProcess)

if osversion.Get().Build < osversion.V20H1 {
if osversion.Build() < osversion.V20H1 {
t.Skip("Requires build +20H1")
}
pullRequiredImages(t, []string{imageWindowsNanoserver})
Expand All @@ -277,7 +277,7 @@ func Test_RunPodSandbox_MMIO_WCOW_Process(t *testing.T) {
func Test_RunPodSandbox_MMIO_WCOW_Hypervisor(t *testing.T) {
requireFeatures(t, featureWCOWHypervisor)

if osversion.Get().Build < osversion.V20H1 {
if osversion.Build() < osversion.V20H1 {
t.Skip("Requires build +20H1")
}
pullRequiredImages(t, []string{imageWindowsNanoserver})
Expand All @@ -294,7 +294,7 @@ func Test_RunPodSandbox_MMIO_WCOW_Hypervisor(t *testing.T) {
func Test_RunPodSandbox_MMIO_LCOW(t *testing.T) {
requireFeatures(t, featureLCOW)

if osversion.Get().Build < osversion.V20H1 {
if osversion.Build() < osversion.V20H1 {
t.Skip("Requires build +20H1")
}
pullRequiredLcowImages(t, []string{imageLcowK8sPause})
Expand Down Expand Up @@ -917,7 +917,7 @@ func Test_RunPodSandbox_MultipleContainersSameVhd_WCOW(t *testing.T) {
requireFeatures(t, featureWCOWHypervisor)
// Prior to 19H1, we aren't able to easily create a formatted VHD, as
// HcsFormatWritableLayerVhd requires the VHD to be mounted prior the call.
if osversion.Get().Build < osversion.V19H1 {
if osversion.Build() < osversion.V19H1 {
t.Skip("Requires at least 19H1")
}

Expand Down
4 changes: 2 additions & 2 deletions test/functional/utilities/requiresbuild.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,13 @@ import (
)

func RequiresBuild(t *testing.T, b uint16) {
if osversion.Get().Build < b {
if osversion.Build() < b {
t.Skipf("Requires build %d+", b)
}
}

func RequiresExactBuild(t *testing.T, b uint16) {
if osversion.Get().Build != b {
if osversion.Build() != b {
t.Skipf("Requires exact build %d", b)
}
}

0 comments on commit 4b67ed2

Please sign in to comment.