blob: 1924b6edc8393e1deab2dd4e04fdc37e1289ba17 [file] [log] [blame]
// Copyright 2018 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "ui/ozone/platform/drm/gpu/drm_gpu_util.h"
#include <xf86drmMode.h>
#include "base/trace_event/trace_event.h"
#include "ui/display/types/gamma_ramp_rgb_entry.h"
#include "ui/ozone/platform/drm/gpu/drm_device.h"
namespace ui {
bool GetDrmPropertyForName(DrmDevice* drm,
drmModeObjectProperties* properties,
const std::string& name,
DrmDevice::Property* property) {
for (uint32_t i = 0; i < properties->count_props; ++i) {
ScopedDrmPropertyPtr drm_property(drm->GetProperty(properties->props[i]));
if (name != drm_property->name)
continue;
property->id = drm_property->prop_id;
property->value = properties->prop_values[i];
if (property->id)
return true;
}
return false;
}
ScopedDrmColorLutPtr CreateLutBlob(
const std::vector<display::GammaRampRGBEntry>& source) {
TRACE_EVENT0("drm", "CreateLutBlob");
if (source.empty())
return nullptr;
ScopedDrmColorLutPtr lut(static_cast<drm_color_lut*>(
malloc(sizeof(drm_color_lut) * source.size())));
drm_color_lut* p = lut.get();
for (size_t i = 0; i < source.size(); ++i) {
p[i].red = source[i].r;
p[i].green = source[i].g;
p[i].blue = source[i].b;
}
return lut;
}
ScopedDrmColorCtmPtr CreateCTMBlob(const std::vector<float>& color_matrix) {
if (color_matrix.empty())
return nullptr;
ScopedDrmColorCtmPtr ctm(
static_cast<drm_color_ctm*>(malloc(sizeof(drm_color_ctm))));
DCHECK_EQ(color_matrix.size(), base::size(ctm->matrix));
for (size_t i = 0; i < base::size(ctm->matrix); ++i) {
if (color_matrix[i] < 0) {
ctm->matrix[i] = static_cast<uint64_t>(-color_matrix[i] * (1ull << 32));
ctm->matrix[i] |= static_cast<uint64_t>(1) << 63;
} else {
ctm->matrix[i] = static_cast<uint64_t>(color_matrix[i] * (1ull << 32));
}
}
return ctm;
}
std::vector<display::GammaRampRGBEntry> ResampleLut(
const std::vector<display::GammaRampRGBEntry>& lut_in,
size_t desired_size) {
TRACE_EVENT1("drm", "ResampleLut", "desired_size", desired_size);
if (lut_in.empty())
return std::vector<display::GammaRampRGBEntry>();
if (lut_in.size() == desired_size)
return lut_in;
std::vector<display::GammaRampRGBEntry> result;
result.resize(desired_size);
for (size_t i = 0; i < desired_size; ++i) {
size_t base_index = lut_in.size() * i / desired_size;
size_t remaining = lut_in.size() * i % desired_size;
if (base_index < lut_in.size() - 1) {
result[i].r = lut_in[base_index].r +
(lut_in[base_index + 1].r - lut_in[base_index].r) *
remaining / desired_size;
result[i].g = lut_in[base_index].g +
(lut_in[base_index + 1].g - lut_in[base_index].g) *
remaining / desired_size;
result[i].b = lut_in[base_index].b +
(lut_in[base_index + 1].b - lut_in[base_index].b) *
remaining / desired_size;
} else {
result[i] = lut_in.back();
}
}
return result;
}
} // namespace ui