static uint8_T c22_d_emlrt_marshallIn(SFc22_BuckBoost1InstanceStruct
  *chartInstance, const mxArray *c22_b_is_active_c22_BuckBoost1, const char_T
  *c22_identifier)
{
  uint8_T c22_y;
  emlrtMsgIdentifier c22_thisId;
  c22_thisId.fIdentifier = c22_identifier;
  c22_thisId.fParent = NULL;
  c22_y = c22_e_emlrt_marshallIn(chartInstance, sf_mex_dup
    (c22_b_is_active_c22_BuckBoost1), &c22_thisId);
  sf_mex_destroy(&c22_b_is_active_c22_BuckBoost1);
  return c22_y;
}
static void set_sim_state_c22_CSE1_DP(SFc22_CSE1_DPInstanceStruct *chartInstance,
  const mxArray *c22_st)
{
  const mxArray *c22_u;
  real_T c22_dv0[9];
  int32_T c22_i1;
  real_T (*c22_K_p)[9];
  c22_K_p = (real_T (*)[9])ssGetOutputPortSignal(chartInstance->S, 1);
  chartInstance->c22_doneDoubleBufferReInit = true;
  c22_u = sf_mex_dup(c22_st);
  c22_emlrt_marshallIn(chartInstance, sf_mex_dup(sf_mex_getcell(c22_u, 0)),
                       "K_p", c22_dv0);
  for (c22_i1 = 0; c22_i1 < 9; c22_i1++) {
    (*c22_K_p)[c22_i1] = c22_dv0[c22_i1];
  }

  chartInstance->c22_is_active_c22_CSE1_DP = c22_e_emlrt_marshallIn
    (chartInstance, sf_mex_dup(sf_mex_getcell(c22_u, 1)),
     "is_active_c22_CSE1_DP");
  sf_mex_destroy(&c22_u);
  c22_update_debugger_state_c22_CSE1_DP(chartInstance);
  sf_mex_destroy(&c22_st);
}