github.com/metacubex/gvisor@v0.0.0-20240320004321-933faba989ec/pkg/sentry/kernel/pipe/pipe_mutex.go (about)

     1  package pipe
     2  
     3  import (
     4  	"reflect"
     5  
     6  	"github.com/metacubex/gvisor/pkg/sync"
     7  	"github.com/metacubex/gvisor/pkg/sync/locking"
     8  )
     9  
    10  // Mutex is sync.Mutex with the correctness validator.
    11  type pipeMutex struct {
    12  	mu sync.Mutex
    13  }
    14  
    15  var pipeprefixIndex *locking.MutexClass
    16  
    17  // lockNames is a list of user-friendly lock names.
    18  // Populated in init.
    19  var pipelockNames []string
    20  
    21  // lockNameIndex is used as an index passed to NestedLock and NestedUnlock,
    22  // referring to an index within lockNames.
    23  // Values are specified using the "consts" field of go_template_instance.
    24  type pipelockNameIndex int
    25  
    26  // DO NOT REMOVE: The following function automatically replaced with lock index constants.
    27  const (
    28  	pipeLockPipe = pipelockNameIndex(0)
    29  )
    30  const ()
    31  
    32  // Lock locks m.
    33  // +checklocksignore
    34  func (m *pipeMutex) Lock() {
    35  	locking.AddGLock(pipeprefixIndex, -1)
    36  	m.mu.Lock()
    37  }
    38  
    39  // NestedLock locks m knowing that another lock of the same type is held.
    40  // +checklocksignore
    41  func (m *pipeMutex) NestedLock(i pipelockNameIndex) {
    42  	locking.AddGLock(pipeprefixIndex, int(i))
    43  	m.mu.Lock()
    44  }
    45  
    46  // Unlock unlocks m.
    47  // +checklocksignore
    48  func (m *pipeMutex) Unlock() {
    49  	locking.DelGLock(pipeprefixIndex, -1)
    50  	m.mu.Unlock()
    51  }
    52  
    53  // NestedUnlock unlocks m knowing that another lock of the same type is held.
    54  // +checklocksignore
    55  func (m *pipeMutex) NestedUnlock(i pipelockNameIndex) {
    56  	locking.DelGLock(pipeprefixIndex, int(i))
    57  	m.mu.Unlock()
    58  }
    59  
    60  // DO NOT REMOVE: The following function is automatically replaced.
    61  func pipeinitLockNames() { pipelockNames = []string{"pipe"} }
    62  
    63  func init() {
    64  	pipeinitLockNames()
    65  	pipeprefixIndex = locking.NewMutexClass(reflect.TypeOf(pipeMutex{}), pipelockNames)
    66  }