encoder 从 CRTC 拿到 pixel data,并将其转化为 connector 需要的 format。

encoder 通过 drm_encoder_init() 初始化,drm_encoder_cleanup() 清除。

struct drm_encoder_funcs {
  void (*reset)(struct drm_encoder *encoder);
  void (*destroy)(struct drm_encoder *encoder);
  int (*late_register)(struct drm_encoder *encoder);
  void (*early_unregister)(struct drm_encoder *encoder);
  void (*debugfs_init)(struct drm_encoder *encoder, struct dentry *root);
};

reset: reset encoder

destroy: drm_encoder_cleanup

late_register: 和 crtc 相关接口类似 early_unregister: 同上

debugfs_init: 注册 debugfs_init

struct drm_encoder {
  struct drm_device *dev;
  struct list_head head;
  struct drm_mode_object base;
  char *name;
  int encoder_type; /// DRM_MODE_ENCODER_<foo>
  unsigned index;
  uint32_t possible_crtcs;
  uint32_t possible_clones;
  struct list_head bridge_chain;
  const struct drm_encoder_funcs *funcs;
  const struct drm_encoder_helper_funcs *helper_private;
  struct dentry *debugfs_entry;
};

possible_clones: 用于定义哪些 encoder 可以与当前 encoder 同时工作,在多显示输出的场景中有用,比如需要在多个显示器上显示相同内容时。如果单显示输出置为 0 即可。

struct drm_encoder_helper_funcs {
  enum drm_mode_status (*mode_valid)(struct drm_encoder *crtc,
             const struct drm_display_mode *mode);
  void (*atomic_mode_set)(struct drm_encoder *encoder,
        struct drm_crtc_state *crtc_state,
        struct drm_connector_state *conn_state);
  void (*atomic_disable)(struct drm_encoder *encoder,
             struct drm_atomic_state *state);
  void (*atomic_enable)(struct drm_encoder *encoder,
            struct drm_atomic_state *state);
  int (*atomic_check)(struct drm_encoder *encoder,
          struct drm_crtc_state *crtc_state,
          struct drm_connector_state *conn_state);
};

mode_valid: optional, 检查 userspace 传入的 drm_display_mode 是否满足 encoder 的约束

atomic_mode_set:

atomic_disable: disable encoder.

atomic_enable: enable encoder.