coreboot-libre-fam15h-rdimm/3rdparty/chromeec/board/fleex/analyzestack.yaml

279 lines
13 KiB
YAML

# Size of extra stack frame needed by exception context switch.
# See core/cortex-m/switch.S
exception_frame_size: 224
# Missing calls
add:
# TCPC stack
tcpm_set_cc[driver/tcpm/tcpm.h:139]:
- tcpci_tcpm_set_cc
tcpm_set_rx_enable[driver/tcpm/tcpm.h:160]:
- tcpci_tcpm_set_rx_enable
tcpm_set_snk_ctrl[driver/tcpm/tcpm.h:179]:
- tcpci_tcpm_set_snk_ctrl
tcpm_get_cc[driver/tcpm/tcpm.h:124]:
- tcpci_tcpm_get_cc
enter_low_power_mode[driver/usb_mux.c:42]:
- tcpci_enter_low_power_mode
svdm_exit_dp_mode[baseboard/octopus/usb_pd_policy.c:346]:
- anx7447_tcpc_update_hpd_status
- ps8xxx_tcpc_update_hpd_status
tcpm_set_src_ctrl[driver/tcpm/tcpm.h:187]:
- tcpci_tcpm_set_src_ctrl
tcpm_init[driver/tcpm/tcpm.h:106]:
- anx7447_init
- tcpci_tcpm_init
tcpm_get_vbus_level[driver/tcpm/tcpm.h:129]:
- anx7447_tcpm_get_vbus_level
- tcpci_tcpm_get_vbus_level
baseboard_tcpc_init[baseboard/octopus/baseboard.c:212]:
- anx7447_tcpc_update_hpd_status
- ps8xxx_tcpc_update_hpd_status
tcpm_get_chip_info[driver/tcpm/tcpm.h:240]:
- tcpci_get_chip_info
- ps8xxx_get_chip_info
tcpm_transmit[driver/tcpm/tcpm.h:172]:
- tcpci_tcpm_transmit
- ps8xxx_tcpm_transmit
tcpc_alert[driver/tcpm/tcpm.h:195]:
- anx7447_tcpc_alert
- tcpci_tcpc_alert
tcpm_set_msg_header[driver/tcpm/tcpm.h:154]:
- tcpci_tcpm_set_msg_header
tcpm_set_vconn[driver/tcpm/tcpm.h:149]:
- tcpci_tcpm_set_vconn
tcpm_select_rp_value[driver/tcpm/tcpm.h:134]:
- tcpci_tcpm_select_rp_value
tcpm_enqueue_message[driver/tcpm/tcpci.c:404]:
- tcpci_tcpm_get_message_raw
svdm_dp_post_config[baseboard/octopus/usb_pd_policy.c:320]:
- anx7447_tcpc_update_hpd_status
- ps8xxx_tcpc_update_hpd_status
svdm_dp_attention[baseboard/octopus/usb_pd_policy.c:335]:
- anx7447_tcpc_update_hpd_status
- ps8xxx_tcpc_update_hpd_status
tcpm_release[driver/tcpm/tcpm.h:119]:
- anx7447_release
- ps8xxx_tcpm_release
tcpm_set_polarity[driver/tcpm/tcpm.h:144]:
- tcpci_tcpm_set_polarity
tcpm_enable_drp_toggle[driver/tcpm/tcpm.h:211]:
- tcpci_tcpc_drp_toggle
tcpm_enter_low_power_mode[driver/tcpm/tcpm.h:218]:
- tcpci_enter_low_power_mode
# USB mux
usb_mux_flip[driver/usb_mux.c:163]:
- anx7447_mux_get
- tcpci_tcpm_mux_get
usb_mux_flip[driver/usb_mux.c:174]:
- anx7447_mux_set
- tcpci_tcpm_mux_set
usb_mux_set[driver/usb_mux.c:112]:
- anx7447_mux_set
- tcpci_tcpm_mux_set
usb_mux_init[driver/usb_mux.c:64]:
- anx7447_mux_init
- tcpci_tcpm_mux_init
usb_mux_get[driver/usb_mux.c:140]:
- anx7447_mux_get
- tcpci_tcpm_mux_get
hc_usb_pd_mux_info[driver/usb_mux.c:240]:
- anx7447_mux_get
- tcpci_tcpm_mux_get
# PPC
ppc_is_sourcing_vbus[common/usbc_ppc.c:42]:
- nx20p348x_is_sourcing_vbus
ppc_init[common/usbc_ppc.c:26]:
- nx20p348x_init
ppc_vbus_sink_enable[common/usbc_ppc.c:86]:
- nx20p348x_vbus_sink_enable
ppc_discharge_vbus[common/usbc_ppc.c:68]:
- nx20p348x_discharge_vbus
ppc_vbus_source_enable[common/usbc_ppc.c:107]:
- nx20p348x_vbus_source_enable
ppc_set_vbus_source_current_limit[common/usbc_ppc.c:60]:
- nx20p348x_set_vbus_source_current_limit
command_ppc_dump[common/usbc_ppc.c:135]:
- nx20p348x_dump
# Motion sensors
command_accelrange[common/motion_sense.c:1513]:
- set_range[driver/accel_lis2dh.c]
- set_range[driver/accelgyro_lsm6dsm.c]
command_accelrange[common/motion_sense.c:1519]:
- get_range[driver/accel_lis2dh.c]
- get_range[driver/accelgyro_lsm6dsm.c]
motion_sensor_time_to_read[common/motion_sense.c:213]:
- st_get_data_rate[driver/stm_mems_common.c]
motion_sense_read[common/motion_sense.c:694]:
- st_get_data_rate[driver/stm_mems_common.c]
motion_sense_read[common/motion_sense.c:707]:
- read[driver/accel_lis2dh.c]
- read[driver/accelgyro_lsm6dsm.c]
motion_sense_process[common/motion_sense.c:719]:
- irq_handler[driver/accelgyro_lsm6dsm.c]
sensor_init_done[common/motion_sense.c:468]:
- set_range[driver/accel_lis2dh.c]
- set_range[driver/accelgyro_lsm6dsm.c]
sensor_init_done[common/motion_sense.c:471]:
- get_range[driver/accel_lis2dh.c]
- get_range[driver/accelgyro_lsm6dsm.c]
motion_sense_set_ec_rate_from_ap[common/motion_sense.c:305]:
- st_get_data_rate[driver/stm_mems_common.c]
host_cmd_motion_sense[common/motion_sense.c:1242]:
- set_range[driver/accel_lis2dh.c]
- set_range[driver/accelgyro_lsm6dsm.c]
host_cmd_motion_sense[common/motion_sense.c:1253]:
- get_range[driver/accel_lis2dh.c]
- get_range[driver/accelgyro_lsm6dsm.c]
host_cmd_motion_sense[common/motion_sense.c:1268]:
- st_set_offset[driver/stm_mems_common.c]
host_cmd_motion_sense[common/motion_sense.c:1303]:
- None
host_cmd_motion_sense[common/motion_sense.c:1306]:
- st_get_offset[driver/stm_mems_common.c]
motion_sense_init[common/motion_sense.c:447]:
- init[driver/accel_lis2dh.c]
- init[driver/accelgyro_lsm6dsm.c]
motion_sense_set_data_rate[common/motion_sense.c:267]:
- set_data_rate[driver/accel_lis2dh.c]
- set_data_rate[driver/accelgyro_lsm6dsm.c]
motion_sense_set_data_rate[common/motion_sense.c:287]:
- st_get_data_rate[driver/stm_mems_common.c]
motion_sense_set_motion_intervals[common/motion_sense.c:411]:
- st_get_data_rate[driver/stm_mems_common.c]
calculate_lid_angle[common/motion_lid.c:385]:
- get_range[driver/accelgyro_lsm6dsm.c]
calculate_lid_angle[common/motion_lid.c:386]:
- get_range[driver/accel_lis2dh.c]
motion_sense_set_data_rate[common/motion_sense.c:286]:
- st_get_data_rate[driver/stm_mems_common.c]
command_accel_read_xyz[common/motion_sense.c:1657]:
- read[driver/accel_lis2dh.c]
- read[driver/accelgyro_lsm6dsm.c]
host_cmd_motion_sense[common/motion_sense.c:1294]:
- None
host_cmd_motion_sense[common/motion_sense.c:1297]:
- st_get_offset[driver/stm_mems_common.c]
command_accelresolution[common/motion_sense.c:1562]:
- None
command_accelresolution[common/motion_sense.c:1566]:
- st_get_resolution[driver/stm_mems_common.c]
command_accelrange[common/motion_sense.c:1518]:
- get_range[driver/accel_lis2dh.c]
- get_range[driver/accelgyro_lsm6dsm.c]
st_normalize[driver/stm_mems_common.c:137]:
- get_range[driver/accel_lis2dh.c]
- get_range[driver/accelgyro_lsm6dsm.c]
command_accel_data_rate[common/motion_sense.c:1621]:
- st_get_data_rate[driver/stm_mems_common.c]
# Misc.
host_send_response[common/host_command.c:153]:
- host_packet_respond
pd_dfp_enter_mode[common/usb_pd_policy.c:465]:
- svdm_enter_dp_mode[baseboard/octopus/usb_pd_policy.c]
- svdm_enter_gfu_mode[baseboard/octopus/usb_pd_policy.c]
pd_svdm[common/usb_pd_policy.c:773]:
- svdm_dp_status[baseboard/octopus/usb_pd_policy.c]
- svdm_gfu_status[baseboard/octopus/usb_pd_policy.c]
pd_svdm[common/usb_pd_policy.c:784]:
- svdm_dp_config[baseboard/octopus/usb_pd_policy.c]
- svdm_gfu_config[baseboard/octopus/usb_pd_policy.c]
pd_svdm[common/usb_pd_policy.c:790]:
- svdm_dp_post_config[baseboard/octopus/usb_pd_policy.c]
dfp_consume_attention[common/usb_pd_policy.c:503]:
- svdm_dp_attention[baseboard/octopus/usb_pd_policy.c]
- svdm_gfu_attention[baseboard/octopus/usb_pd_policy.c]
kblight_set_deferred[common/keyboard_backlight.c:35]:
- kblight_pwm_set
temp_sensor_read[common/temp_sensor.c:26]:
- charge_get_battery_temp
- get_temp_3v3_51k1_47k_4050b
- get_temp_3v3_13k7_47k_4050b
kblight_enable[common/keyboard_backlight.c:61]:
- kblight_pwm_enable
host_packet_respond[common/host_command.c:240]:
- lpc_send_response
kblight_init[common/keyboard_backlight.c:28]:
- kblight_pwm_init
vfnprintf[common/printf.c:75]:
- __tx_char
vfnprintf[common/printf.c:88]:
- __tx_char
vfnprintf[common/printf.c:96]:
- __tx_char
vfnprintf[common/printf.c:171]:
- __tx_char
vfnprintf[common/printf.c:172]:
- __tx_char
vfnprintf[common/printf.c:310]:
- __tx_char
vfnprintf[common/printf.c:315]:
- __tx_char
vfnprintf[common/printf.c:318]:
- __tx_char
pd_dfp_exit_mode[common/usb_pd_policy.c:569]:
- svdm_exit_dp_mode[baseboard/octopus/usb_pd_policy.c]
- svdm_exit_gfu_mode[baseboard/octopus/usb_pd_policy.c]
pd_dfp_exit_mode[common/usb_pd_policy.c:586]:
- svdm_exit_dp_mode[baseboard/octopus/usb_pd_policy.c]
- svdm_exit_gfu_mode[baseboard/octopus/usb_pd_policy.c]
# Indirect callsites in common structures - likely common for all boards
handle_command[common/console.c:248]:
- { name: __cmds, stride: 16, offset: 4 }
host_command_process[common/host_command.c:704]:
- { name: __hcmds, stride: 12, offset: 0 }
mkbp_get_next_event[common/mkbp_event.c:160]:
- { name: __mkbp_evt_srcs, stride: 8, offset: 4 }
hook_task[common/hooks.c:199]:
- { name: __deferred_funcs, stride: 4, offset: 0 }
# Note: This assumes worse case, where all hook functions can be called from
# any hook_notify call
# Generate using `grep hooks_.*_end build/$BOARD/R*/ec.R*.smap |
# sed -e 's/.*\(__hooks.*\)_end/ - { name: \1, stride: 8, offset: 0 }/' |
# sort -u`
hook_notify[common/hooks.c:129]:
- { name: __hooks_ac_change, stride: 8, offset: 0 }
- { name: __hooks_base_attached_change, stride: 8, offset: 0 }
- { name: __hooks_battery_soc_change, stride: 8, offset: 0 }
- { name: __hooks_chipset_pre_init, stride: 8, offset: 0 }
- { name: __hooks_chipset_reset, stride: 8, offset: 0 }
- { name: __hooks_chipset_resume, stride: 8, offset: 0 }
- { name: __hooks_chipset_shutdown, stride: 8, offset: 0 }
- { name: __hooks_chipset_startup, stride: 8, offset: 0 }
- { name: __hooks_chipset_suspend, stride: 8, offset: 0 }
- { name: __hooks_freq_change, stride: 8, offset: 0 }
- { name: __hooks_init, stride: 8, offset: 0 }
- { name: __hooks_lid_change, stride: 8, offset: 0 }
- { name: __hooks_pre_freq_change, stride: 8, offset: 0 }
- { name: __hooks_pwrbtn_change, stride: 8, offset: 0 }
- { name: __hooks_second, stride: 8, offset: 0 }
- { name: __hooks_sysjump, stride: 8, offset: 0 }
- { name: __hooks_tablet_mode_change, stride: 8, offset: 0 }
- { name: __hooks_tick, stride: 8, offset: 0 }
- { name: __hooks_usb_pd_disconnect, stride: 8, offset: 0 }
# NULL function pointers
i2c_command_passthru[common/i2c_master.c:678]:
- None
pd_svdm[common/usb_pd_policy.c:720]:
- None
usb_mux_init[driver/usb_mux.c:75]:
- None
remove:
# Remove panic callsites. Once panicking, we no longer care about stack usage
- panic_assert_fail
# Remove reset_device_and_notify for all non-PD analysis since it can only be called from PD task IDs. Comment this out for the PD tasks
- reset_device_and_notify
# Remove the LPM path because the PD_FLAGS_LPM_TRANSITION flag presents this loop
- [ reset_device_and_notify, tcpci_tcpm_init, [ tcpc_read, tcpc_write16 ], pd_wait_for_wakeup ]
# Remove nonesense hook paths that come from the general hook_notify above (Note: these are not a comprehensive list, but a list of
# paths that came up as longest during analysis
# These functions do not call HOOK_INIT
- [ [ s0ix_transition, charger_task, power_button_change_deferred, jump_to_image, tablet_set_mode, pd_set_suspend, set_state, extpower_deferred, lid_switch_open, lid_switch_close, espi_chipset_reset, lpc_chipset_reset ], hook_notify, [ usb_charger_init, baseboard_tcpc_init, motion_sense_startup, gmr_tablet_switch_init, powerbtn_x86_init, cbi_init ] ]
# These functions do not call HOOK_CHIPSET_SHUTDOWN
- [ [ s0ix_transition, charger_task, power_button_change_deferred, jump_to_image, tablet_set_mode, pd_set_suspend, set_state, extpower_deferred, lid_switch_open, lid_switch_close, hook_task, espi_chipset_reset, lpc_chipset_reset ], hook_notify, [ system_common_shutdown, motion_sense_shutdown, board_disable_a1_redriver ] ]
# These functions do not call HOOK_LID_CHANGE
- [ [ s0ix_transition, charger_task, power_button_change_deferred, jump_to_image, tablet_set_mode, pd_set_suspend, set_state, extpower_deferred, hook_task, espi_chipset_reset, lpc_chipset_reset ], hook_notify, powerbtn_x86_lid_change ]
# These functions do not call HOOK_BATTERY_SOC_CHANGE
- [ [ s0ix_transition, power_button_change_deferred, jump_to_image, tablet_set_mode, pd_set_suspend, set_state, extpower_deferred, lid_switch_open, lid_switch_close, hook_task, espi_chipset_reset, lpc_chipset_reset ], hook_notify, power_up_inhibited_cb ]
# These functions do not call HOOK_CHIPSET_STARTUP
- [ [ charger_task, power_button_change_deferred, jump_to_image, tablet_set_mode, pd_set_suspend, set_state, extpower_deferred, lid_switch_open, lid_switch_close, hook_task, espi_chipset_reset, lpc_chipset_reset ], hook_notify, board_enable_a1_redriver ]