1*61046927SAndroid Build Coastguard Worker /*
2*61046927SAndroid Build Coastguard Worker * Copyright © 2020 Intel Corporation
3*61046927SAndroid Build Coastguard Worker *
4*61046927SAndroid Build Coastguard Worker * Permission is hereby granted, free of charge, to any person obtaining a
5*61046927SAndroid Build Coastguard Worker * copy of this software and associated documentation files (the "Software"),
6*61046927SAndroid Build Coastguard Worker * to deal in the Software without restriction, including without limitation
7*61046927SAndroid Build Coastguard Worker * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8*61046927SAndroid Build Coastguard Worker * and/or sell copies of the Software, and to permit persons to whom the
9*61046927SAndroid Build Coastguard Worker * Software is furnished to do so, subject to the following conditions:
10*61046927SAndroid Build Coastguard Worker *
11*61046927SAndroid Build Coastguard Worker * The above copyright notice and this permission notice (including the next
12*61046927SAndroid Build Coastguard Worker * paragraph) shall be included in all copies or substantial portions of the
13*61046927SAndroid Build Coastguard Worker * Software.
14*61046927SAndroid Build Coastguard Worker *
15*61046927SAndroid Build Coastguard Worker * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16*61046927SAndroid Build Coastguard Worker * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17*61046927SAndroid Build Coastguard Worker * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
18*61046927SAndroid Build Coastguard Worker * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19*61046927SAndroid Build Coastguard Worker * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20*61046927SAndroid Build Coastguard Worker * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
21*61046927SAndroid Build Coastguard Worker * IN THE SOFTWARE.
22*61046927SAndroid Build Coastguard Worker */
23*61046927SAndroid Build Coastguard Worker
24*61046927SAndroid Build Coastguard Worker #include "intel_uuid.h"
25*61046927SAndroid Build Coastguard Worker #include "git_sha1.h"
26*61046927SAndroid Build Coastguard Worker #include "util/mesa-sha1.h"
27*61046927SAndroid Build Coastguard Worker
28*61046927SAndroid Build Coastguard Worker void
intel_uuid_compute_device_id(uint8_t * uuid,const struct intel_device_info * devinfo,size_t size)29*61046927SAndroid Build Coastguard Worker intel_uuid_compute_device_id(uint8_t *uuid,
30*61046927SAndroid Build Coastguard Worker const struct intel_device_info *devinfo,
31*61046927SAndroid Build Coastguard Worker size_t size)
32*61046927SAndroid Build Coastguard Worker {
33*61046927SAndroid Build Coastguard Worker /* The device UUID uniquely identifies the given device within the machine.
34*61046927SAndroid Build Coastguard Worker * We use the device information along with PCI information to make sure we
35*61046927SAndroid Build Coastguard Worker * have different UUIDs on a system with multiple identical (discrete)
36*61046927SAndroid Build Coastguard Worker * GPUs.
37*61046927SAndroid Build Coastguard Worker */
38*61046927SAndroid Build Coastguard Worker
39*61046927SAndroid Build Coastguard Worker /* We want to have UUID matching between the different drivers (outside the
40*61046927SAndroid Build Coastguard Worker * Mesa project). This structure has been agreed with the various drivers
41*61046927SAndroid Build Coastguard Worker * to be the generated UUID.
42*61046927SAndroid Build Coastguard Worker *
43*61046927SAndroid Build Coastguard Worker * Consult other drivers before changing this.
44*61046927SAndroid Build Coastguard Worker */
45*61046927SAndroid Build Coastguard Worker struct device_uuid {
46*61046927SAndroid Build Coastguard Worker uint16_t vendor_id;
47*61046927SAndroid Build Coastguard Worker uint16_t device_id;
48*61046927SAndroid Build Coastguard Worker uint16_t revision_id;
49*61046927SAndroid Build Coastguard Worker uint16_t pci_domain;
50*61046927SAndroid Build Coastguard Worker uint8_t pci_bus;
51*61046927SAndroid Build Coastguard Worker uint8_t pci_dev;
52*61046927SAndroid Build Coastguard Worker uint8_t pci_func;
53*61046927SAndroid Build Coastguard Worker uint8_t padding[4];
54*61046927SAndroid Build Coastguard Worker uint8_t sub_device_id; /* Tile number */
55*61046927SAndroid Build Coastguard Worker } shared_uuid = {
56*61046927SAndroid Build Coastguard Worker .vendor_id = 0x8086,
57*61046927SAndroid Build Coastguard Worker .device_id = devinfo->pci_device_id,
58*61046927SAndroid Build Coastguard Worker .revision_id = devinfo->pci_revision_id,
59*61046927SAndroid Build Coastguard Worker .pci_domain = devinfo->pci_domain,
60*61046927SAndroid Build Coastguard Worker .pci_bus = devinfo->pci_bus,
61*61046927SAndroid Build Coastguard Worker .pci_dev = devinfo->pci_dev,
62*61046927SAndroid Build Coastguard Worker .pci_func = devinfo->pci_func,
63*61046927SAndroid Build Coastguard Worker };
64*61046927SAndroid Build Coastguard Worker
65*61046927SAndroid Build Coastguard Worker /* All the users have a 16byte UUID */
66*61046927SAndroid Build Coastguard Worker assert(size == 16);
67*61046927SAndroid Build Coastguard Worker assert(sizeof(shared_uuid) == 16);
68*61046927SAndroid Build Coastguard Worker
69*61046927SAndroid Build Coastguard Worker memcpy(uuid, &shared_uuid, size);
70*61046927SAndroid Build Coastguard Worker }
71*61046927SAndroid Build Coastguard Worker
72*61046927SAndroid Build Coastguard Worker void
intel_uuid_compute_driver_id(uint8_t * uuid,const struct intel_device_info * devinfo,size_t size)73*61046927SAndroid Build Coastguard Worker intel_uuid_compute_driver_id(uint8_t *uuid,
74*61046927SAndroid Build Coastguard Worker const struct intel_device_info *devinfo,
75*61046927SAndroid Build Coastguard Worker size_t size)
76*61046927SAndroid Build Coastguard Worker {
77*61046927SAndroid Build Coastguard Worker const char* intelDriver = PACKAGE_VERSION MESA_GIT_SHA1;
78*61046927SAndroid Build Coastguard Worker struct mesa_sha1 sha1_ctx;
79*61046927SAndroid Build Coastguard Worker uint8_t sha1[20];
80*61046927SAndroid Build Coastguard Worker
81*61046927SAndroid Build Coastguard Worker assert(size <= sizeof(sha1));
82*61046927SAndroid Build Coastguard Worker
83*61046927SAndroid Build Coastguard Worker /* The driver UUID is used for determining sharability of images and memory
84*61046927SAndroid Build Coastguard Worker * between two Vulkan instances in separate processes, but also to
85*61046927SAndroid Build Coastguard Worker * determining memory objects and sharability between Vulkan and OpenGL
86*61046927SAndroid Build Coastguard Worker * driver. People who want to share memory need to also check the device
87*61046927SAndroid Build Coastguard Worker * UUID.
88*61046927SAndroid Build Coastguard Worker */
89*61046927SAndroid Build Coastguard Worker _mesa_sha1_init(&sha1_ctx);
90*61046927SAndroid Build Coastguard Worker _mesa_sha1_update(&sha1_ctx, intelDriver, strlen(intelDriver));
91*61046927SAndroid Build Coastguard Worker _mesa_sha1_update(&sha1_ctx, &devinfo->has_bit6_swizzle,
92*61046927SAndroid Build Coastguard Worker sizeof(devinfo->has_bit6_swizzle));
93*61046927SAndroid Build Coastguard Worker _mesa_sha1_final(&sha1_ctx, sha1);
94*61046927SAndroid Build Coastguard Worker memcpy(uuid, sha1, size);
95*61046927SAndroid Build Coastguard Worker }
96