162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright (C) 2009 Nokia Corporation 462306a36Sopenharmony_ci * Author: Tomi Valkeinen <tomi.valkeinen@nokia.com> 562306a36Sopenharmony_ci * 662306a36Sopenharmony_ci * Some code and ideas taken from drivers/video/omap/ driver 762306a36Sopenharmony_ci * by Imre Deak. 862306a36Sopenharmony_ci */ 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci#define DSS_SUBSYS_NAME "MANAGER" 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ci#include <linux/kernel.h> 1362306a36Sopenharmony_ci#include <linux/kstrtox.h> 1462306a36Sopenharmony_ci#include <linux/slab.h> 1562306a36Sopenharmony_ci#include <linux/module.h> 1662306a36Sopenharmony_ci#include <linux/platform_device.h> 1762306a36Sopenharmony_ci#include <linux/jiffies.h> 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_ci#include <video/omapfb_dss.h> 2062306a36Sopenharmony_ci 2162306a36Sopenharmony_ci#include "dss.h" 2262306a36Sopenharmony_ci#include "dss_features.h" 2362306a36Sopenharmony_ci 2462306a36Sopenharmony_cistatic ssize_t manager_name_show(struct omap_overlay_manager *mgr, char *buf) 2562306a36Sopenharmony_ci{ 2662306a36Sopenharmony_ci return sysfs_emit(buf, "%s\n", mgr->name); 2762306a36Sopenharmony_ci} 2862306a36Sopenharmony_ci 2962306a36Sopenharmony_cistatic ssize_t manager_display_show(struct omap_overlay_manager *mgr, char *buf) 3062306a36Sopenharmony_ci{ 3162306a36Sopenharmony_ci struct omap_dss_device *dssdev = mgr->get_device(mgr); 3262306a36Sopenharmony_ci 3362306a36Sopenharmony_ci return sysfs_emit(buf, "%s\n", dssdev ? 3462306a36Sopenharmony_ci dssdev->name : "<none>"); 3562306a36Sopenharmony_ci} 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_cistatic int manager_display_match(struct omap_dss_device *dssdev, void *data) 3862306a36Sopenharmony_ci{ 3962306a36Sopenharmony_ci const char *str = data; 4062306a36Sopenharmony_ci 4162306a36Sopenharmony_ci return sysfs_streq(dssdev->name, str); 4262306a36Sopenharmony_ci} 4362306a36Sopenharmony_ci 4462306a36Sopenharmony_cistatic ssize_t manager_display_store(struct omap_overlay_manager *mgr, 4562306a36Sopenharmony_ci const char *buf, size_t size) 4662306a36Sopenharmony_ci{ 4762306a36Sopenharmony_ci int r = 0; 4862306a36Sopenharmony_ci size_t len = size; 4962306a36Sopenharmony_ci struct omap_dss_device *dssdev = NULL; 5062306a36Sopenharmony_ci struct omap_dss_device *old_dssdev; 5162306a36Sopenharmony_ci 5262306a36Sopenharmony_ci if (buf[size-1] == '\n') 5362306a36Sopenharmony_ci --len; 5462306a36Sopenharmony_ci 5562306a36Sopenharmony_ci if (len > 0) 5662306a36Sopenharmony_ci dssdev = omap_dss_find_device((void *)buf, 5762306a36Sopenharmony_ci manager_display_match); 5862306a36Sopenharmony_ci 5962306a36Sopenharmony_ci if (len > 0 && dssdev == NULL) 6062306a36Sopenharmony_ci return -EINVAL; 6162306a36Sopenharmony_ci 6262306a36Sopenharmony_ci if (dssdev) { 6362306a36Sopenharmony_ci DSSDBG("display %s found\n", dssdev->name); 6462306a36Sopenharmony_ci 6562306a36Sopenharmony_ci if (omapdss_device_is_connected(dssdev)) { 6662306a36Sopenharmony_ci DSSERR("new display is already connected\n"); 6762306a36Sopenharmony_ci r = -EINVAL; 6862306a36Sopenharmony_ci goto put_device; 6962306a36Sopenharmony_ci } 7062306a36Sopenharmony_ci 7162306a36Sopenharmony_ci if (omapdss_device_is_enabled(dssdev)) { 7262306a36Sopenharmony_ci DSSERR("new display is not disabled\n"); 7362306a36Sopenharmony_ci r = -EINVAL; 7462306a36Sopenharmony_ci goto put_device; 7562306a36Sopenharmony_ci } 7662306a36Sopenharmony_ci } 7762306a36Sopenharmony_ci 7862306a36Sopenharmony_ci old_dssdev = mgr->get_device(mgr); 7962306a36Sopenharmony_ci if (old_dssdev) { 8062306a36Sopenharmony_ci if (omapdss_device_is_enabled(old_dssdev)) { 8162306a36Sopenharmony_ci DSSERR("old display is not disabled\n"); 8262306a36Sopenharmony_ci r = -EINVAL; 8362306a36Sopenharmony_ci goto put_device; 8462306a36Sopenharmony_ci } 8562306a36Sopenharmony_ci 8662306a36Sopenharmony_ci old_dssdev->driver->disconnect(old_dssdev); 8762306a36Sopenharmony_ci } 8862306a36Sopenharmony_ci 8962306a36Sopenharmony_ci if (dssdev) { 9062306a36Sopenharmony_ci r = dssdev->driver->connect(dssdev); 9162306a36Sopenharmony_ci if (r) { 9262306a36Sopenharmony_ci DSSERR("failed to connect new device\n"); 9362306a36Sopenharmony_ci goto put_device; 9462306a36Sopenharmony_ci } 9562306a36Sopenharmony_ci 9662306a36Sopenharmony_ci old_dssdev = mgr->get_device(mgr); 9762306a36Sopenharmony_ci if (old_dssdev != dssdev) { 9862306a36Sopenharmony_ci DSSERR("failed to connect device to this manager\n"); 9962306a36Sopenharmony_ci dssdev->driver->disconnect(dssdev); 10062306a36Sopenharmony_ci goto put_device; 10162306a36Sopenharmony_ci } 10262306a36Sopenharmony_ci 10362306a36Sopenharmony_ci r = mgr->apply(mgr); 10462306a36Sopenharmony_ci if (r) { 10562306a36Sopenharmony_ci DSSERR("failed to apply dispc config\n"); 10662306a36Sopenharmony_ci goto put_device; 10762306a36Sopenharmony_ci } 10862306a36Sopenharmony_ci } 10962306a36Sopenharmony_ci 11062306a36Sopenharmony_ciput_device: 11162306a36Sopenharmony_ci if (dssdev) 11262306a36Sopenharmony_ci omap_dss_put_device(dssdev); 11362306a36Sopenharmony_ci 11462306a36Sopenharmony_ci return r ? r : size; 11562306a36Sopenharmony_ci} 11662306a36Sopenharmony_ci 11762306a36Sopenharmony_cistatic ssize_t manager_default_color_show(struct omap_overlay_manager *mgr, 11862306a36Sopenharmony_ci char *buf) 11962306a36Sopenharmony_ci{ 12062306a36Sopenharmony_ci struct omap_overlay_manager_info info; 12162306a36Sopenharmony_ci 12262306a36Sopenharmony_ci mgr->get_manager_info(mgr, &info); 12362306a36Sopenharmony_ci 12462306a36Sopenharmony_ci return sysfs_emit(buf, "%#x\n", info.default_color); 12562306a36Sopenharmony_ci} 12662306a36Sopenharmony_ci 12762306a36Sopenharmony_cistatic ssize_t manager_default_color_store(struct omap_overlay_manager *mgr, 12862306a36Sopenharmony_ci const char *buf, size_t size) 12962306a36Sopenharmony_ci{ 13062306a36Sopenharmony_ci struct omap_overlay_manager_info info; 13162306a36Sopenharmony_ci u32 color; 13262306a36Sopenharmony_ci int r; 13362306a36Sopenharmony_ci 13462306a36Sopenharmony_ci r = kstrtouint(buf, 0, &color); 13562306a36Sopenharmony_ci if (r) 13662306a36Sopenharmony_ci return r; 13762306a36Sopenharmony_ci 13862306a36Sopenharmony_ci mgr->get_manager_info(mgr, &info); 13962306a36Sopenharmony_ci 14062306a36Sopenharmony_ci info.default_color = color; 14162306a36Sopenharmony_ci 14262306a36Sopenharmony_ci r = mgr->set_manager_info(mgr, &info); 14362306a36Sopenharmony_ci if (r) 14462306a36Sopenharmony_ci return r; 14562306a36Sopenharmony_ci 14662306a36Sopenharmony_ci r = mgr->apply(mgr); 14762306a36Sopenharmony_ci if (r) 14862306a36Sopenharmony_ci return r; 14962306a36Sopenharmony_ci 15062306a36Sopenharmony_ci return size; 15162306a36Sopenharmony_ci} 15262306a36Sopenharmony_ci 15362306a36Sopenharmony_cistatic const char *trans_key_type_str[] = { 15462306a36Sopenharmony_ci "gfx-destination", 15562306a36Sopenharmony_ci "video-source", 15662306a36Sopenharmony_ci}; 15762306a36Sopenharmony_ci 15862306a36Sopenharmony_cistatic ssize_t manager_trans_key_type_show(struct omap_overlay_manager *mgr, 15962306a36Sopenharmony_ci char *buf) 16062306a36Sopenharmony_ci{ 16162306a36Sopenharmony_ci enum omap_dss_trans_key_type key_type; 16262306a36Sopenharmony_ci struct omap_overlay_manager_info info; 16362306a36Sopenharmony_ci 16462306a36Sopenharmony_ci mgr->get_manager_info(mgr, &info); 16562306a36Sopenharmony_ci 16662306a36Sopenharmony_ci key_type = info.trans_key_type; 16762306a36Sopenharmony_ci BUG_ON(key_type >= ARRAY_SIZE(trans_key_type_str)); 16862306a36Sopenharmony_ci 16962306a36Sopenharmony_ci return sysfs_emit(buf, "%s\n", trans_key_type_str[key_type]); 17062306a36Sopenharmony_ci} 17162306a36Sopenharmony_ci 17262306a36Sopenharmony_cistatic ssize_t manager_trans_key_type_store(struct omap_overlay_manager *mgr, 17362306a36Sopenharmony_ci const char *buf, size_t size) 17462306a36Sopenharmony_ci{ 17562306a36Sopenharmony_ci struct omap_overlay_manager_info info; 17662306a36Sopenharmony_ci int r; 17762306a36Sopenharmony_ci 17862306a36Sopenharmony_ci r = sysfs_match_string(trans_key_type_str, buf); 17962306a36Sopenharmony_ci if (r < 0) 18062306a36Sopenharmony_ci return r; 18162306a36Sopenharmony_ci 18262306a36Sopenharmony_ci mgr->get_manager_info(mgr, &info); 18362306a36Sopenharmony_ci 18462306a36Sopenharmony_ci info.trans_key_type = r; 18562306a36Sopenharmony_ci 18662306a36Sopenharmony_ci r = mgr->set_manager_info(mgr, &info); 18762306a36Sopenharmony_ci if (r) 18862306a36Sopenharmony_ci return r; 18962306a36Sopenharmony_ci 19062306a36Sopenharmony_ci r = mgr->apply(mgr); 19162306a36Sopenharmony_ci if (r) 19262306a36Sopenharmony_ci return r; 19362306a36Sopenharmony_ci 19462306a36Sopenharmony_ci return size; 19562306a36Sopenharmony_ci} 19662306a36Sopenharmony_ci 19762306a36Sopenharmony_cistatic ssize_t manager_trans_key_value_show(struct omap_overlay_manager *mgr, 19862306a36Sopenharmony_ci char *buf) 19962306a36Sopenharmony_ci{ 20062306a36Sopenharmony_ci struct omap_overlay_manager_info info; 20162306a36Sopenharmony_ci 20262306a36Sopenharmony_ci mgr->get_manager_info(mgr, &info); 20362306a36Sopenharmony_ci 20462306a36Sopenharmony_ci return sysfs_emit(buf, "%#x\n", info.trans_key); 20562306a36Sopenharmony_ci} 20662306a36Sopenharmony_ci 20762306a36Sopenharmony_cistatic ssize_t manager_trans_key_value_store(struct omap_overlay_manager *mgr, 20862306a36Sopenharmony_ci const char *buf, size_t size) 20962306a36Sopenharmony_ci{ 21062306a36Sopenharmony_ci struct omap_overlay_manager_info info; 21162306a36Sopenharmony_ci u32 key_value; 21262306a36Sopenharmony_ci int r; 21362306a36Sopenharmony_ci 21462306a36Sopenharmony_ci r = kstrtouint(buf, 0, &key_value); 21562306a36Sopenharmony_ci if (r) 21662306a36Sopenharmony_ci return r; 21762306a36Sopenharmony_ci 21862306a36Sopenharmony_ci mgr->get_manager_info(mgr, &info); 21962306a36Sopenharmony_ci 22062306a36Sopenharmony_ci info.trans_key = key_value; 22162306a36Sopenharmony_ci 22262306a36Sopenharmony_ci r = mgr->set_manager_info(mgr, &info); 22362306a36Sopenharmony_ci if (r) 22462306a36Sopenharmony_ci return r; 22562306a36Sopenharmony_ci 22662306a36Sopenharmony_ci r = mgr->apply(mgr); 22762306a36Sopenharmony_ci if (r) 22862306a36Sopenharmony_ci return r; 22962306a36Sopenharmony_ci 23062306a36Sopenharmony_ci return size; 23162306a36Sopenharmony_ci} 23262306a36Sopenharmony_ci 23362306a36Sopenharmony_cistatic ssize_t manager_trans_key_enabled_show(struct omap_overlay_manager *mgr, 23462306a36Sopenharmony_ci char *buf) 23562306a36Sopenharmony_ci{ 23662306a36Sopenharmony_ci struct omap_overlay_manager_info info; 23762306a36Sopenharmony_ci 23862306a36Sopenharmony_ci mgr->get_manager_info(mgr, &info); 23962306a36Sopenharmony_ci 24062306a36Sopenharmony_ci return sysfs_emit(buf, "%d\n", info.trans_enabled); 24162306a36Sopenharmony_ci} 24262306a36Sopenharmony_ci 24362306a36Sopenharmony_cistatic ssize_t manager_trans_key_enabled_store(struct omap_overlay_manager *mgr, 24462306a36Sopenharmony_ci const char *buf, size_t size) 24562306a36Sopenharmony_ci{ 24662306a36Sopenharmony_ci struct omap_overlay_manager_info info; 24762306a36Sopenharmony_ci bool enable; 24862306a36Sopenharmony_ci int r; 24962306a36Sopenharmony_ci 25062306a36Sopenharmony_ci r = kstrtobool(buf, &enable); 25162306a36Sopenharmony_ci if (r) 25262306a36Sopenharmony_ci return r; 25362306a36Sopenharmony_ci 25462306a36Sopenharmony_ci mgr->get_manager_info(mgr, &info); 25562306a36Sopenharmony_ci 25662306a36Sopenharmony_ci info.trans_enabled = enable; 25762306a36Sopenharmony_ci 25862306a36Sopenharmony_ci r = mgr->set_manager_info(mgr, &info); 25962306a36Sopenharmony_ci if (r) 26062306a36Sopenharmony_ci return r; 26162306a36Sopenharmony_ci 26262306a36Sopenharmony_ci r = mgr->apply(mgr); 26362306a36Sopenharmony_ci if (r) 26462306a36Sopenharmony_ci return r; 26562306a36Sopenharmony_ci 26662306a36Sopenharmony_ci return size; 26762306a36Sopenharmony_ci} 26862306a36Sopenharmony_ci 26962306a36Sopenharmony_cistatic ssize_t manager_alpha_blending_enabled_show( 27062306a36Sopenharmony_ci struct omap_overlay_manager *mgr, char *buf) 27162306a36Sopenharmony_ci{ 27262306a36Sopenharmony_ci struct omap_overlay_manager_info info; 27362306a36Sopenharmony_ci 27462306a36Sopenharmony_ci if(!dss_has_feature(FEAT_ALPHA_FIXED_ZORDER)) 27562306a36Sopenharmony_ci return -ENODEV; 27662306a36Sopenharmony_ci 27762306a36Sopenharmony_ci mgr->get_manager_info(mgr, &info); 27862306a36Sopenharmony_ci 27962306a36Sopenharmony_ci return sysfs_emit(buf, "%d\n", 28062306a36Sopenharmony_ci info.partial_alpha_enabled); 28162306a36Sopenharmony_ci} 28262306a36Sopenharmony_ci 28362306a36Sopenharmony_cistatic ssize_t manager_alpha_blending_enabled_store( 28462306a36Sopenharmony_ci struct omap_overlay_manager *mgr, 28562306a36Sopenharmony_ci const char *buf, size_t size) 28662306a36Sopenharmony_ci{ 28762306a36Sopenharmony_ci struct omap_overlay_manager_info info; 28862306a36Sopenharmony_ci bool enable; 28962306a36Sopenharmony_ci int r; 29062306a36Sopenharmony_ci 29162306a36Sopenharmony_ci if(!dss_has_feature(FEAT_ALPHA_FIXED_ZORDER)) 29262306a36Sopenharmony_ci return -ENODEV; 29362306a36Sopenharmony_ci 29462306a36Sopenharmony_ci r = kstrtobool(buf, &enable); 29562306a36Sopenharmony_ci if (r) 29662306a36Sopenharmony_ci return r; 29762306a36Sopenharmony_ci 29862306a36Sopenharmony_ci mgr->get_manager_info(mgr, &info); 29962306a36Sopenharmony_ci 30062306a36Sopenharmony_ci info.partial_alpha_enabled = enable; 30162306a36Sopenharmony_ci 30262306a36Sopenharmony_ci r = mgr->set_manager_info(mgr, &info); 30362306a36Sopenharmony_ci if (r) 30462306a36Sopenharmony_ci return r; 30562306a36Sopenharmony_ci 30662306a36Sopenharmony_ci r = mgr->apply(mgr); 30762306a36Sopenharmony_ci if (r) 30862306a36Sopenharmony_ci return r; 30962306a36Sopenharmony_ci 31062306a36Sopenharmony_ci return size; 31162306a36Sopenharmony_ci} 31262306a36Sopenharmony_ci 31362306a36Sopenharmony_cistatic ssize_t manager_cpr_enable_show(struct omap_overlay_manager *mgr, 31462306a36Sopenharmony_ci char *buf) 31562306a36Sopenharmony_ci{ 31662306a36Sopenharmony_ci struct omap_overlay_manager_info info; 31762306a36Sopenharmony_ci 31862306a36Sopenharmony_ci mgr->get_manager_info(mgr, &info); 31962306a36Sopenharmony_ci 32062306a36Sopenharmony_ci return sysfs_emit(buf, "%d\n", info.cpr_enable); 32162306a36Sopenharmony_ci} 32262306a36Sopenharmony_ci 32362306a36Sopenharmony_cistatic ssize_t manager_cpr_enable_store(struct omap_overlay_manager *mgr, 32462306a36Sopenharmony_ci const char *buf, size_t size) 32562306a36Sopenharmony_ci{ 32662306a36Sopenharmony_ci struct omap_overlay_manager_info info; 32762306a36Sopenharmony_ci int r; 32862306a36Sopenharmony_ci bool enable; 32962306a36Sopenharmony_ci 33062306a36Sopenharmony_ci if (!dss_has_feature(FEAT_CPR)) 33162306a36Sopenharmony_ci return -ENODEV; 33262306a36Sopenharmony_ci 33362306a36Sopenharmony_ci r = kstrtobool(buf, &enable); 33462306a36Sopenharmony_ci if (r) 33562306a36Sopenharmony_ci return r; 33662306a36Sopenharmony_ci 33762306a36Sopenharmony_ci mgr->get_manager_info(mgr, &info); 33862306a36Sopenharmony_ci 33962306a36Sopenharmony_ci if (info.cpr_enable == enable) 34062306a36Sopenharmony_ci return size; 34162306a36Sopenharmony_ci 34262306a36Sopenharmony_ci info.cpr_enable = enable; 34362306a36Sopenharmony_ci 34462306a36Sopenharmony_ci r = mgr->set_manager_info(mgr, &info); 34562306a36Sopenharmony_ci if (r) 34662306a36Sopenharmony_ci return r; 34762306a36Sopenharmony_ci 34862306a36Sopenharmony_ci r = mgr->apply(mgr); 34962306a36Sopenharmony_ci if (r) 35062306a36Sopenharmony_ci return r; 35162306a36Sopenharmony_ci 35262306a36Sopenharmony_ci return size; 35362306a36Sopenharmony_ci} 35462306a36Sopenharmony_ci 35562306a36Sopenharmony_cistatic ssize_t manager_cpr_coef_show(struct omap_overlay_manager *mgr, 35662306a36Sopenharmony_ci char *buf) 35762306a36Sopenharmony_ci{ 35862306a36Sopenharmony_ci struct omap_overlay_manager_info info; 35962306a36Sopenharmony_ci 36062306a36Sopenharmony_ci mgr->get_manager_info(mgr, &info); 36162306a36Sopenharmony_ci 36262306a36Sopenharmony_ci return sysfs_emit(buf, 36362306a36Sopenharmony_ci "%d %d %d %d %d %d %d %d %d\n", 36462306a36Sopenharmony_ci info.cpr_coefs.rr, 36562306a36Sopenharmony_ci info.cpr_coefs.rg, 36662306a36Sopenharmony_ci info.cpr_coefs.rb, 36762306a36Sopenharmony_ci info.cpr_coefs.gr, 36862306a36Sopenharmony_ci info.cpr_coefs.gg, 36962306a36Sopenharmony_ci info.cpr_coefs.gb, 37062306a36Sopenharmony_ci info.cpr_coefs.br, 37162306a36Sopenharmony_ci info.cpr_coefs.bg, 37262306a36Sopenharmony_ci info.cpr_coefs.bb); 37362306a36Sopenharmony_ci} 37462306a36Sopenharmony_ci 37562306a36Sopenharmony_cistatic ssize_t manager_cpr_coef_store(struct omap_overlay_manager *mgr, 37662306a36Sopenharmony_ci const char *buf, size_t size) 37762306a36Sopenharmony_ci{ 37862306a36Sopenharmony_ci struct omap_overlay_manager_info info; 37962306a36Sopenharmony_ci struct omap_dss_cpr_coefs coefs; 38062306a36Sopenharmony_ci int r, i; 38162306a36Sopenharmony_ci s16 *arr; 38262306a36Sopenharmony_ci 38362306a36Sopenharmony_ci if (!dss_has_feature(FEAT_CPR)) 38462306a36Sopenharmony_ci return -ENODEV; 38562306a36Sopenharmony_ci 38662306a36Sopenharmony_ci if (sscanf(buf, "%hd %hd %hd %hd %hd %hd %hd %hd %hd", 38762306a36Sopenharmony_ci &coefs.rr, &coefs.rg, &coefs.rb, 38862306a36Sopenharmony_ci &coefs.gr, &coefs.gg, &coefs.gb, 38962306a36Sopenharmony_ci &coefs.br, &coefs.bg, &coefs.bb) != 9) 39062306a36Sopenharmony_ci return -EINVAL; 39162306a36Sopenharmony_ci 39262306a36Sopenharmony_ci arr = (s16[]){ coefs.rr, coefs.rg, coefs.rb, 39362306a36Sopenharmony_ci coefs.gr, coefs.gg, coefs.gb, 39462306a36Sopenharmony_ci coefs.br, coefs.bg, coefs.bb }; 39562306a36Sopenharmony_ci 39662306a36Sopenharmony_ci for (i = 0; i < 9; ++i) { 39762306a36Sopenharmony_ci if (arr[i] < -512 || arr[i] > 511) 39862306a36Sopenharmony_ci return -EINVAL; 39962306a36Sopenharmony_ci } 40062306a36Sopenharmony_ci 40162306a36Sopenharmony_ci mgr->get_manager_info(mgr, &info); 40262306a36Sopenharmony_ci 40362306a36Sopenharmony_ci info.cpr_coefs = coefs; 40462306a36Sopenharmony_ci 40562306a36Sopenharmony_ci r = mgr->set_manager_info(mgr, &info); 40662306a36Sopenharmony_ci if (r) 40762306a36Sopenharmony_ci return r; 40862306a36Sopenharmony_ci 40962306a36Sopenharmony_ci r = mgr->apply(mgr); 41062306a36Sopenharmony_ci if (r) 41162306a36Sopenharmony_ci return r; 41262306a36Sopenharmony_ci 41362306a36Sopenharmony_ci return size; 41462306a36Sopenharmony_ci} 41562306a36Sopenharmony_ci 41662306a36Sopenharmony_cistruct manager_attribute { 41762306a36Sopenharmony_ci struct attribute attr; 41862306a36Sopenharmony_ci ssize_t (*show)(struct omap_overlay_manager *, char *); 41962306a36Sopenharmony_ci ssize_t (*store)(struct omap_overlay_manager *, const char *, size_t); 42062306a36Sopenharmony_ci}; 42162306a36Sopenharmony_ci 42262306a36Sopenharmony_ci#define MANAGER_ATTR(_name, _mode, _show, _store) \ 42362306a36Sopenharmony_ci struct manager_attribute manager_attr_##_name = \ 42462306a36Sopenharmony_ci __ATTR(_name, _mode, _show, _store) 42562306a36Sopenharmony_ci 42662306a36Sopenharmony_cistatic MANAGER_ATTR(name, S_IRUGO, manager_name_show, NULL); 42762306a36Sopenharmony_cistatic MANAGER_ATTR(display, S_IRUGO|S_IWUSR, 42862306a36Sopenharmony_ci manager_display_show, manager_display_store); 42962306a36Sopenharmony_cistatic MANAGER_ATTR(default_color, S_IRUGO|S_IWUSR, 43062306a36Sopenharmony_ci manager_default_color_show, manager_default_color_store); 43162306a36Sopenharmony_cistatic MANAGER_ATTR(trans_key_type, S_IRUGO|S_IWUSR, 43262306a36Sopenharmony_ci manager_trans_key_type_show, manager_trans_key_type_store); 43362306a36Sopenharmony_cistatic MANAGER_ATTR(trans_key_value, S_IRUGO|S_IWUSR, 43462306a36Sopenharmony_ci manager_trans_key_value_show, manager_trans_key_value_store); 43562306a36Sopenharmony_cistatic MANAGER_ATTR(trans_key_enabled, S_IRUGO|S_IWUSR, 43662306a36Sopenharmony_ci manager_trans_key_enabled_show, 43762306a36Sopenharmony_ci manager_trans_key_enabled_store); 43862306a36Sopenharmony_cistatic MANAGER_ATTR(alpha_blending_enabled, S_IRUGO|S_IWUSR, 43962306a36Sopenharmony_ci manager_alpha_blending_enabled_show, 44062306a36Sopenharmony_ci manager_alpha_blending_enabled_store); 44162306a36Sopenharmony_cistatic MANAGER_ATTR(cpr_enable, S_IRUGO|S_IWUSR, 44262306a36Sopenharmony_ci manager_cpr_enable_show, 44362306a36Sopenharmony_ci manager_cpr_enable_store); 44462306a36Sopenharmony_cistatic MANAGER_ATTR(cpr_coef, S_IRUGO|S_IWUSR, 44562306a36Sopenharmony_ci manager_cpr_coef_show, 44662306a36Sopenharmony_ci manager_cpr_coef_store); 44762306a36Sopenharmony_ci 44862306a36Sopenharmony_ci 44962306a36Sopenharmony_cistatic struct attribute *manager_sysfs_attrs[] = { 45062306a36Sopenharmony_ci &manager_attr_name.attr, 45162306a36Sopenharmony_ci &manager_attr_display.attr, 45262306a36Sopenharmony_ci &manager_attr_default_color.attr, 45362306a36Sopenharmony_ci &manager_attr_trans_key_type.attr, 45462306a36Sopenharmony_ci &manager_attr_trans_key_value.attr, 45562306a36Sopenharmony_ci &manager_attr_trans_key_enabled.attr, 45662306a36Sopenharmony_ci &manager_attr_alpha_blending_enabled.attr, 45762306a36Sopenharmony_ci &manager_attr_cpr_enable.attr, 45862306a36Sopenharmony_ci &manager_attr_cpr_coef.attr, 45962306a36Sopenharmony_ci NULL 46062306a36Sopenharmony_ci}; 46162306a36Sopenharmony_ciATTRIBUTE_GROUPS(manager_sysfs); 46262306a36Sopenharmony_ci 46362306a36Sopenharmony_cistatic ssize_t manager_attr_show(struct kobject *kobj, struct attribute *attr, 46462306a36Sopenharmony_ci char *buf) 46562306a36Sopenharmony_ci{ 46662306a36Sopenharmony_ci struct omap_overlay_manager *manager; 46762306a36Sopenharmony_ci struct manager_attribute *manager_attr; 46862306a36Sopenharmony_ci 46962306a36Sopenharmony_ci manager = container_of(kobj, struct omap_overlay_manager, kobj); 47062306a36Sopenharmony_ci manager_attr = container_of(attr, struct manager_attribute, attr); 47162306a36Sopenharmony_ci 47262306a36Sopenharmony_ci if (!manager_attr->show) 47362306a36Sopenharmony_ci return -ENOENT; 47462306a36Sopenharmony_ci 47562306a36Sopenharmony_ci return manager_attr->show(manager, buf); 47662306a36Sopenharmony_ci} 47762306a36Sopenharmony_ci 47862306a36Sopenharmony_cistatic ssize_t manager_attr_store(struct kobject *kobj, struct attribute *attr, 47962306a36Sopenharmony_ci const char *buf, size_t size) 48062306a36Sopenharmony_ci{ 48162306a36Sopenharmony_ci struct omap_overlay_manager *manager; 48262306a36Sopenharmony_ci struct manager_attribute *manager_attr; 48362306a36Sopenharmony_ci 48462306a36Sopenharmony_ci manager = container_of(kobj, struct omap_overlay_manager, kobj); 48562306a36Sopenharmony_ci manager_attr = container_of(attr, struct manager_attribute, attr); 48662306a36Sopenharmony_ci 48762306a36Sopenharmony_ci if (!manager_attr->store) 48862306a36Sopenharmony_ci return -ENOENT; 48962306a36Sopenharmony_ci 49062306a36Sopenharmony_ci return manager_attr->store(manager, buf, size); 49162306a36Sopenharmony_ci} 49262306a36Sopenharmony_ci 49362306a36Sopenharmony_cistatic const struct sysfs_ops manager_sysfs_ops = { 49462306a36Sopenharmony_ci .show = manager_attr_show, 49562306a36Sopenharmony_ci .store = manager_attr_store, 49662306a36Sopenharmony_ci}; 49762306a36Sopenharmony_ci 49862306a36Sopenharmony_cistatic struct kobj_type manager_ktype = { 49962306a36Sopenharmony_ci .sysfs_ops = &manager_sysfs_ops, 50062306a36Sopenharmony_ci .default_groups = manager_sysfs_groups, 50162306a36Sopenharmony_ci}; 50262306a36Sopenharmony_ci 50362306a36Sopenharmony_ciint dss_manager_kobj_init(struct omap_overlay_manager *mgr, 50462306a36Sopenharmony_ci struct platform_device *pdev) 50562306a36Sopenharmony_ci{ 50662306a36Sopenharmony_ci return kobject_init_and_add(&mgr->kobj, &manager_ktype, 50762306a36Sopenharmony_ci &pdev->dev.kobj, "manager%d", mgr->id); 50862306a36Sopenharmony_ci} 50962306a36Sopenharmony_ci 51062306a36Sopenharmony_civoid dss_manager_kobj_uninit(struct omap_overlay_manager *mgr) 51162306a36Sopenharmony_ci{ 51262306a36Sopenharmony_ci kobject_del(&mgr->kobj); 51362306a36Sopenharmony_ci kobject_put(&mgr->kobj); 51462306a36Sopenharmony_ci 51562306a36Sopenharmony_ci memset(&mgr->kobj, 0, sizeof(mgr->kobj)); 51662306a36Sopenharmony_ci} 517