1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
|
// Copyright 2019 The gVisor Authors.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package pgalloc
import (
"context"
)
// contextID is this package's type for context.Context.Value keys.
type contextID int
const (
// CtxMemoryFile is a Context.Value key for a MemoryFile.
CtxMemoryFile contextID = iota
// CtxMemoryCgroupID is the memory cgroup id which the task belongs to.
CtxMemoryCgroupID
// CtxMemoryFileMap is a Context.Value key for mapping
// MemoryFileOpts.RestoreID to *MemoryFile. This is used for save/restore.
CtxMemoryFileMap
)
// MemoryFileFromContext returns the MemoryFile used by ctx, or nil if no such
// MemoryFile exists.
func MemoryFileFromContext(ctx context.Context) *MemoryFile {
if v := ctx.Value(CtxMemoryFile); v != nil {
return v.(*MemoryFile)
}
return nil
}
// MemoryCgroupIDFromContext returns the memory cgroup id of the ctx, or
// zero if the ctx does not belong to any memory cgroup.
func MemoryCgroupIDFromContext(ctx context.Context) uint32 {
if v := ctx.Value(CtxMemoryCgroupID); v != nil {
return v.(uint32)
}
return 0
}
// MemoryFileMapFromContext returns the memory file map used by ctx, or nil if
// no such map exists.
func MemoryFileMapFromContext(ctx context.Context) map[string]*MemoryFile {
if v := ctx.Value(CtxMemoryFileMap); v != nil {
return v.(map[string]*MemoryFile)
}
return nil
}
|