File: cpu_utils.cc

package info (click to toggle)
chromium 120.0.6099.224-1~deb11u1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 6,112,112 kB
  • sloc: cpp: 32,907,025; ansic: 8,148,123; javascript: 3,679,536; python: 2,031,248; asm: 959,718; java: 804,675; xml: 617,256; sh: 111,417; objc: 100,835; perl: 88,443; cs: 53,032; makefile: 29,579; fortran: 24,137; php: 21,162; tcl: 21,147; sql: 20,809; ruby: 17,735; pascal: 12,864; yacc: 8,045; lisp: 3,388; lex: 1,323; ada: 727; awk: 329; jsp: 267; csh: 117; exp: 43; sed: 37
file content (41 lines) | stat: -rw-r--r-- 1,263 bytes parent folder | download
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
// Copyright 2021 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#include "remoting/base/cpu_utils.h"

#include "base/cpu.h"
#include "build/build_config.h"

namespace remoting {

namespace {
// Supporting SSE3 is a requirement for Chromium on x86/x64 so that is our base
// alignment. Both SSE3 (x86) and NEON (ARM) benefit from 16 byte alignment in
// libyuv so make that the default. If the CPU supports AVX2, then we will use
// that alignment instead. In the cases where AVX512 is used in libyuv, the
// alignment requirements are the same as for AVX2.
constexpr int kDefaultAlignmentBytes = 16;
constexpr int kAvx2AlignmentBytes = 32;
}  // namespace

bool IsCpuSupported() {
#if defined(ARCH_CPU_X86_FAMILY)
  // x86 Chromium builds target SSE3.
  // See crbug.com/1251642 for more info.
  if (!base::CPU().has_sse3()) {
    return false;
  }
#endif
  return true;
}

int GetSimdMemoryAlignment() {
  // We only need to calculate this once since the processor capabilities won't
  // change while the process is running.
  static const int alignment =
      base::CPU().has_avx2() ? kAvx2AlignmentBytes : kDefaultAlignmentBytes;
  return alignment;
}

}  // namespace remoting