4d15769bf5a3fbd0e4c6171948bb847a35391b35
[platform/core/uifw/vulkan-wsi-tizen.git] / layer / private_data.cpp
1 /*
2  * Copyright (c) 2018-2019 Arm Limited.
3  *
4  * SPDX-License-Identifier: MIT
5  *
6  * Permission is hereby granted, free of charge, to any person obtaining a copy
7  * of this software and associated documentation files (the "Software"), to
8  * deal in the Software without restriction, including without limitation the
9  * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
10  * sell copies of the Software, and to permit persons to whom the Software is
11  * furnished to do so, subject to the following conditions:
12  *
13  * The above copyright notice and this permission notice shall be included in all
14  * copies or substantial portions of the Software.
15  *
16  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22  * SOFTWARE.
23  */
24
25 #include <cassert>
26 #include <map>
27 #include <mutex>
28
29 #include "private_data.hpp"
30
31 using scoped_mutex = std::lock_guard<std::mutex>;
32
33 namespace layer
34 {
35
36 static std::mutex g_data_lock;
37 static std::map<void *, instance_private_data *> g_instance_data;
38 static std::map<void *, device_private_data *> g_device_data;
39
40 instance_private_data::instance_private_data(VkInstance inst, PFN_vkGetInstanceProcAddr get_proc,
41                                              PFN_vkSetInstanceLoaderData set_loader_data)
42    : disp(inst, get_proc)
43    , SetInstanceLoaderData(set_loader_data)
44 {
45 }
46
47 instance_private_data &instance_private_data::create(VkInstance inst, PFN_vkGetInstanceProcAddr get_proc,
48                                                      PFN_vkSetInstanceLoaderData set_loader_data)
49 {
50    instance_private_data *inst_data = new instance_private_data(inst, get_proc, set_loader_data);
51    scoped_mutex lock(g_data_lock);
52    g_instance_data[get_key(inst)] = inst_data;
53    return *inst_data;
54 }
55
56 instance_private_data &instance_private_data::get(void *key)
57 {
58    scoped_mutex lock(g_data_lock);
59    instance_private_data *data = g_instance_data[key];
60    assert(data);
61    return *data;
62 }
63
64 void instance_private_data::destroy(VkInstance inst)
65 {
66    instance_private_data *data;
67    {
68       scoped_mutex lock(g_data_lock);
69       data = g_instance_data[get_key(inst)];
70       assert(data);
71       g_instance_data.erase(get_key(inst));
72    }
73    delete data;
74 }
75
76 device_private_data::device_private_data(VkDevice dev, PFN_vkGetDeviceProcAddr get_proc,
77                                          instance_private_data &inst_data, PFN_vkSetDeviceLoaderData set_loader_data)
78    : disp(dev, get_proc)
79    , instance_data(inst_data)
80    , SetDeviceLoaderData(set_loader_data)
81 {
82 }
83
84 device_private_data &device_private_data::create(VkDevice dev, PFN_vkGetDeviceProcAddr get_proc,
85                                                  VkPhysicalDevice phys_dev, PFN_vkSetDeviceLoaderData set_loader_data)
86 {
87    device_private_data *dev_data =
88       new device_private_data(dev, get_proc, instance_private_data::get(get_key(phys_dev)), set_loader_data);
89    scoped_mutex lock(g_data_lock);
90    g_device_data[get_key(dev)] = dev_data;
91 }
92
93 device_private_data &device_private_data::get(void *key)
94 {
95    scoped_mutex lock(g_data_lock);
96    device_private_data *data = g_device_data[key];
97    assert(data);
98    return *data;
99 }
100
101 void device_private_data::destroy(VkDevice dev)
102 {
103    device_private_data *data;
104    {
105       scoped_mutex lock(g_data_lock);
106       data = g_device_data[get_key(dev)];
107       g_device_data.erase(get_key(dev));
108    }
109    delete data;
110 }
111
112 } /* namespace layer */