summaryrefslogtreecommitdiffstats
path: root/gfx/angle/src/libANGLE/renderer/driver_utils.h
blob: 865de73e182397bc180de915a7b4db7224b43d59 (plain)
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
//
// Copyright (c) 2016 The ANGLE Project Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
//

// driver_utils.h : provides more information about current driver.

#ifndef LIBANGLE_RENDERER_DRIVER_UTILS_H_
#define LIBANGLE_RENDERER_DRIVER_UTILS_H_

#include "libANGLE/angletypes.h"

namespace rx
{

enum VendorID : uint32_t
{
    VENDOR_ID_UNKNOWN = 0x0,
    VENDOR_ID_AMD     = 0x1002,
    VENDOR_ID_INTEL   = 0x8086,
    VENDOR_ID_NVIDIA  = 0x10DE,
    // This is Qualcomm PCI Vendor ID.
    // Android doesn't have a PCI bus, but all we need is a unique id.
    VENDOR_ID_QUALCOMM = 0x5143,
};

inline bool IsAMD(uint32_t vendor_id)
{
    return vendor_id == VENDOR_ID_AMD;
}

inline bool IsIntel(uint32_t vendor_id)
{
    return vendor_id == VENDOR_ID_INTEL;
}

inline bool IsNvidia(uint32_t vendor_id)
{
    return vendor_id == VENDOR_ID_NVIDIA;
}

inline bool IsQualcomm(uint32_t vendor_id)
{
    return vendor_id == VENDOR_ID_QUALCOMM;
}

// Intel
bool IsHaswell(uint32_t DeviceId);
bool IsBroadwell(uint32_t DeviceId);
bool IsCherryView(uint32_t DeviceId);
bool IsSkylake(uint32_t DeviceId);
bool IsBroxton(uint32_t DeviceId);
bool IsKabylake(uint32_t DeviceId);

}  // namespace rx
#endif  // LIBANGLE_RENDERER_DRIVER_UTILS_H_