RK3399 Android7.1 异形屏修改

属性说明:
persist.sys.framebuffer.xoffset //用来调整水平方向偏移
persist.sys.framebuffer.yoffset //用来调整垂直方向偏移
persist.sys.framebuffer.main //用来设置上层应用的渲染布局,这个属性值与裁剪屏尺寸相关,例如可显示区域为 1920x400,那么就设置为 1920x400@60 即可。
sys.hwc.compose_policy=0 //裁剪屏建议关闭HWC,否则在一些场景显示会出现偏差出现抖屏的情况,修改方法可将build.prop文件中的该字段修改为 0,默认值为 6

 

HWC_DISPLAY_PRIMARY = 0,
HWC_DISPLAY_EXTERNAL = 1, // HDMI, EDP

 

hardware\rockchip\hwcomposer\hwcomposer.cpp 

static int hwc_get_display_configs(struct hwc_composer_device_1 *dev,
                                   int display, uint32_t *configs,
                                   size_t *num_configs) {
  if (!num_configs)
    return 0;

  struct hwc_context_t *ctx = (struct hwc_context_t *)&dev->common;
  DrmConnector *connector = ctx->drm.GetConnectorFromType(display);
  if (!connector) {
    ALOGE("%s:Failed to get connector for display %d line=%d", __FUNCTION__,display,__LINE__);
    return -ENODEV;
  }

  hwc_drm_display_t *hd = &ctx->displays[connector->display()];
  if (!hd->active)
    return -ENODEV;

  int ret = connector->UpdateModes();
  if (ret) {
    ALOGE("Failed to update display modes %d", ret);
    return ret;
  }

  if (connector->state() != DRM_MODE_CONNECTED && display == HWC_DISPLAY_EXTERNAL) {
    ALOGE("connector is not connected with display %d", display);
    return -ENODEV;
  }

  update_display_bestmode(hd, display, connector);
  DrmMode mode = connector->best_mode();
  connector->set_current_mode(mode);

  char framebuffer_size[PROPERTY_VALUE_MAX];
  uint32_t width = 0, height = 0 , vrefresh = 0 ;
  if (display == HWC_DISPLAY_PRIMARY)
    property_get("persist." PROPERTY_TYPE ".framebuffer.main", framebuffer_size, "use_baseparameter");
  else if(display == HWC_DISPLAY_EXTERNAL)
    property_get("persist." PROPERTY_TYPE ".framebuffer.aux", framebuffer_size, "use_baseparameter");

android7.1_异形屏修改

0.dts中配置1920x1080的分辨率
1.build.prop添加下面属性:
persist.sys.framebuffer.main=1920x600@60  
2.hardware/rockchip/hwcomposer合入下面修改:
diff --git a/hwcomposer.cpp b/hwcomposer.cpp
index 0fd2177..3ad13a9 100755
--- a/hwcomposer.cpp
+++ b/hwcomposer.cpp
@@ -3498,8 +3498,10 @@ static int hwc_get_display_configs(struct hwc_composer_device_1 *dev,

   char framebuffer_size[PROPERTY_VALUE_MAX];
   uint32_t width = 0, height = 0 , vrefresh = 0 ;
+  if (display == HWC_DISPLAY_PRIMARY)
   property_get("persist.sys.framebuffer.main", framebuffer_size, "use_baseparameter");
-
+  else if(display == HWC_DISPLAY_EXTERNAL)
+  property_get("persist.sys.framebuffer.aux", framebuffer_size, "use_baseparameter");
   /*
    * if unset framebuffer_size, get it from baseparameter , by libin
    */

@@ -2298,7 +2301,8 @@ static int hwc_prepare(hwc_composer_device_1_t *dev, size_t num_displays,
     hd->rel_yres = mode.v_display();
     hd->v_total = mode.v_total();
     hd->w_scale = (float)mode.h_display() / hd->framebuffer_width;
-    hd->h_scale = (float)mode.v_display() / hd->framebuffer_height;
+    //hd->h_scale = (float)mode.v_display() / hd->framebuffer_height;
+    hd->h_scale = 1.0;
     int fbSize = hd->framebuffer_width * hd->framebuffer_height;
     //get plane size for display
     std::vector<PlaneGroup *>& plane_groups = ctx->drm.GetPlaneGroups();
@@ -3638,7 +3647,8 @@ static int hwc_set_active_config(struct hwc_composer_device_1 *dev, int display,
     return -ENOENT;
   }
   hd->w_scale = (float)mode.h_display() / hd->framebuffer_width;
-  hd->h_scale = (float)mode.v_display() / hd->framebuffer_height;
+  //hd->h_scale = (float)mode.v_display() / hd->framebuffer_height;
+  hd->h_scale = 1.0;

   c->set_current_mode(mode);
   ctx->drm.UpdateDisplayRoute();

  

  

posted @ 2021-09-01 11:37  CrushGirl  阅读(1291)  评论(0编辑  收藏  举报