if (ret < 0)
                        goto remove_pad_error;
 
-               load  += in_frame->info.padded_width;
+               load  += in_frame->frame_info.padded_width;
                store += width;
        }
 
 
  *  This is the main structure used for all input and output images.
  */
 struct ia_css_frame {
-       struct ia_css_frame_info info; /** info struct describing the frame */
+       struct ia_css_frame_info frame_info; /** info struct describing the frame */
        ia_css_ptr   data;             /** pointer to start of image data */
        unsigned int data_bytes;       /** size of image data in bytes */
        /* LA: move this to ia_css_buffer */
 };
 
 #define DEFAULT_FRAME { \
-       .info                   = IA_CSS_BINARY_DEFAULT_FRAME_INFO, \
+       .frame_info             = IA_CSS_BINARY_DEFAULT_FRAME_INFO, \
        .dynamic_queue_id       = SH_CSS_INVALID_QUEUE_ID, \
        .buf_type               = IA_CSS_BUFFER_TYPE_INVALID, \
        .flash_state            = IA_CSS_FRAME_FLASH_STATE_NONE, \
 void
 ia_css_frame_unmap(struct ia_css_frame *frame);
 
+static inline const struct ia_css_frame_info *
+ia_css_frame_get_info(const struct ia_css_frame *frame)
+{
+       return frame ? &frame->frame_info : NULL;
+}
+
 #endif /* __IA_CSS_FRAME_PUBLIC_H */
 
        const struct ia_css_frame *in_frame = args->in_frame;
        const struct ia_css_frame **out_frames = (const struct ia_css_frame **)
                &args->out_frame;
-       const struct ia_css_frame_info *in_frame_info = (in_frame) ? &in_frame->info :
-               &binary->in_frame_info;
-
+       const struct ia_css_frame_info *in_frame_info = ia_css_frame_get_info(in_frame);
        const unsigned int ddr_bits_per_element = sizeof(short) * 8;
        const unsigned int ddr_elems_per_word = ceil_div(HIVE_ISP_DDR_WORD_BITS,
                                                ddr_bits_per_element);
                                    "ia_css_bayer_io_config() put part enter:\n");
 #endif
 
-               ret = ia_css_dma_configure_from_info(&config, &out_frames[0]->info);
+               ret = ia_css_dma_configure_from_info(&config, &out_frames[0]->frame_info);
                if (ret)
                        return ret;
                to->base_address = out_frames[0]->data;
-               to->width = out_frames[0]->info.res.width;
-               to->height = out_frames[0]->info.res.height;
+               to->width = out_frames[0]->frame_info.res.width;
+               to->height = out_frames[0]->frame_info.res.height;
                to->stride = config.stride;
                to->ddr_elems_per_word = ddr_elems_per_word;
 
 
        const struct ia_css_frame *in_frame = args->in_frame;
        const struct ia_css_frame **out_frames = (const struct ia_css_frame **)
                &args->out_frame;
-       const struct ia_css_frame_info *in_frame_info = (in_frame) ? &in_frame->info :
-               &binary->in_frame_info;
-
+       const struct ia_css_frame_info *in_frame_info = ia_css_frame_get_info(in_frame);
        const unsigned int ddr_bits_per_element = sizeof(short) * 8;
        const unsigned int ddr_elems_per_word = ceil_div(HIVE_ISP_DDR_WORD_BITS,
                                                ddr_bits_per_element);
                                    "ia_css_yuv444_io_config() put part enter:\n");
 #endif
 
-               ret = ia_css_dma_configure_from_info(&config, &out_frames[0]->info);
+               ret = ia_css_dma_configure_from_info(&config, &out_frames[0]->frame_info);
                if (ret)
                        return ret;
 
                to->base_address = out_frames[0]->data;
-               to->width = out_frames[0]->info.res.width;
-               to->height = out_frames[0]->info.res.height;
+               to->width = out_frames[0]->frame_info.res.width;
+               to->height = out_frames[0]->frame_info.res.height;
                to->stride = config.stride;
                to->ddr_elems_per_word = ddr_elems_per_word;
 
 
        int ret;
 
        if (from->ref_frames[0]) {
-               ret = ia_css_dma_configure_from_info(&to->port_b, &from->ref_frames[0]->info);
+               ret = ia_css_dma_configure_from_info(&to->port_b, &from->ref_frames[0]->frame_info);
                if (ret)
                        return ret;
                to->width_a_over_b = elems_a / to->port_b.elems;
 
        unsigned int i;
        int ret;
 
-       ret = ia_css_dma_configure_from_info(&to->port_b, &from->tnr_frames[0]->info);
+       ret = ia_css_dma_configure_from_info(&to->port_b, &from->tnr_frames[0]->frame_info);
        if (ret)
                return ret;
        to->width_a_over_b = elems_a / to->port_b.elems;
-       to->frame_height = from->tnr_frames[0]->info.res.height;
+       to->frame_height = from->tnr_frames[0]->frame_info.res.height;
        for (i = 0; i < NUM_VIDEO_TNR_FRAMES; i++) {
                to->tnr_frame_addr[i] = from->tnr_frames[i]->data +
                                        from->tnr_frames[i]->planes.yuyv.offset;
 
        data = (char *)HOST_ADDRESS(frame->data);
        ia_css_debug_dtrace(2, "frame %s (%p):\n", descr, frame);
        ia_css_debug_dtrace(2, "  resolution    = %dx%d\n",
-                           frame->info.res.width, frame->info.res.height);
+                           frame->frame_info.res.width, frame->frame_info.res.height);
        ia_css_debug_dtrace(2, "  padded width  = %d\n",
-                           frame->info.padded_width);
-       ia_css_debug_dtrace(2, "  format        = %d\n", frame->info.format);
-       switch (frame->info.format) {
+                           frame->frame_info.padded_width);
+       ia_css_debug_dtrace(2, "  format        = %d\n", frame->frame_info.format);
+       switch (frame->frame_info.format) {
        case IA_CSS_FRAME_FORMAT_NV12:
        case IA_CSS_FRAME_FORMAT_NV16:
        case IA_CSS_FRAME_FORMAT_NV21:
        dtrace_dot(
            "node [shape = box, fixedsize=true, width=2, height=0.7]; \"%p\" [label = \"%s\\n%d(%d) x %d, %dbpp\\n%s\"];",
            frame,
-           debug_frame_format2str(frame->info.format),
-           frame->info.res.width,
-           frame->info.padded_width,
-           frame->info.res.height,
-           frame->info.raw_bit_depth,
+           debug_frame_format2str(frame->frame_info.format),
+           frame->frame_info.res.width,
+           frame->frame_info.padded_width,
+           frame->frame_info.res.height,
+           frame->frame_info.raw_bit_depth,
            bufinfo);
 
        if (in_frame) {
        snprintf(ring_buffer, sizeof(ring_buffer),
                 "node [shape = box, fixedsize=true, width=2, height=0.7]; \"%p\" [label = \"%s\\n%d(%d) x %d\\nRingbuffer\"];",
                 out_frame,
-                debug_frame_format2str(out_frame->info.format),
-                out_frame->info.res.width,
-                out_frame->info.padded_width,
-                out_frame->info.res.height);
+                debug_frame_format2str(out_frame->frame_info.format),
+                out_frame->frame_info.res.width,
+                out_frame->frame_info.padded_width,
+                out_frame->frame_info.res.height);
 
        dtrace_dot(ring_buffer);
 
 
 {
        assert(frame);
 
-       switch (frame->info.format) {
+       switch (frame->frame_info.format) {
        case IA_CSS_FRAME_FORMAT_MIPI:
                dev_err(atomisp_dev,
                        "%s: unexpected use of IA_CSS_FRAME_FORMAT_MIPI\n", __func__);
                return -EINVAL;
        case IA_CSS_FRAME_FORMAT_RAW_PACKED:
                frame_init_raw_single_plane(frame, &frame->planes.raw,
-                                           frame->info.res.height,
-                                           frame->info.padded_width,
-                                           frame->info.raw_bit_depth);
+                                           frame->frame_info.res.height,
+                                           frame->frame_info.padded_width,
+                                           frame->frame_info.raw_bit_depth);
                break;
        case IA_CSS_FRAME_FORMAT_RAW:
                frame_init_single_plane(frame, &frame->planes.raw,
-                                       frame->info.res.height,
-                                       frame->info.padded_width,
-                                       frame->info.raw_bit_depth <= 8 ? 1 : 2);
+                                       frame->frame_info.res.height,
+                                       frame->frame_info.padded_width,
+                                       frame->frame_info.raw_bit_depth <= 8 ? 1 : 2);
                break;
        case IA_CSS_FRAME_FORMAT_RGB565:
                frame_init_single_plane(frame, &frame->planes.rgb,
-                                       frame->info.res.height,
-                                       frame->info.padded_width, 2);
+                                       frame->frame_info.res.height,
+                                       frame->frame_info.padded_width, 2);
                break;
        case IA_CSS_FRAME_FORMAT_RGBA888:
                frame_init_single_plane(frame, &frame->planes.rgb,
-                                       frame->info.res.height,
-                                       frame->info.padded_width * 4, 1);
+                                       frame->frame_info.res.height,
+                                       frame->frame_info.padded_width * 4, 1);
                break;
        case IA_CSS_FRAME_FORMAT_PLANAR_RGB888:
                frame_init_rgb_planes(frame, 1);
        case IA_CSS_FRAME_FORMAT_CSI_MIPI_YUV420_8:
        case IA_CSS_FRAME_FORMAT_CSI_MIPI_LEGACY_YUV420_8:
                frame_init_single_plane(frame, &frame->planes.yuyv,
-                                       frame->info.res.height,
-                                       frame->info.padded_width * 2, 1);
+                                       frame->frame_info.res.height,
+                                       frame->frame_info.padded_width * 2, 1);
                break;
        case IA_CSS_FRAME_FORMAT_YUV_LINE:
                /* Needs 3 extra lines to allow vf_pp prefetching */
                frame_init_single_plane(frame, &frame->planes.yuyv,
-                                       frame->info.res.height * 3 / 2 + 3,
-                                       frame->info.padded_width, 1);
+                                       frame->frame_info.res.height * 3 / 2 + 3,
+                                       frame->frame_info.padded_width, 1);
                break;
        case IA_CSS_FRAME_FORMAT_NV11:
                frame_init_nv_planes(frame, 4, 1, 1);
                break;
        case IA_CSS_FRAME_FORMAT_BINARY_8:
                frame_init_single_plane(frame, &frame->planes.binary.data,
-                                       frame->info.res.height,
-                                       frame->info.padded_width, 1);
+                                       frame->frame_info.res.height,
+                                       frame->frame_info.padded_width, 1);
                frame->planes.binary.size = 0;
                break;
        default:
                               const struct ia_css_frame *frame_b)
 {
        bool is_equal = false;
-       const struct ia_css_frame_info *info_a = &frame_a->info,
-                                               *info_b = &frame_b->info;
+       const struct ia_css_frame_info *info_a = &frame_a->frame_info;
+       const struct ia_css_frame_info *info_b = &frame_b->frame_info;
 
        ia_css_debug_dtrace(IA_CSS_DEBUG_TRACE,
                            "ia_css_frame_is_same_type() enter:\n");
                                 unsigned int vertical_decimation,
                                 unsigned int bytes_per_element)
 {
-       unsigned int y_width = frame->info.padded_width;
-       unsigned int y_height = frame->info.res.height;
+       unsigned int y_width = frame->frame_info.padded_width;
+       unsigned int y_height = frame->frame_info.res.height;
        unsigned int uv_width;
        unsigned int uv_height;
        unsigned int y_bytes;
        uv_width = 2 * (y_width / horizontal_decimation);
        uv_height = y_height / vertical_decimation;
 
-       if (frame->info.format == IA_CSS_FRAME_FORMAT_NV12_TILEY) {
+       if (frame->frame_info.format == IA_CSS_FRAME_FORMAT_NV12_TILEY) {
                y_width   = CEIL_MUL(y_width,   NV12_TILEY_TILE_WIDTH);
                uv_width  = CEIL_MUL(uv_width,  NV12_TILEY_TILE_WIDTH);
                y_height  = CEIL_MUL(y_height,  NV12_TILEY_TILE_HEIGHT);
                                  bool swap_uv,
                                  unsigned int bytes_per_element)
 {
-       unsigned int y_width = frame->info.padded_width,
-                    y_height = frame->info.res.height,
+       unsigned int y_width = frame->frame_info.padded_width,
+                    y_height = frame->frame_info.res.height,
                     uv_width = y_width / horizontal_decimation,
                     uv_height = y_height / vertical_decimation,
                     y_stride, y_bytes, uv_bytes, uv_stride;
 static void frame_init_rgb_planes(struct ia_css_frame *frame,
                                  unsigned int bytes_per_element)
 {
-       unsigned int width = frame->info.res.width,
-                    height = frame->info.res.height, stride, bytes;
+       unsigned int width = frame->frame_info.res.width,
+                    height = frame->frame_info.res.height, stride, bytes;
 
        stride = width * bytes_per_element;
        bytes = stride * height;
 
 static void frame_init_qplane6_planes(struct ia_css_frame *frame)
 {
-       unsigned int width = frame->info.padded_width / 2,
-                    height = frame->info.res.height / 2, bytes, stride;
+       unsigned int width = frame->frame_info.padded_width / 2,
+                    height = frame->frame_info.res.height / 2, bytes, stride;
 
        stride = width * 2;
        bytes = stride * height;
                return NULL;
 
        memset(me, 0, sizeof(*me));
-       me->info.res.width = width;
-       me->info.res.height = height;
-       me->info.format = format;
-       me->info.padded_width = padded_width;
-       me->info.raw_bit_depth = raw_bit_depth;
+       me->frame_info.res.width = width;
+       me->frame_info.res.height = height;
+       me->frame_info.format = format;
+       me->frame_info.padded_width = padded_width;
+       me->frame_info.raw_bit_depth = raw_bit_depth;
        me->valid = valid;
        me->data_bytes = 0;
        me->data = mmgr_NULL;
 int ia_css_frame_init_from_info(struct ia_css_frame *frame,
                                const struct ia_css_frame_info *frame_info)
 {
-       frame->info.res.width = frame_info->res.width;
-       frame->info.res.height = frame_info->res.height;
-       frame->info.format = frame_info->format;
-       frame->info.padded_width = frame_info->padded_width;
-       frame->info.raw_bit_depth = frame_info->raw_bit_depth;
+       frame->frame_info.res.width = frame_info->res.width;
+       frame->frame_info.res.height = frame_info->res.height;
+       frame->frame_info.format = frame_info->format;
+       frame->frame_info.padded_width = frame_info->padded_width;
+       frame->frame_info.raw_bit_depth = frame_info->raw_bit_depth;
        frame->valid = true;
        /* To indicate it is not valid frame. */
        frame->dynamic_queue_id = SH_CSS_INVALID_QUEUE_ID;
 
 
        assert(vf_frame);
 
-       sh_css_pipe_get_viewfinder_frame_info(pipe, &vf_frame->info, idx);
+       sh_css_pipe_get_viewfinder_frame_info(pipe, &vf_frame->frame_info, idx);
        vf_frame->flash_state = IA_CSS_FRAME_FLASH_STATE_NONE;
        ia_css_pipeline_get_sp_thread_id(ia_css_pipe_get_pipe_num(pipe), &thread_id);
        ia_css_query_internal_queue_id(IA_CSS_BUFFER_TYPE_VF_OUTPUT_FRAME + idx, thread_id, &queue_id);
        assert(frame);
        in_frame = frame;
 
-       in_frame->info.format = format;
+       in_frame->frame_info.format = format;
 
 #ifdef ISP2401
        if (format == IA_CSS_FRAME_FORMAT_RAW)
-               in_frame->info.format = (pipe->stream->config.pack_raw_pixels) ?
+               in_frame->frame_info.format = (pipe->stream->config.pack_raw_pixels) ?
                IA_CSS_FRAME_FORMAT_RAW_PACKED : IA_CSS_FRAME_FORMAT_RAW;
 #endif
 
-       in_frame->info.res.width = pipe->stream->config.input_config.input_res.width;
-       in_frame->info.res.height = pipe->stream->config.input_config.input_res.height;
-       in_frame->info.raw_bit_depth =
-       ia_css_pipe_util_pipe_input_format_bpp(pipe);
-       ia_css_frame_info_set_width(&in_frame->info, pipe->stream->config.input_config.input_res.width, 0);
+       in_frame->frame_info.res.width = pipe->stream->config.input_config.input_res.width;
+       in_frame->frame_info.res.height = pipe->stream->config.input_config.input_res.height;
+       in_frame->frame_info.raw_bit_depth = ia_css_pipe_util_pipe_input_format_bpp(pipe);
+       ia_css_frame_info_set_width(&in_frame->frame_info,
+                                   pipe->stream->config.input_config.input_res.width, 0);
        in_frame->flash_state = IA_CSS_FRAME_FLASH_STATE_NONE;
        ia_css_pipeline_get_sp_thread_id(ia_css_pipe_get_pipe_num(pipe), &thread_id);
        ia_css_query_internal_queue_id(IA_CSS_BUFFER_TYPE_INPUT_FRAME, thread_id, &queue_id);
        in_frame->dynamic_queue_id = queue_id;
        in_frame->buf_type = IA_CSS_BUFFER_TYPE_INPUT_FRAME;
 #ifdef ISP2401
-       ia_css_get_crop_offsets(pipe, &in_frame->info);
+       ia_css_get_crop_offsets(pipe, &in_frame->frame_info);
 #endif
        err = ia_css_frame_init_planes(in_frame);
 
-       ia_css_debug_dtrace(IA_CSS_DEBUG_TRACE_PRIVATE,
-                           "init_in_frameinfo_memory_defaults() bayer_order = %d:\n", in_frame->info.raw_bayer_order);
+       ia_css_debug_dtrace(IA_CSS_DEBUG_TRACE_PRIVATE, "%s() bayer_order = %d\n",
+                           __func__, in_frame->frame_info.raw_bayer_order);
 
        return err;
 }
 
        assert(out_frame);
 
-       sh_css_pipe_get_output_frame_info(pipe, &out_frame->info, idx);
+       sh_css_pipe_get_output_frame_info(pipe, &out_frame->frame_info, idx);
        out_frame->flash_state = IA_CSS_FRAME_FLASH_STATE_NONE;
        ia_css_pipeline_get_sp_thread_id(ia_css_pipe_get_pipe_num(pipe), &thread_id);
        ia_css_query_internal_queue_id(IA_CSS_BUFFER_TYPE_OUTPUT_FRAME + idx, thread_id, &queue_id);
                                if (!frame->valid)
                                        pipe->num_invalid_frames--;
 
-                               if (frame->info.format == IA_CSS_FRAME_FORMAT_BINARY_8) {
+                               if (frame->frame_info.format == IA_CSS_FRAME_FORMAT_BINARY_8) {
 #ifdef ISP2401
                                        frame->planes.binary.size = frame->data_bytes;
 #else
                        /* we use output port 1 as internal output port */
                        tmp_in_frame = yuv_scaler_stage->args.out_frame[1];
                        if (pipe->pipe_settings.yuvpp.is_output_stage[i]) {
-                               if (tmp_vf_frame && (tmp_vf_frame->info.res.width != 0)) {
+                               if (tmp_vf_frame && (tmp_vf_frame->frame_info.res.width != 0)) {
                                        in_frame = yuv_scaler_stage->args.out_vf_frame;
                                        err = add_vf_pp_stage(pipe, in_frame,
                                                              tmp_vf_frame,
                        }
                }
        } else if (copy_stage) {
-               if (vf_frame[0] && vf_frame[0]->info.res.width != 0) {
+               if (vf_frame[0] && vf_frame[0]->frame_info.res.width != 0) {
                        in_frame = copy_stage->args.out_vf_frame;
                        err = add_vf_pp_stage(pipe, in_frame, vf_frame[0],
                                              &vf_pp_binary[0], &vf_pp_stage);
 
        if (copy_on_sp(pipe) &&
            pipe->stream->config.input_config.format == ATOMISP_INPUT_FORMAT_BINARY_8) {
-               ia_css_frame_info_init(&out_frame->info, JPEG_BYTES, 1,
+               ia_css_frame_info_init(&out_frame->frame_info, JPEG_BYTES, 1,
                                       IA_CSS_FRAME_FORMAT_BINARY_8, 0);
-       } else if (out_frame->info.format == IA_CSS_FRAME_FORMAT_RAW) {
-               out_frame->info.raw_bit_depth =
+       } else if (out_frame->frame_info.format == IA_CSS_FRAME_FORMAT_RAW) {
+               out_frame->frame_info.raw_bit_depth =
                ia_css_pipe_util_pipe_input_format_bpp(pipe);
        }
 
        ia_css_pipeline_clean(me);
 
        /* Construct out_frame info */
-       err = sh_css_pipe_get_output_frame_info(pipe, &out_frame->info, 0);
+       err = sh_css_pipe_get_output_frame_info(pipe, &out_frame->frame_info, 0);
        if (err)
                return err;
        out_frame->flash_state = IA_CSS_FRAME_FLASH_STATE_NONE;
 
        assert(raw_black_frame);
 
        params = stream->isp_params_configs;
-       height = raw_black_frame->info.res.height;
-       width = raw_black_frame->info.padded_width;
+       height = raw_black_frame->frame_info.res.height;
+       width = raw_black_frame->frame_info.padded_width;
 
        ptr = raw_black_frame->data
        + raw_black_frame->planes.raw.offset;
                        const struct sh_css_binary_args *args = &stage->args;
                        const struct ia_css_frame_info *out_infos[IA_CSS_BINARY_MAX_OUTPUT_PORTS] = {NULL};
 
-                       if (args->out_frame[0])
-                               out_infos[0] = &args->out_frame[0]->info;
+                       out_infos[0] = ia_css_frame_get_info(args->out_frame[0]);
+
                        info = &stage->firmware->info.isp;
                        ia_css_binary_fill_info(info, false, false,
                                                ATOMISP_INPUT_FORMAT_RAW_10,
-                                               args->in_frame  ? &args->in_frame->info  : NULL,
+                                               ia_css_frame_get_info(args->in_frame),
                                                NULL,
                                                out_infos,
-                                               args->out_vf_frame ? &args->out_vf_frame->info
-                                               : NULL,
+                                               ia_css_frame_get_info(args->out_vf_frame),
                                                &tmp_binary,
                                                NULL,
                                                -1, true);
                        if (stage->args.delay_frames[0]) {
                                /*When delay frames are present(as in case of video),
                                they are used for dvs. Configure DVS using those params*/
-                               dvs_in_frame_info = &stage->args.delay_frames[0]->info;
+                               dvs_in_frame_info = &stage->args.delay_frames[0]->frame_info;
                        } else {
                                /*Otherwise, use input frame to configure DVS*/
-                               dvs_in_frame_info = &stage->args.in_frame->info;
+                               dvs_in_frame_info = &stage->args.in_frame->frame_info;
                        }
 
                        /* Generate default DVS unity table on start up*/
 
        ia_css_pipeline_get_sp_thread_id(pipe_num, &thread_id);
        pipe = &sh_css_sp_group.pipe[thread_id];
 
-       pipe->copy.raw.height       = out_frame->info.res.height;
-       pipe->copy.raw.width        = out_frame->info.res.width;
-       pipe->copy.raw.padded_width  = out_frame->info.padded_width;
-       pipe->copy.raw.raw_bit_depth = out_frame->info.raw_bit_depth;
+       pipe->copy.raw.height       = out_frame->frame_info.res.height;
+       pipe->copy.raw.width        = out_frame->frame_info.res.width;
+       pipe->copy.raw.padded_width  = out_frame->frame_info.padded_width;
+       pipe->copy.raw.raw_bit_depth = out_frame->frame_info.raw_bit_depth;
        pipe->copy.raw.max_input_width = max_input_width;
        pipe->num_stages = 1;
        pipe->pipe_id = pipe_id;
        ia_css_pipeline_get_sp_thread_id(pipe_num, &thread_id);
        pipe = &sh_css_sp_group.pipe[thread_id];
 
-       pipe->copy.raw.height           = out_frame->info.res.height;
-       pipe->copy.raw.width            = out_frame->info.res.width;
-       pipe->copy.raw.padded_width     = out_frame->info.padded_width;
-       pipe->copy.raw.raw_bit_depth    = out_frame->info.raw_bit_depth;
+       pipe->copy.raw.height           = out_frame->frame_info.res.height;
+       pipe->copy.raw.width            = out_frame->frame_info.res.width;
+       pipe->copy.raw.padded_width     = out_frame->frame_info.padded_width;
+       pipe->copy.raw.raw_bit_depth    = out_frame->frame_info.raw_bit_depth;
        pipe->copy.raw.max_input_width  = max_input_width;
        pipe->num_stages                = 1;
        pipe->pipe_id                   = pipe_id;
                                            frame_in->data,
                                            frame_in->buf_type);
 
-       ia_css_frame_info_to_frame_sp_info(&sp_frame_out->info, &frame_in->info);
+       ia_css_frame_info_to_frame_sp_info(&sp_frame_out->info, &frame_in->frame_info);
 
-       switch (frame_in->info.format) {
+       switch (frame_in->frame_info.format) {
        case IA_CSS_FRAME_FORMAT_RAW_PACKED:
        case IA_CSS_FRAME_FORMAT_RAW:
                sp_frame_out->planes.raw.offset = frame_in->planes.raw.offset;
        if (!frame)
                return -EINVAL;
 
-       switch (frame->info.format) {
+       switch (frame->frame_info.format) {
        case IA_CSS_FRAME_FORMAT_QPLANE6:
        case IA_CSS_FRAME_FORMAT_YUV420_16:
        case IA_CSS_FRAME_FORMAT_RAW_PACKED:
        if (!frame)
                return -EINVAL;
 
-       switch (frame->info.format) {
+       switch (frame->frame_info.format) {
        case IA_CSS_FRAME_FORMAT_YUV420:
        case IA_CSS_FRAME_FORMAT_YUV422:
        case IA_CSS_FRAME_FORMAT_YUV444:
        if (!frame)
                return -EINVAL;
 
-       switch (frame->info.format) {
+       switch (frame->frame_info.format) {
        /* the dual output pin */
        case IA_CSS_FRAME_FORMAT_NV12:
        case IA_CSS_FRAME_FORMAT_NV12_16:
        ret = ia_css_fpn_configure(binary,  &binary->in_frame_info);
        if (ret)
                return ret;
-       ret = ia_css_crop_configure(binary, &args->delay_frames[0]->info);
+       ret = ia_css_crop_configure(binary, ia_css_frame_get_info(args->delay_frames[0]));
        if (ret)
                return ret;
        ret = ia_css_qplane_configure(pipeline, binary, &binary->in_frame_info);
        if (ret)
                return ret;
-       ret = ia_css_output0_configure(binary, &args->out_frame[0]->info);
+       ret = ia_css_output0_configure(binary, ia_css_frame_get_info(args->out_frame[0]));
        if (ret)
                return ret;
-       ret = ia_css_output1_configure(binary, &args->out_vf_frame->info);
+       ret = ia_css_output1_configure(binary, ia_css_frame_get_info(args->out_vf_frame));
        if (ret)
                return ret;
        ret = ia_css_copy_output_configure(binary, args->copy_output);
        if (ret)
                return ret;
-       ret = ia_css_output0_configure(binary, &args->out_frame[0]->info);
+       ret = ia_css_output0_configure(binary, ia_css_frame_get_info(args->out_frame[0]));
        if (ret)
                return ret;
-       ret = ia_css_iterator_configure(binary, &args->in_frame->info);
+       ret = ia_css_iterator_configure(binary, ia_css_frame_get_info(args->in_frame));
        if (ret)
                return ret;
-       ret = ia_css_dvs_configure(binary, &args->out_frame[0]->info);
+       ret = ia_css_dvs_configure(binary, ia_css_frame_get_info(args->out_frame[0]));
        if (ret)
                return ret;
-       ret = ia_css_output_configure(binary, &args->out_frame[0]->info);
+       ret = ia_css_output_configure(binary, ia_css_frame_get_info(args->out_frame[0]));
        if (ret)
                return ret;
-       ret = ia_css_raw_configure(pipeline, binary, &args->in_frame->info, &binary->in_frame_info, two_ppc, deinterleaved);
+       ret = ia_css_raw_configure(pipeline, binary, ia_css_frame_get_info(args->in_frame),
+                                  &binary->in_frame_info, two_ppc, deinterleaved);
        if (ret)
                return ret;
 
                return -EINVAL;
 
        if (args->in_frame)
-               ia_css_get_crop_offsets(pipe, &args->in_frame->info);
+               ia_css_get_crop_offsets(pipe, &args->in_frame->frame_info);
        else
                ia_css_get_crop_offsets(pipe, &binary->in_frame_info);
 #else
                const struct ia_css_frame_info *out_infos[IA_CSS_BINARY_MAX_OUTPUT_PORTS] = {NULL};
 
                if (args->out_frame[0])
-                       out_infos[0] = &args->out_frame[0]->info;
+                       out_infos[0] = &args->out_frame[0]->frame_info;
                info = &firmware->info.isp;
                ia_css_binary_fill_info(info, false, false,
                                        ATOMISP_INPUT_FORMAT_RAW_10,
-                                       args->in_frame  ? &args->in_frame->info  : NULL,
+                                       ia_css_frame_get_info(args->in_frame),
                                        NULL,
                                        out_infos,
-                                       args->out_vf_frame ? &args->out_vf_frame->info
-                                       : NULL,
+                                       ia_css_frame_get_info(args->out_vf_frame),
                                        &tmp_binary,
                                        NULL,
                                        -1, true);