Kevin Barnett | 6c22376 | 2016-06-27 16:41:00 -0500 | [diff] [blame] | 1 | /* |
| 2 | * driver for Microsemi PQI-based storage controllers |
Don Brace | 2f4c4b9 | 2019-03-14 16:58:02 -0500 | [diff] [blame^] | 3 | * Copyright (c) 2019 Microchip Technology Inc. and its subsidiaries |
| 4 | * Copyright (c) 2016-2018 Microsemi Corporation |
Kevin Barnett | 6c22376 | 2016-06-27 16:41:00 -0500 | [diff] [blame] | 5 | * Copyright (c) 2016 PMC-Sierra, Inc. |
| 6 | * |
| 7 | * This program is free software; you can redistribute it and/or modify |
| 8 | * it under the terms of the GNU General Public License as published by |
| 9 | * the Free Software Foundation; version 2 of the License. |
| 10 | * |
| 11 | * This program is distributed in the hope that it will be useful, |
| 12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 13 | * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE, GOOD TITLE or |
| 14 | * NON INFRINGEMENT. See the GNU General Public License for more details. |
| 15 | * |
Don Brace | 2f4c4b9 | 2019-03-14 16:58:02 -0500 | [diff] [blame^] | 16 | * Questions/Comments/Bugfixes to storagedev@microchip.com |
Kevin Barnett | 6c22376 | 2016-06-27 16:41:00 -0500 | [diff] [blame] | 17 | * |
| 18 | */ |
| 19 | |
| 20 | #if !defined(_SMARTPQI_SIS_H) |
| 21 | #define _SMARTPQI_SIS_H |
| 22 | |
| 23 | int sis_wait_for_ctrl_ready(struct pqi_ctrl_info *ctrl_info); |
Kevin Barnett | 061ef06 | 2017-05-03 18:53:05 -0500 | [diff] [blame] | 24 | int sis_wait_for_ctrl_ready_resume(struct pqi_ctrl_info *ctrl_info); |
Kevin Barnett | 6c22376 | 2016-06-27 16:41:00 -0500 | [diff] [blame] | 25 | bool sis_is_firmware_running(struct pqi_ctrl_info *ctrl_info); |
Kevin Barnett | 162d775 | 2017-05-03 18:52:46 -0500 | [diff] [blame] | 26 | bool sis_is_kernel_up(struct pqi_ctrl_info *ctrl_info); |
Kevin Barnett | 6c22376 | 2016-06-27 16:41:00 -0500 | [diff] [blame] | 27 | int sis_get_ctrl_properties(struct pqi_ctrl_info *ctrl_info); |
| 28 | int sis_get_pqi_capabilities(struct pqi_ctrl_info *ctrl_info); |
| 29 | int sis_init_base_struct_addr(struct pqi_ctrl_info *ctrl_info); |
| 30 | void sis_enable_msix(struct pqi_ctrl_info *ctrl_info); |
Kevin Barnett | 061ef06 | 2017-05-03 18:53:05 -0500 | [diff] [blame] | 31 | void sis_enable_intx(struct pqi_ctrl_info *ctrl_info); |
Kevin Barnett | 5b0fba0 | 2017-05-03 18:52:40 -0500 | [diff] [blame] | 32 | void sis_shutdown_ctrl(struct pqi_ctrl_info *ctrl_info); |
Kevin Barnett | 336b681 | 2017-08-10 13:46:39 -0500 | [diff] [blame] | 33 | int sis_pqi_reset_quiesce(struct pqi_ctrl_info *ctrl_info); |
Kevin Barnett | 6c22376 | 2016-06-27 16:41:00 -0500 | [diff] [blame] | 34 | int sis_reenable_sis_mode(struct pqi_ctrl_info *ctrl_info); |
Kevin Barnett | ff6abb7 | 2016-08-31 14:54:41 -0500 | [diff] [blame] | 35 | void sis_write_driver_scratch(struct pqi_ctrl_info *ctrl_info, u32 value); |
| 36 | u32 sis_read_driver_scratch(struct pqi_ctrl_info *ctrl_info); |
Mahesh Rajashekhara | 4fd22c1 | 2018-12-18 17:39:07 -0600 | [diff] [blame] | 37 | void sis_soft_reset(struct pqi_ctrl_info *ctrl_info); |
Kevin Barnett | 6c22376 | 2016-06-27 16:41:00 -0500 | [diff] [blame] | 38 | |
| 39 | #endif /* _SMARTPQI_SIS_H */ |