^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1) /* SPDX-License-Identifier: GPL-2.0 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 3) * driver for Microsemi PQI-based storage controllers
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 4) * Copyright (c) 2019-2020 Microchip Technology Inc. and its subsidiaries
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 5) * Copyright (c) 2016-2018 Microsemi Corporation
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 6) * Copyright (c) 2016 PMC-Sierra, Inc.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 7) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 8) * Questions/Comments/Bugfixes to storagedev@microchip.com
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 9) *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12) #if !defined(_SMARTPQI_SIS_H)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13) #define _SMARTPQI_SIS_H
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15) int sis_wait_for_ctrl_ready(struct pqi_ctrl_info *ctrl_info);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16) int sis_wait_for_ctrl_ready_resume(struct pqi_ctrl_info *ctrl_info);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17) bool sis_is_firmware_running(struct pqi_ctrl_info *ctrl_info);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18) bool sis_is_kernel_up(struct pqi_ctrl_info *ctrl_info);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19) int sis_get_ctrl_properties(struct pqi_ctrl_info *ctrl_info);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) int sis_get_pqi_capabilities(struct pqi_ctrl_info *ctrl_info);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21) int sis_init_base_struct_addr(struct pqi_ctrl_info *ctrl_info);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22) void sis_enable_msix(struct pqi_ctrl_info *ctrl_info);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23) void sis_enable_intx(struct pqi_ctrl_info *ctrl_info);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24) void sis_shutdown_ctrl(struct pqi_ctrl_info *ctrl_info);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25) int sis_pqi_reset_quiesce(struct pqi_ctrl_info *ctrl_info);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 26) int sis_reenable_sis_mode(struct pqi_ctrl_info *ctrl_info);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 27) void sis_write_driver_scratch(struct pqi_ctrl_info *ctrl_info, u32 value);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 28) u32 sis_read_driver_scratch(struct pqi_ctrl_info *ctrl_info);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 29) void sis_soft_reset(struct pqi_ctrl_info *ctrl_info);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 30)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 31) #endif /* _SMARTPQI_SIS_H */