u32 cpp;
 
        info = drm_get_format_info(adev->ddev, mode_cmd);
-       cpp = drm_format_info_plane_cpp(info, 0);
+       cpp = info->cpp[0];
 
        /* need to align pitch with crtc limits */
        mode_cmd->pitches[0] = amdgpu_align_pitch(adev, mode_cmd->width, cpp,
 
 int malidp_format_get_bpp(u32 fmt)
 {
        const struct drm_format_info *info = drm_format_info(fmt);
-       int bpp = drm_format_info_plane_cpp(info, 0) * 8;
+       int bpp = info->cpp[0] * 8;
 
        if (bpp == 0) {
                switch (fmt) {
 
 
        if (modifier & AFBC_SPLIT) {
                if (!info->is_yuv) {
-                       if (drm_format_info_plane_cpp(info, 0) <= 2) {
+                       if (info->cpp[0] <= 2) {
                                DRM_DEBUG_KMS("RGB formats <= 16bpp are not supported with SPLIT\n");
                                return false;
                        }
 
 
        dumb_args.width = width;
        dumb_args.height = height;
-       dumb_args.bpp = drm_format_info_plane_cpp(info, 0) * 8;
+       dumb_args.bpp = info->cpp[0] * 8;
        ret = drm_mode_create_dumb(dev, &dumb_args, client->file);
        if (ret)
                goto err_delete;
 
                                          struct drm_clip_rect *clip)
 {
        struct drm_framebuffer *fb = fb_helper->fb;
-       unsigned int cpp = drm_format_info_plane_cpp(fb->format, 0);
+       unsigned int cpp = fb->format->cpp[0];
        size_t offset = clip->y1 * fb->pitches[0] + clip->x1 * cpp;
        void *src = fb_helper->fbdev->screen_buffer + offset;
        void *dst = fb_helper->buffer->vaddr + offset;
 
 void drm_fb_memcpy(void *dst, void *vaddr, struct drm_framebuffer *fb,
                   struct drm_rect *clip)
 {
-       unsigned int cpp = drm_format_info_plane_cpp(fb->format, 0);
+       unsigned int cpp = fb->format->cpp[0];
        size_t len = (clip->x2 - clip->x1) * cpp;
        unsigned int y, lines = clip->y2 - clip->y1;
 
                           struct drm_framebuffer *fb,
                           struct drm_rect *clip)
 {
-       unsigned int cpp = drm_format_info_plane_cpp(fb->format, 0);
+       unsigned int cpp = fb->format->cpp[0];
        unsigned int offset = clip_offset(clip, fb->pitches[0], cpp);
        size_t len = (clip->x2 - clip->x1) * cpp;
        unsigned int y, lines = clip->y2 - clip->y1;
 
                     unsigned int rotation)
 {
        const struct drm_format_info *info = drm_format_info(pixel_format);
-       int cpp = drm_format_info_plane_cpp(info, 0);
+       int cpp = info->cpp[0];
 
        /*
         * "The stride in bytes must not exceed the
 
        if (!gem)
                return ERR_PTR(-ENOENT);
 
-       bpp = drm_format_info_plane_cpp(info, 0);
+       bpp = info->cpp[0];
        size = (height - 1) * cmd->pitches[0] + width * bpp;
        size += cmd->offsets[0];
 
 
        width = mdp5_crtc->cursor.width;
        height = mdp5_crtc->cursor.height;
 
-       stride = width * drm_format_info_plane_cpp(info, 0);
+       stride = width * info->cpp[0];
 
        get_roi(crtc, &roi_w, &roi_h);
 
 
        for (i = 0; i < nplanes; i++) {
                int n, fetch_stride, cpp;
 
-               cpp = drm_format_info_plane_cpp(info, i);
+               cpp = info->cpp[i];
                fetch_stride = width * cpp / (i ? hsub : 1);
 
                n = DIV_ROUND_UP(fetch_stride * nlines, smp->blk_size);
 
                unsigned int min_size;
 
                min_size = (height - 1) * mode_cmd->pitches[i]
-                        + width * drm_format_info_plane_cpp(info, i)
+                        + width * info->cpp[i]
                         + mode_cmd->offsets[i];
 
                if (bos[i]->size < min_size) {
 
        u32 cpp;
 
        info = drm_get_format_info(rdev->ddev, mode_cmd);
-       cpp = drm_format_info_plane_cpp(info, 0);
+       cpp = info->cpp[0];
 
        /* need to align pitch with crtc limits */
        mode_cmd->pitches[0] = radeon_align_pitch(rdev, mode_cmd->width, cpp,
 
 
                min_size = (height - 1) * mode_cmd->pitches[i] +
                        mode_cmd->offsets[i] +
-                       width * drm_format_info_plane_cpp(info, i);
+                       width * info->cpp[i];
 
                if (obj->size < min_size) {
                        drm_gem_object_put_unlocked(obj);
 
 
        /* Configures the color frame buffer pitch in bytes & line length */
        pitch_in_bytes = fb->pitches[0];
-       line_length = drm_format_info_plane_cpp(fb->format, 0) *
+       line_length = fb->format->cpp[0] *
                      (x1 - x0 + 1) + (ldev->caps.bus_width >> 3) - 1;
        val = ((pitch_in_bytes << 16) | line_length);
        reg_update_bits(ldev->regs, LTDC_L1CFBLR + lofs,
 
                        goto unreference;
                }
 
-               bpp = drm_format_info_plane_cpp(info, i);
+               bpp = info->cpp[i];
 
                size = (height - 1) * cmd->pitches[i] +
                       width * bpp + cmd->offsets[i];
 
                cma_obj = drm_fb_cma_get_gem_obj(fb, i);
                paddr = cma_obj->paddr + fb->offsets[i];
                paddr += src_y * fb->pitches[i];
-               paddr += src_x * drm_format_info_plane_cpp(fb->format, i);
+               paddr += src_x * fb->format->cpp[i];
                zx_writel(paddr_reg, paddr);
                paddr_reg += 4;
        }
 
        return info->is_yuv && info->hsub == 1 && info->vsub == 1;
 }
 
-/**
- * drm_format_info_plane_cpp - determine the bytes per pixel value
- * @format: pixel format info
- * @plane: plane index
- *
- * Returns:
- * The bytes per pixel value for the specified plane.
- */
-static inline
-int drm_format_info_plane_cpp(const struct drm_format_info *info, int plane)
-{
-       if (!info || plane >= info->num_planes)
-               return 0;
-
-       return info->cpp[plane];
-}
-
 /**
  * drm_format_info_plane_width - width of the plane given the first plane
  * @format: pixel format info