Oren Weil | 3ce7272 | 2011-05-15 13:43:43 +0300 | [diff] [blame] | 1 | /* |
| 2 | * |
| 3 | * Intel Management Engine Interface (Intel MEI) Linux driver |
Tomas Winkler | 733ba91 | 2012-02-09 19:25:53 +0200 | [diff] [blame] | 4 | * Copyright (c) 2003-2012, Intel Corporation. |
Oren Weil | 3ce7272 | 2011-05-15 13:43:43 +0300 | [diff] [blame] | 5 | * |
| 6 | * This program is free software; you can redistribute it and/or modify it |
| 7 | * under the terms and conditions of the GNU General Public License, |
| 8 | * version 2, as published by the Free Software Foundation. |
| 9 | * |
| 10 | * This program is distributed in the hope it will be useful, but WITHOUT |
| 11 | * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
| 12 | * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for |
| 13 | * more details. |
| 14 | * |
| 15 | */ |
| 16 | |
| 17 | |
| 18 | |
| 19 | #ifndef _MEI_INTERFACE_H_ |
| 20 | #define _MEI_INTERFACE_H_ |
| 21 | |
Tomas Winkler | 4f3afe1 | 2012-05-09 16:38:59 +0300 | [diff] [blame] | 22 | #include <linux/mei.h> |
Oren Weil | 3ce7272 | 2011-05-15 13:43:43 +0300 | [diff] [blame] | 23 | #include "mei_dev.h" |
| 24 | |
| 25 | |
Oren Weil | 9ce178e | 2011-09-07 09:03:09 +0300 | [diff] [blame] | 26 | #define AMT_WD_DEFAULT_TIMEOUT 120 /* seconds */ |
| 27 | #define AMT_WD_MIN_TIMEOUT 120 /* seconds */ |
| 28 | #define AMT_WD_MAX_TIMEOUT 65535 /* seconds */ |
Oren Weil | 3ce7272 | 2011-05-15 13:43:43 +0300 | [diff] [blame] | 29 | |
| 30 | #define MEI_WATCHDOG_DATA_SIZE 16 |
| 31 | #define MEI_START_WD_DATA_SIZE 20 |
| 32 | #define MEI_WD_PARAMS_SIZE 4 |
| 33 | |
| 34 | |
| 35 | void mei_read_slots(struct mei_device *dev, |
Tomas Winkler | edf1eed | 2012-02-09 19:25:54 +0200 | [diff] [blame] | 36 | unsigned char *buffer, |
| 37 | unsigned long buffer_length); |
Oren Weil | 3ce7272 | 2011-05-15 13:43:43 +0300 | [diff] [blame] | 38 | |
| 39 | int mei_write_message(struct mei_device *dev, |
| 40 | struct mei_msg_hdr *header, |
| 41 | unsigned char *write_buffer, |
| 42 | unsigned long write_length); |
| 43 | |
| 44 | int mei_host_buffer_is_empty(struct mei_device *dev); |
| 45 | |
| 46 | int mei_count_full_read_slots(struct mei_device *dev); |
| 47 | |
| 48 | int mei_count_empty_write_slots(struct mei_device *dev); |
| 49 | |
| 50 | int mei_flow_ctrl_creds(struct mei_device *dev, struct mei_cl *cl); |
| 51 | |
| 52 | int mei_wd_send(struct mei_device *dev); |
| 53 | int mei_wd_stop(struct mei_device *dev, bool preserve); |
Tomas Winkler | 9487eb0 | 2012-04-03 23:34:58 +0300 | [diff] [blame] | 54 | int mei_wd_host_init(struct mei_device *dev); |
Tomas Winkler | 70cd533 | 2011-12-22 18:50:50 +0200 | [diff] [blame] | 55 | /* |
| 56 | * mei_watchdog_register - Registering watchdog interface |
| 57 | * once we got connection to the WD Client |
| 58 | * @dev - mei device |
| 59 | */ |
| 60 | void mei_watchdog_register(struct mei_device *dev); |
| 61 | /* |
Justin P. Mattock | 5f9092f3 | 2012-03-12 07:18:09 -0700 | [diff] [blame] | 62 | * mei_watchdog_unregister - Unregistering watchdog interface |
Tomas Winkler | 70cd533 | 2011-12-22 18:50:50 +0200 | [diff] [blame] | 63 | * @dev - mei device |
| 64 | */ |
| 65 | void mei_watchdog_unregister(struct mei_device *dev); |
Oren Weil | 3ce7272 | 2011-05-15 13:43:43 +0300 | [diff] [blame] | 66 | |
| 67 | int mei_flow_ctrl_reduce(struct mei_device *dev, struct mei_cl *cl); |
| 68 | |
| 69 | int mei_send_flow_control(struct mei_device *dev, struct mei_cl *cl); |
| 70 | |
| 71 | int mei_disconnect(struct mei_device *dev, struct mei_cl *cl); |
| 72 | int mei_other_client_is_connecting(struct mei_device *dev, struct mei_cl *cl); |
| 73 | int mei_connect(struct mei_device *dev, struct mei_cl *cl); |
| 74 | |
| 75 | #endif /* _MEI_INTERFACE_H_ */ |