2019-03-12 00:10:41 +02:00
/* SPDX-License-Identifier: GPL-2.0 */
2013-01-08 23:07:14 +02:00
/*
2019-03-12 00:10:44 +02:00
* Copyright ( c ) 2003 - 2018 , Intel Corporation . All rights reserved .
2013-01-08 23:07:14 +02:00
* Intel Management Engine Interface ( Intel MEI ) Linux driver
*/
# ifndef _MEI_CLIENT_H_
# define _MEI_CLIENT_H_
# include <linux/types.h>
# include <linux/poll.h>
# include <linux/mei.h>
# include "mei_dev.h"
2015-01-11 00:07:16 +02:00
/*
* reference counting base function
*/
void mei_me_cl_init ( struct mei_me_client * me_cl ) ;
void mei_me_cl_put ( struct mei_me_client * me_cl ) ;
struct mei_me_client * mei_me_cl_get ( struct mei_me_client * me_cl ) ;
2015-02-10 10:39:31 +02:00
void mei_me_cl_add ( struct mei_device * dev , struct mei_me_client * me_cl ) ;
void mei_me_cl_del ( struct mei_device * dev , struct mei_me_client * me_cl ) ;
struct mei_me_client * mei_me_cl_by_uuid ( struct mei_device * dev ,
2015-01-11 00:07:16 +02:00
const uuid_le * uuid ) ;
2014-08-24 12:08:55 +03:00
struct mei_me_client * mei_me_cl_by_id ( struct mei_device * dev , u8 client_id ) ;
2014-08-21 14:29:15 +03:00
struct mei_me_client * mei_me_cl_by_uuid_id ( struct mei_device * dev ,
const uuid_le * uuid , u8 client_id ) ;
2015-01-11 00:07:16 +02:00
void mei_me_cl_rm_by_uuid ( struct mei_device * dev , const uuid_le * uuid ) ;
void mei_me_cl_rm_by_uuid_id ( struct mei_device * dev ,
const uuid_le * uuid , u8 id ) ;
void mei_me_cl_rm_all ( struct mei_device * dev ) ;
2013-01-08 23:07:14 +02:00
2015-05-04 09:43:54 +03:00
/**
* mei_me_cl_is_active - check whether me client is active in the fw
*
* @ me_cl : me client
*
* Return : true if the me client is active in the firmware
*/
static inline bool mei_me_cl_is_active ( const struct mei_me_client * me_cl )
{
return ! list_empty_careful ( & me_cl - > list ) ;
}
/**
* mei_me_cl_uuid - return me client protocol name ( uuid )
*
* @ me_cl : me client
*
* Return : me client protocol name
*/
static inline const uuid_le * mei_me_cl_uuid ( const struct mei_me_client * me_cl )
{
return & me_cl - > props . protocol_name ;
}
2015-09-10 10:18:00 +03:00
/**
* mei_me_cl_ver - return me client protocol version
*
* @ me_cl : me client
*
* Return : me client protocol version
*/
static inline u8 mei_me_cl_ver ( const struct mei_me_client * me_cl )
{
return me_cl - > props . protocol_version ;
}
2019-11-16 16:21:36 +02:00
/**
* mei_me_cl_max_conn - return me client max number of connections
*
* @ me_cl : me client
*
* Return : me client max number of connections
*/
static inline u8 mei_me_cl_max_conn ( const struct mei_me_client * me_cl )
{
return me_cl - > props . max_number_of_connections ;
}
/**
* mei_me_cl_fixed - return me client fixed address , if any
*
* @ me_cl : me client
*
* Return : me client fixed address
*/
static inline u8 mei_me_cl_fixed ( const struct mei_me_client * me_cl )
{
return me_cl - > props . fixed_address ;
}
2020-08-18 14:51:37 +03:00
/**
* mei_me_cl_vt - return me client vtag supported status
*
* @ me_cl : me client
*
* Return : true if me client supports vt tagging
*/
static inline bool mei_me_cl_vt ( const struct mei_me_client * me_cl )
{
return me_cl - > props . vt_supported = = 1 ;
}
2019-11-16 16:21:36 +02:00
/**
* mei_me_cl_max_len - return me client max msg length
*
* @ me_cl : me client
*
* Return : me client max msg length
*/
static inline u32 mei_me_cl_max_len ( const struct mei_me_client * me_cl )
{
return me_cl - > props . max_msg_length ;
}
2013-01-08 23:07:14 +02:00
/*
* MEI IO Functions
*/
void mei_io_cb_free ( struct mei_cl_cb * priv_cb ) ;
/*
* MEI Host Client Functions
*/
struct mei_cl * mei_cl_allocate ( struct mei_device * dev ) ;
2016-02-07 23:35:40 +02:00
int mei_cl_link ( struct mei_cl * cl ) ;
2013-01-08 23:07:14 +02:00
int mei_cl_unlink ( struct mei_cl * cl ) ;
2016-02-07 23:35:40 +02:00
struct mei_cl * mei_cl_alloc_linked ( struct mei_device * dev ) ;
2015-02-10 10:39:44 +02:00
2020-08-18 14:51:40 +03:00
struct mei_cl_cb * mei_cl_read_cb ( struct mei_cl * cl , const struct file * fp ) ;
void mei_cl_add_rd_completed ( struct mei_cl * cl , struct mei_cl_cb * cb ) ;
void mei_cl_del_rd_completed ( struct mei_cl * cl , struct mei_cl_cb * cb ) ;
2015-02-10 10:39:43 +02:00
struct mei_cl_cb * mei_cl_alloc_cb ( struct mei_cl * cl , size_t length ,
2016-02-07 23:35:23 +02:00
enum mei_cb_file_ops type ,
const struct file * fp ) ;
2016-07-26 01:06:05 +03:00
struct mei_cl_cb * mei_cl_enqueue_ctrl_wr_cb ( struct mei_cl * cl , size_t length ,
enum mei_cb_file_ops type ,
const struct file * fp ) ;
2015-02-10 10:39:46 +02:00
int mei_cl_flush_queues ( struct mei_cl * cl , const struct file * fp ) ;
2013-01-08 23:07:14 +02:00
2020-08-18 14:51:41 +03:00
struct mei_cl_vtag * mei_cl_vtag_alloc ( struct file * fp , u8 vtag ) ;
const struct file * mei_cl_fp_by_vtag ( const struct mei_cl * cl , u8 vtag ) ;
int mei_cl_vt_support_check ( const struct mei_cl * cl ) ;
2013-01-08 23:07:14 +02:00
/*
* MEI input output function prototype
*/
2015-03-27 00:27:59 +02:00
/**
* mei_cl_is_connected - host client is connected
*
2015-05-04 09:43:54 +03:00
* @ cl : host client
2015-03-27 00:27:59 +02:00
*
2015-05-04 09:43:54 +03:00
* Return : true if the host client is connected
2015-03-27 00:27:59 +02:00
*/
2013-07-25 20:15:53 +03:00
static inline bool mei_cl_is_connected ( struct mei_cl * cl )
{
2015-03-19 12:10:09 +02:00
return cl - > state = = MEI_FILE_CONNECTED ;
2013-07-25 20:15:53 +03:00
}
2015-05-04 09:43:54 +03:00
/**
* mei_cl_me_id - me client id
*
* @ cl : host client
*
* Return : me client id or 0 if client is not connected
*/
static inline u8 mei_cl_me_id ( const struct mei_cl * cl )
{
return cl - > me_cl ? cl - > me_cl - > client_id : 0 ;
}
/**
* mei_cl_mtu - maximal message that client can send and receive
*
* @ cl : host client
*
* Return : mtu
*/
static inline size_t mei_cl_mtu ( const struct mei_cl * cl )
{
return cl - > me_cl - > props . max_msg_length ;
}
/**
* mei_cl_is_fixed_address - check whether the me client uses fixed address
*
* @ cl : host client
*
* Return : true if the client is connected and it has fixed me address
*/
static inline bool mei_cl_is_fixed_address ( const struct mei_cl * cl )
{
return cl - > me_cl & & cl - > me_cl - > props . fixed_address ;
}
/**
* mei_cl_is_single_recv_buf - check whether the me client
* uses single receiving buffer
*
* @ cl : host client
*
* Return : true if single_recv_buf = = 1 ; 0 otherwise
*/
static inline bool mei_cl_is_single_recv_buf ( const struct mei_cl * cl )
{
return cl - > me_cl - > props . single_recv_buf ;
}
/**
* mei_cl_uuid - client ' s uuid
*
* @ cl : host client
*
* Return : return uuid of connected me client
*/
static inline const uuid_le * mei_cl_uuid ( const struct mei_cl * cl )
{
return mei_me_cl_uuid ( cl - > me_cl ) ;
}
2015-05-04 09:43:56 +03:00
/**
* mei_cl_host_addr - client ' s host address
*
* @ cl : host client
*
* Return : 0 for fixed address client , host address for dynamic client
*/
static inline u8 mei_cl_host_addr ( const struct mei_cl * cl )
{
return mei_cl_is_fixed_address ( cl ) ? 0 : cl - > host_client_id ;
}
2013-01-08 23:07:14 +02:00
int mei_cl_disconnect ( struct mei_cl * cl ) ;
2015-05-04 09:43:52 +03:00
int mei_cl_irq_disconnect ( struct mei_cl * cl , struct mei_cl_cb * cb ,
2017-01-27 16:32:45 +02:00
struct list_head * cmpl_list ) ;
2015-05-04 09:43:54 +03:00
int mei_cl_connect ( struct mei_cl * cl , struct mei_me_client * me_cl ,
2016-02-07 23:35:23 +02:00
const struct file * file ) ;
2015-05-04 09:43:53 +03:00
int mei_cl_irq_connect ( struct mei_cl * cl , struct mei_cl_cb * cb ,
2017-01-27 16:32:45 +02:00
struct list_head * cmpl_list ) ;
2016-02-07 23:35:23 +02:00
int mei_cl_read_start ( struct mei_cl * cl , size_t length , const struct file * fp ) ;
2018-07-12 17:10:10 +03:00
ssize_t mei_cl_write ( struct mei_cl * cl , struct mei_cl_cb * cb ) ;
2014-02-19 17:35:48 +02:00
int mei_cl_irq_write ( struct mei_cl * cl , struct mei_cl_cb * cb ,
2017-01-27 16:32:45 +02:00
struct list_head * cmpl_list ) ;
2013-06-23 09:36:59 +03:00
2013-05-12 15:34:45 +03:00
void mei_cl_complete ( struct mei_cl * cl , struct mei_cl_cb * cb ) ;
2013-01-08 23:07:14 +02:00
2016-02-07 23:35:43 +02:00
void mei_host_client_init ( struct mei_device * dev ) ;
2013-01-08 23:07:14 +02:00
2015-07-26 09:54:18 +03:00
u8 mei_cl_notify_fop2req ( enum mei_cb_file_ops fop ) ;
enum mei_cb_file_ops mei_cl_notify_req2fop ( u8 request ) ;
2016-02-07 23:35:23 +02:00
int mei_cl_notify_request ( struct mei_cl * cl ,
const struct file * file , u8 request ) ;
2015-07-26 09:54:18 +03:00
int mei_cl_irq_notify ( struct mei_cl * cl , struct mei_cl_cb * cb ,
2017-01-27 16:32:45 +02:00
struct list_head * cmpl_list ) ;
2015-07-26 09:54:19 +03:00
int mei_cl_notify_get ( struct mei_cl * cl , bool block , bool * notify_ev ) ;
2015-07-26 09:54:22 +03:00
void mei_cl_notify ( struct mei_cl * cl ) ;
2015-07-26 09:54:18 +03:00
2013-02-06 14:06:44 +02:00
void mei_cl_all_disconnect ( struct mei_device * dev ) ;
2013-09-15 18:11:07 +03:00
# define MEI_CL_FMT "cl:host=%02d me=%02d "
2015-05-04 09:43:54 +03:00
# define MEI_CL_PRM(cl) (cl)->host_client_id, mei_cl_me_id(cl)
2013-09-15 18:11:07 +03:00
# define cl_dbg(dev, cl, format, arg...) \
2014-09-29 16:31:42 +03:00
dev_dbg ( ( dev ) - > dev , MEI_CL_FMT format , MEI_CL_PRM ( cl ) , # # arg )
2013-09-15 18:11:07 +03:00
2016-02-07 23:35:39 +02:00
# define cl_warn(dev, cl, format, arg...) \
dev_warn ( ( dev ) - > dev , MEI_CL_FMT format , MEI_CL_PRM ( cl ) , # # arg )
2013-09-15 18:11:07 +03:00
# define cl_err(dev, cl, format, arg...) \
2014-09-29 16:31:42 +03:00
dev_err ( ( dev ) - > dev , MEI_CL_FMT format , MEI_CL_PRM ( cl ) , # # arg )
2013-09-15 18:11:07 +03:00
2013-01-08 23:07:14 +02:00
# endif /* _MEI_CLIENT_H_ */