Anforderungen  |   Konzepte  |   Entwurf  |   Entwicklung  |   Qualitätssicherung  |   Lebenszyklus  |   Steuerung
 
 
 
 


Quelle  dcss-kms.c   Sprache: C

 
// SPDX-License-Identifier: GPL-2.0
/*
 * Copyright 2019 NXP.
 */


#include <drm/clients/drm_client_setup.h>
#include <drm/drm_atomic.h>
#include <drm/drm_atomic_helper.h>
#include <drm/drm_bridge.h>
#include <drm/drm_bridge_connector.h>
#include <drm/drm_drv.h>
#include <drm/drm_fbdev_dma.h>
#include <drm/drm_gem_dma_helper.h>
#include <drm/drm_gem_framebuffer_helper.h>
#include <drm/drm_of.h>
#include <drm/drm_probe_helper.h>
#include <drm/drm_vblank.h>

#include "dcss-dev.h"
#include "dcss-kms.h"

DEFINE_DRM_GEM_DMA_FOPS(dcss_cma_fops);

static const struct drm_mode_config_funcs dcss_drm_mode_config_funcs = {
 .fb_create = drm_gem_fb_create,
 .atomic_check = drm_atomic_helper_check,
 .atomic_commit = drm_atomic_helper_commit,
};

static const struct drm_driver dcss_kms_driver = {
 .driver_features = DRIVER_MODESET | DRIVER_GEM | DRIVER_ATOMIC,
 DRM_GEM_DMA_DRIVER_OPS,
 DRM_FBDEV_DMA_DRIVER_OPS,
 .fops   = &dcss_cma_fops,
 .name   = "imx-dcss",
 .desc   = "i.MX8MQ Display Subsystem",
 .major   = 1,
 .minor   = 0,
 .patchlevel  = 0,
};

static const struct drm_mode_config_helper_funcs dcss_mode_config_helpers = {
 .atomic_commit_tail = drm_atomic_helper_commit_tail_rpm,
};

static void dcss_kms_mode_config_init(struct dcss_kms_dev *kms)
{
 struct drm_mode_config *config = &kms->base.mode_config;

 drm_mode_config_init(&kms->base);

 config->min_width = 1;
 config->min_height = 1;
 config->max_width = 4096;
 config->max_height = 4096;
 config->normalize_zpos = true;

 config->funcs = &dcss_drm_mode_config_funcs;
 config->helper_private = &dcss_mode_config_helpers;
}

static const struct drm_encoder_funcs dcss_kms_simple_encoder_funcs = {
 .destroy = drm_encoder_cleanup,
};

static int dcss_kms_bridge_connector_init(struct dcss_kms_dev *kms)
{
 struct drm_device *ddev = &kms->base;
 struct drm_encoder *encoder = &kms->encoder;
 struct drm_crtc *crtc = (struct drm_crtc *)&kms->crtc;
 struct drm_panel *panel;
 struct drm_bridge *bridge;
 int ret;

 ret = drm_of_find_panel_or_bridge(ddev->dev->of_node, 0, 0,
       &panel, &bridge);
 if (ret)
  return ret;

 if (!bridge) {
  dev_err(ddev->dev, "No bridge found %d.\n", ret);
  return -ENODEV;
 }

 encoder->possible_crtcs = drm_crtc_mask(crtc);

 ret = drm_encoder_init(&kms->base, encoder,
          &dcss_kms_simple_encoder_funcs,
          DRM_MODE_ENCODER_NONE, NULL);
 if (ret) {
  dev_err(ddev->dev, "Failed initializing encoder %d.\n", ret);
  return ret;
 }

 ret = drm_bridge_attach(encoder, bridge, NULL,
    DRM_BRIDGE_ATTACH_NO_CONNECTOR);
 if (ret < 0)
  return ret;

 kms->connector = drm_bridge_connector_init(ddev, encoder);
 if (IS_ERR(kms->connector)) {
  dev_err(ddev->dev, "Unable to create bridge connector.\n");
  return PTR_ERR(kms->connector);
 }

 drm_connector_attach_encoder(kms->connector, encoder);

 return 0;
}

struct dcss_kms_dev *dcss_kms_attach(struct dcss_dev *dcss)
{
 struct dcss_kms_dev *kms;
 struct drm_device *drm;
 struct dcss_crtc *crtc;
 int ret;

 kms = devm_drm_dev_alloc(dcss->dev, &dcss_kms_driver,
     struct dcss_kms_dev, base);
 if (IS_ERR(kms))
  return kms;

 drm = &kms->base;
 crtc = &kms->crtc;

 drm->dev_private = dcss;

 dcss_kms_mode_config_init(kms);

 ret = drm_vblank_init(drm, 1);
 if (ret)
  goto cleanup_mode_config;

 ret = dcss_kms_bridge_connector_init(kms);
 if (ret)
  goto cleanup_mode_config;

 ret = dcss_crtc_init(crtc, drm);
 if (ret)
  goto cleanup_mode_config;

 drm_mode_config_reset(drm);

 drm_kms_helper_poll_init(drm);

 ret = drm_dev_register(drm, 0);
 if (ret)
  goto cleanup_crtc;

 drm_client_setup(drm, NULL);

 return kms;

cleanup_crtc:
 drm_kms_helper_poll_fini(drm);
 dcss_crtc_deinit(crtc, drm);

cleanup_mode_config:
 drm_mode_config_cleanup(drm);
 drm->dev_private = NULL;

 return ERR_PTR(ret);
}

void dcss_kms_detach(struct dcss_kms_dev *kms)
{
 struct drm_device *drm = &kms->base;

 drm_dev_unregister(drm);
 drm_kms_helper_poll_fini(drm);
 drm_atomic_helper_shutdown(drm);
 drm_crtc_vblank_off(&kms->crtc.base);
 drm_mode_config_cleanup(drm);
 dcss_crtc_deinit(&kms->crtc, drm);
 drm->dev_private = NULL;
}

void dcss_kms_shutdown(struct dcss_kms_dev *kms)
{
 struct drm_device *drm = &kms->base;

 drm_atomic_helper_shutdown(drm);
}

Messung V0.5
C=93 H=92 G=92

¤ Dauer der Verarbeitung: 0.10 Sekunden  (vorverarbeitet)  ¤

*© Formatika GbR, Deutschland






Wurzel

Suchen

Beweissystem der NASA

Beweissystem Isabelle

NIST Cobol Testsuite

Cephes Mathematical Library

Wiener Entwicklungsmethode

Haftungshinweis

Die Informationen auf dieser Webseite wurden nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit, noch Qualität der bereit gestellten Informationen zugesichert.

Bemerkung:

Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.






                                                                                                                                                                                                                                                                                                                                                                                                     


Neuigkeiten

     Aktuelles
     Motto des Tages

Software

     Produkte
     Quellcodebibliothek

Aktivitäten

     Artikel über Sicherheit
     Anleitung zur Aktivierung von SSL

Muße

     Gedichte
     Musik
     Bilder

Jenseits des Üblichen ....
    

Besucherstatistik

Besucherstatistik

Monitoring

Montastic status badge