2
* Copyright © 2013 Canonical Ltd.
4
* This program is free software: you can redistribute it and/or modify it
5
* under the terms of the GNU Lesser General Public License version 3,
6
* as published by the Free Software Foundation.
8
* This program is distributed in the hope that it will be useful,
9
* but WITHOUT ANY WARRANTY; without even the implied warranty of
10
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11
* GNU Lesser General Public License for more details.
13
* You should have received a copy of the GNU Lesser General Public License
14
* along with this program. If not, see <http://www.gnu.org/licenses/>.
16
* Authored by: Alexandros Frantzis <alexandros.frantzis@canonical.com>
19
#include "real_kms_output_container.h"
20
#include "real_kms_output.h"
22
namespace mgm = mir::graphics::mesa;
24
mgm::RealKMSOutputContainer::RealKMSOutputContainer(
25
int drm_fd, std::shared_ptr<PageFlipper> const& page_flipper)
27
page_flipper{page_flipper}
31
std::shared_ptr<mgm::KMSOutput>
32
mgm::RealKMSOutputContainer::get_kms_output_for(uint32_t connector_id)
34
std::shared_ptr<KMSOutput> output;
36
auto output_iter = outputs.find(connector_id);
37
if (output_iter == outputs.end())
39
output = std::make_shared<RealKMSOutput>(drm_fd, connector_id, page_flipper);
40
outputs[connector_id] = output;
44
output = output_iter->second;
50
void mgm::RealKMSOutputContainer::for_each_output(std::function<void(KMSOutput&)> functor) const
52
for(auto& pair: outputs)
53
functor(*pair.second);