Source file src/internal/cpu/cpu_mips64x.go

     1  // Copyright 2019 The Go Authors. All rights reserved.
     2  // Use of this source code is governed by a BSD-style
     3  // license that can be found in the LICENSE file.
     4  
     5  //go:build mips64 || mips64le
     6  
     7  package cpu
     8  
     9  const CacheLinePadSize = 32
    10  
    11  // This is initialized by archauxv and should not be changed after it is
    12  // initialized.
    13  var HWCap uint
    14  
    15  // HWCAP bits. These are exposed by the Linux kernel 5.4.
    16  const (
    17  	// CPU features
    18  	hwcap_MIPS_MSA = 1 << 1
    19  )
    20  
    21  func doinit() {
    22  	options = []option{
    23  		{Name: "msa", Feature: &MIPS64X.HasMSA},
    24  	}
    25  
    26  	// HWCAP feature bits
    27  	MIPS64X.HasMSA = isSet(HWCap, hwcap_MIPS_MSA)
    28  }
    29  
    30  func isSet(hwc uint, value uint) bool {
    31  	return hwc&value != 0
    32  }
    33  

View as plain text