2019-03-12 00:10:41 +02:00
// SPDX-License-Identifier: GPL-2.0
2013-04-11 03:03:29 +02:00
/*
2022-09-08 00:51:05 +03:00
* Copyright ( c ) 2013 - 2022 , Intel Corporation . All rights reserved .
2013-04-11 03:03:29 +02:00
* Intel Management Engine Interface ( Intel MEI ) Linux driver
*/
# include <linux/kernel.h>
2013-04-11 03:03:31 +02:00
# include <linux/sched.h>
2013-04-11 03:03:29 +02:00
# include <linux/module.h>
# include <linux/device.h>
2014-09-29 16:31:46 +03:00
# include <linux/slab.h>
2015-07-23 15:08:43 +03:00
# include <linux/uuid.h>
2014-09-29 16:31:46 +03:00
2013-04-11 03:03:29 +02:00
# include <linux/mei_cl_bus.h>
# include "mei_dev.h"
# include "client.h"
2022-09-08 00:51:06 +03:00
# include "mkhi.h"
2013-04-11 03:03:29 +02:00
2015-07-23 15:08:44 +03:00
# define MEI_UUID_NFC_INFO UUID_LE(0xd2de1625, 0x382d, 0x417d, \
0x48 , 0xa4 , 0xef , 0xab , 0xba , 0x8a , 0x12 , 0x06 )
2015-07-23 15:08:47 +03:00
static const uuid_le mei_nfc_info_guid = MEI_UUID_NFC_INFO ;
# define MEI_UUID_NFC_HCI UUID_LE(0x0bb17a78, 0x2a8e, 0x4c50, \
0x94 , 0xd4 , 0x50 , 0x26 , 0x67 , 0x23 , 0x77 , 0x5c )
2016-01-08 00:49:24 +02:00
# define MEI_UUID_WD UUID_LE(0x05B79A6F, 0x4628, 0x4D7F, \
0x89 , 0x9D , 0xA9 , 0x15 , 0x14 , 0xCB , 0x32 , 0xAB )
2016-11-10 18:38:57 +02:00
# define MEI_UUID_MKHIF_FIX UUID_LE(0x55213584, 0x9a29, 0x4916, \
0xba , 0xdf , 0xf , 0xb7 , 0xed , 0x68 , 0x2a , 0xeb )
2022-04-19 12:33:12 -07:00
# define MEI_UUID_IGSC_MKHI UUID_LE(0xE2C2AFA2, 0x3817, 0x4D19, \
0x9D , 0x95 , 0x06 , 0xB1 , 0x6B , 0x58 , 0x8A , 0x5D )
# define MEI_UUID_IGSC_MKHI_FIX UUID_LE(0x46E0C1FB, 0xA546, 0x414F, \
0x91 , 0x70 , 0xB7 , 0xF4 , 0x6D , 0x57 , 0xB4 , 0xAD )
2019-02-21 23:41:55 +05:30
# define MEI_UUID_HDCP UUID_LE(0xB638AB7E, 0x94E2, 0x4EA2, \
0xA5 , 0x52 , 0xD1 , 0xC5 , 0x4B , 0x62 , 0x7F , 0x04 )
2020-11-16 14:56:12 +02:00
# define MEI_UUID_PAVP UUID_LE(0xfbf6fcf1, 0x96cf, 0x4e2e, 0xA6, \
0xa6 , 0x1b , 0xab , 0x8c , 0xbe , 0x36 , 0xb1 )
2015-07-23 15:08:43 +03:00
# define MEI_UUID_ANY NULL_UUID_LE
2015-07-23 15:08:45 +03:00
/**
* number_of_connections - determine whether an client be on the bus
* according number of connections
* We support only clients :
* 1. with single connection
* 2. and fixed clients ( max_number_of_connections = = 0 )
*
* @ cldev : me clients device
*/
static void number_of_connections ( struct mei_cl_device * cldev )
{
if ( cldev - > me_cl - > props . max_number_of_connections > 1 )
cldev - > do_match = 0 ;
}
2015-07-23 15:08:44 +03:00
/**
* blacklist - blacklist a client from the bus
*
* @ cldev : me clients device
*/
static void blacklist ( struct mei_cl_device * cldev )
{
cldev - > do_match = 0 ;
}
2019-02-21 23:41:55 +05:30
/**
* whitelist - forcefully whitelist client
*
* @ cldev : me clients device
*/
static void whitelist ( struct mei_cl_device * cldev )
{
cldev - > do_match = 1 ;
}
2016-11-10 18:38:57 +02:00
# define OSTYPE_LINUX 2
struct mei_os_ver {
__le16 build ;
__le16 reserved1 ;
u8 os_type ;
u8 major ;
u8 minor ;
u8 reserved2 ;
} __packed ;
2018-06-25 00:11:41 +03:00
struct mkhi_fw_ver_block {
u16 minor ;
u8 major ;
u8 platform ;
u16 buildno ;
u16 hotfix ;
} __packed ;
struct mkhi_fw_ver {
struct mkhi_fw_ver_block ver [ MEI_MAX_FW_VER_BLOCKS ] ;
} __packed ;
2017-03-20 15:04:05 +02:00
# define MKHI_OSVER_BUF_LEN (sizeof(struct mkhi_msg_hdr) + \
sizeof ( struct mkhi_fwcaps ) + \
sizeof ( struct mei_os_ver ) )
2016-11-10 18:38:57 +02:00
static int mei_osver ( struct mei_cl_device * cldev )
{
2017-03-20 15:04:05 +02:00
const size_t size = MKHI_OSVER_BUF_LEN ;
char buf [ MKHI_OSVER_BUF_LEN ] ;
2016-11-10 18:38:57 +02:00
struct mkhi_msg * req ;
struct mkhi_fwcaps * fwcaps ;
struct mei_os_ver * os_ver ;
unsigned int mode = MEI_CL_IO_TX_BLOCKING | MEI_CL_IO_TX_INTERNAL ;
memset ( buf , 0 , size ) ;
req = ( struct mkhi_msg * ) buf ;
req - > hdr . group_id = MKHI_FWCAPS_GROUP_ID ;
req - > hdr . command = MKHI_FWCAPS_SET_OS_VER_APP_RULE_CMD ;
fwcaps = ( struct mkhi_fwcaps * ) req - > data ;
fwcaps - > id . rule_type = 0x0 ;
fwcaps - > id . feature_id = MKHI_FEATURE_PTT ;
fwcaps - > len = sizeof ( * os_ver ) ;
os_ver = ( struct mei_os_ver * ) fwcaps - > data ;
os_ver - > os_type = OSTYPE_LINUX ;
2020-11-16 14:56:11 +02:00
return __mei_cl_send ( cldev - > cl , buf , size , 0 , mode ) ;
2016-11-10 18:38:57 +02:00
}
2018-06-25 00:11:41 +03:00
# define MKHI_FWVER_BUF_LEN (sizeof(struct mkhi_msg_hdr) + \
sizeof ( struct mkhi_fw_ver ) )
# define MKHI_FWVER_LEN(__num) (sizeof(struct mkhi_msg_hdr) + \
sizeof ( struct mkhi_fw_ver_block ) * ( __num ) )
static int mei_fwver ( struct mei_cl_device * cldev )
{
char buf [ MKHI_FWVER_BUF_LEN ] ;
2020-07-23 17:59:24 +03:00
struct mkhi_msg req ;
struct mkhi_msg * rsp ;
2018-06-25 00:11:41 +03:00
struct mkhi_fw_ver * fwver ;
int bytes_recv , ret , i ;
memset ( buf , 0 , sizeof ( buf ) ) ;
2020-07-23 17:59:24 +03:00
req . hdr . group_id = MKHI_GEN_GROUP_ID ;
req . hdr . command = MKHI_GEN_GET_FW_VERSION_CMD ;
2018-06-25 00:11:41 +03:00
2020-11-16 14:56:11 +02:00
ret = __mei_cl_send ( cldev - > cl , ( u8 * ) & req , sizeof ( req ) , 0 ,
2018-06-25 00:11:41 +03:00
MEI_CL_IO_TX_BLOCKING ) ;
if ( ret < 0 ) {
dev_err ( & cldev - > dev , " Could not send ReqFWVersion cmd \n " ) ;
return ret ;
}
ret = 0 ;
2020-11-16 14:56:11 +02:00
bytes_recv = __mei_cl_recv ( cldev - > cl , buf , sizeof ( buf ) , NULL , 0 ,
2022-09-08 00:51:05 +03:00
cldev - > bus - > timeouts . mkhi_recv ) ;
2018-07-15 14:41:18 +03:00
if ( bytes_recv < 0 | | ( size_t ) bytes_recv < MKHI_FWVER_LEN ( 1 ) ) {
2018-06-25 00:11:41 +03:00
/*
* Should be at least one version block ,
* error out if nothing found
*/
dev_err ( & cldev - > dev , " Could not read FW version \n " ) ;
return - EIO ;
}
2020-07-23 17:59:24 +03:00
rsp = ( struct mkhi_msg * ) buf ;
fwver = ( struct mkhi_fw_ver * ) rsp - > data ;
2018-06-25 00:11:41 +03:00
memset ( cldev - > bus - > fw_ver , 0 , sizeof ( cldev - > bus - > fw_ver ) ) ;
for ( i = 0 ; i < MEI_MAX_FW_VER_BLOCKS ; i + + ) {
2018-07-15 14:41:18 +03:00
if ( ( size_t ) bytes_recv < MKHI_FWVER_LEN ( i + 1 ) )
2018-06-25 00:11:41 +03:00
break ;
dev_dbg ( & cldev - > dev , " FW version%d %d:%d.%d.%d.%d \n " ,
i , fwver - > ver [ i ] . platform ,
fwver - > ver [ i ] . major , fwver - > ver [ i ] . minor ,
fwver - > ver [ i ] . hotfix , fwver - > ver [ i ] . buildno ) ;
cldev - > bus - > fw_ver [ i ] . platform = fwver - > ver [ i ] . platform ;
cldev - > bus - > fw_ver [ i ] . major = fwver - > ver [ i ] . major ;
cldev - > bus - > fw_ver [ i ] . minor = fwver - > ver [ i ] . minor ;
cldev - > bus - > fw_ver [ i ] . hotfix = fwver - > ver [ i ] . hotfix ;
cldev - > bus - > fw_ver [ i ] . buildno = fwver - > ver [ i ] . buildno ;
}
return ret ;
}
2022-09-08 00:51:08 +03:00
static int mei_gfx_memory_ready ( struct mei_cl_device * cldev )
{
struct mkhi_gfx_mem_ready req = { 0 } ;
unsigned int mode = MEI_CL_IO_TX_INTERNAL ;
req . hdr . group_id = MKHI_GROUP_ID_GFX ;
req . hdr . command = MKHI_GFX_MEMORY_READY_CMD_REQ ;
req . flags = MKHI_GFX_MEM_READY_PXP_ALLOWED ;
dev_dbg ( & cldev - > dev , " Sending memory ready command \n " ) ;
return __mei_cl_send ( cldev - > cl , ( u8 * ) & req , sizeof ( req ) , 0 , mode ) ;
}
2016-11-10 18:38:57 +02:00
static void mei_mkhi_fix ( struct mei_cl_device * cldev )
{
int ret ;
2019-10-04 21:17:22 +03:00
/* No need to enable the client if nothing is needed from it */
if ( ! cldev - > bus - > fw_f_fw_ver_supported & &
! cldev - > bus - > hbm_f_os_supported )
return ;
2016-11-10 18:38:57 +02:00
ret = mei_cldev_enable ( cldev ) ;
if ( ret )
return ;
2019-10-04 21:17:22 +03:00
if ( cldev - > bus - > fw_f_fw_ver_supported ) {
ret = mei_fwver ( cldev ) ;
if ( ret < 0 )
dev_err ( & cldev - > dev , " FW version command failed %d \n " ,
ret ) ;
}
2018-06-25 00:11:41 +03:00
if ( cldev - > bus - > hbm_f_os_supported ) {
ret = mei_osver ( cldev ) ;
if ( ret < 0 )
dev_err ( & cldev - > dev , " OS version command failed %d \n " ,
ret ) ;
}
2016-11-10 18:38:57 +02:00
mei_cldev_disable ( cldev ) ;
}
2022-04-19 12:33:12 -07:00
static void mei_gsc_mkhi_ver ( struct mei_cl_device * cldev )
{
int ret ;
/* No need to enable the client if nothing is needed from it */
if ( ! cldev - > bus - > fw_f_fw_ver_supported )
return ;
ret = mei_cldev_enable ( cldev ) ;
if ( ret )
return ;
ret = mei_fwver ( cldev ) ;
if ( ret < 0 )
dev_err ( & cldev - > dev , " FW version command failed %d \n " , ret ) ;
mei_cldev_disable ( cldev ) ;
}
2022-09-08 00:51:08 +03:00
static void mei_gsc_mkhi_fix_ver ( struct mei_cl_device * cldev )
{
int ret ;
/* No need to enable the client if nothing is needed from it */
if ( ! cldev - > bus - > fw_f_fw_ver_supported & &
cldev - > bus - > pxp_mode ! = MEI_DEV_PXP_INIT )
return ;
ret = mei_cldev_enable ( cldev ) ;
if ( ret )
return ;
if ( cldev - > bus - > pxp_mode = = MEI_DEV_PXP_INIT ) {
ret = mei_gfx_memory_ready ( cldev ) ;
if ( ret < 0 )
dev_err ( & cldev - > dev , " memory ready command failed %d \n " , ret ) ;
else
dev_dbg ( & cldev - > dev , " memory ready command sent \n " ) ;
/* we go to reset after that */
cldev - > bus - > pxp_mode = MEI_DEV_PXP_SETUP ;
goto out ;
}
ret = mei_fwver ( cldev ) ;
if ( ret < 0 )
dev_err ( & cldev - > dev , " FW version command failed %d \n " ,
ret ) ;
out :
mei_cldev_disable ( cldev ) ;
}
2016-01-08 00:49:24 +02:00
/**
* mei_wd - wd client on the bus , change protocol version
* as the API has changed .
*
* @ cldev : me clients device
*/
# if IS_ENABLED(CONFIG_INTEL_MEI_ME)
# include <linux/pci.h>
# include "hw-me-regs.h"
static void mei_wd ( struct mei_cl_device * cldev )
{
struct pci_dev * pdev = to_pci_dev ( cldev - > dev . parent ) ;
if ( pdev - > device = = MEI_DEV_ID_WPT_LP | |
pdev - > device = = MEI_DEV_ID_SPT | |
pdev - > device = = MEI_DEV_ID_SPT_H )
cldev - > me_cl - > props . protocol_version = 0x2 ;
cldev - > do_match = 1 ;
}
# else
static inline void mei_wd ( struct mei_cl_device * cldev ) { }
# endif /* CONFIG_INTEL_MEI_ME */
2013-04-11 03:03:29 +02:00
struct mei_nfc_cmd {
u8 command ;
u8 status ;
u16 req_id ;
u32 reserved ;
u16 data_size ;
u8 sub_command ;
u8 data [ ] ;
} __packed ;
struct mei_nfc_reply {
u8 command ;
u8 status ;
u16 req_id ;
u32 reserved ;
u16 data_size ;
u8 sub_command ;
u8 reply_status ;
u8 data [ ] ;
} __packed ;
struct mei_nfc_if_version {
u8 radio_version_sw [ 3 ] ;
u8 reserved [ 3 ] ;
u8 radio_version_hw [ 3 ] ;
u8 i2c_addr ;
u8 fw_ivn ;
u8 vendor_id ;
u8 radio_type ;
} __packed ;
# define MEI_NFC_CMD_MAINTENANCE 0x00
# define MEI_NFC_SUBCMD_IF_VERSION 0x01
2013-04-11 03:03:30 +02:00
/* Vendors */
# define MEI_NFC_VENDOR_INSIDE 0x00
# define MEI_NFC_VENDOR_NXP 0x01
/* Radio types */
# define MEI_NFC_VENDOR_INSIDE_UREAD 0x00
# define MEI_NFC_VENDOR_NXP_PN544 0x01
2015-07-23 15:08:46 +03:00
/**
* mei_nfc_if_version - get NFC interface version
*
* @ cl : host client ( nfc info )
* @ ver : NFC interface version to be filled in
*
* Return : 0 on success ; < 0 otherwise
*/
static int mei_nfc_if_version ( struct mei_cl * cl ,
struct mei_nfc_if_version * ver )
2013-04-11 03:03:29 +02:00
{
2015-07-23 15:08:33 +03:00
struct mei_device * bus ;
2015-07-23 15:08:46 +03:00
struct mei_nfc_cmd cmd = {
. command = MEI_NFC_CMD_MAINTENANCE ,
. data_size = 1 ,
. sub_command = MEI_NFC_SUBCMD_IF_VERSION ,
} ;
2013-04-11 03:03:29 +02:00
struct mei_nfc_reply * reply = NULL ;
size_t if_version_length ;
2020-11-16 14:56:11 +02:00
u8 vtag ;
2013-04-11 03:03:29 +02:00
int bytes_recv , ret ;
2015-07-23 15:08:33 +03:00
bus = cl - > dev ;
2013-04-11 03:03:29 +02:00
2015-07-23 15:08:46 +03:00
WARN_ON ( mutex_is_locked ( & bus - > device_lock ) ) ;
2013-04-11 03:03:29 +02:00
2020-11-16 14:56:11 +02:00
ret = __mei_cl_send ( cl , ( u8 * ) & cmd , sizeof ( cmd ) , 0 ,
MEI_CL_IO_TX_BLOCKING ) ;
2013-04-11 03:03:29 +02:00
if ( ret < 0 ) {
2015-07-23 15:08:33 +03:00
dev_err ( bus - > dev , " Could not send IF version cmd \n " ) ;
2013-04-11 03:03:29 +02:00
return ret ;
}
/* to be sure on the stack we alloc memory */
2020-07-23 17:59:24 +03:00
if_version_length = sizeof ( * reply ) + sizeof ( * ver ) ;
2013-04-11 03:03:29 +02:00
reply = kzalloc ( if_version_length , GFP_KERNEL ) ;
if ( ! reply )
return - ENOMEM ;
2015-07-23 15:08:46 +03:00
ret = 0 ;
2020-11-16 14:56:11 +02:00
bytes_recv = __mei_cl_recv ( cl , ( u8 * ) reply , if_version_length , & vtag ,
0 , 0 ) ;
2018-07-15 14:41:18 +03:00
if ( bytes_recv < 0 | | ( size_t ) bytes_recv < if_version_length ) {
2015-07-23 15:08:33 +03:00
dev_err ( bus - > dev , " Could not read IF version \n " ) ;
2013-04-11 03:03:29 +02:00
ret = - EIO ;
goto err ;
}
2020-07-23 17:59:24 +03:00
memcpy ( ver , reply - > data , sizeof ( * ver ) ) ;
2013-04-11 03:03:29 +02:00
2015-07-23 15:08:46 +03:00
dev_info ( bus - > dev , " NFC MEI VERSION: IVN 0x%x Vendor ID 0x%x Type 0x%x \n " ,
ver - > fw_ivn , ver - > vendor_id , ver - > radio_type ) ;
2013-04-11 03:03:29 +02:00
err :
kfree ( reply ) ;
return ret ;
}
2015-07-23 15:08:46 +03:00
/**
* mei_nfc_radio_name - derive nfc radio name from the interface version
*
* @ ver : NFC radio version
*
* Return : radio name string
*/
static const char * mei_nfc_radio_name ( struct mei_nfc_if_version * ver )
{
if ( ver - > vendor_id = = MEI_NFC_VENDOR_INSIDE ) {
if ( ver - > radio_type = = MEI_NFC_VENDOR_INSIDE_UREAD )
return " microread " ;
}
if ( ver - > vendor_id = = MEI_NFC_VENDOR_NXP ) {
if ( ver - > radio_type = = MEI_NFC_VENDOR_NXP_PN544 )
return " pn544 " ;
}
return NULL ;
}
2015-07-23 15:08:47 +03:00
/**
* mei_nfc - The nfc fixup function . The function retrieves nfc radio
* name and set is as device attribute so we can load
* the proper device driver for it
*
* @ cldev : me client device ( nfc )
*/
static void mei_nfc ( struct mei_cl_device * cldev )
2013-04-11 03:03:29 +02:00
{
2015-07-23 15:08:33 +03:00
struct mei_device * bus ;
2015-07-23 15:08:47 +03:00
struct mei_cl * cl ;
struct mei_me_client * me_cl = NULL ;
struct mei_nfc_if_version ver ;
const char * radio_name = NULL ;
int ret ;
2013-04-11 03:03:29 +02:00
2015-07-23 15:08:47 +03:00
bus = cldev - > bus ;
2013-04-11 03:03:29 +02:00
2015-07-23 15:08:33 +03:00
mutex_lock ( & bus - > device_lock ) ;
2015-07-23 15:08:47 +03:00
/* we need to connect to INFO GUID */
2016-02-07 23:35:40 +02:00
cl = mei_cl_alloc_linked ( bus ) ;
2015-07-23 15:08:47 +03:00
if ( IS_ERR ( cl ) ) {
ret = PTR_ERR ( cl ) ;
cl = NULL ;
dev_err ( bus - > dev , " nfc hook alloc failed %d \n " , ret ) ;
goto out ;
2013-04-11 03:03:29 +02:00
}
2015-07-23 15:08:47 +03:00
me_cl = mei_me_cl_by_uuid ( bus , & mei_nfc_info_guid ) ;
if ( ! me_cl ) {
ret = - ENOTTY ;
dev_err ( bus - > dev , " Cannot find nfc info %d \n " , ret ) ;
goto out ;
2013-04-11 03:03:29 +02:00
}
2015-07-23 15:08:47 +03:00
ret = mei_cl_connect ( cl , me_cl , NULL ) ;
if ( ret < 0 ) {
dev_err ( & cldev - > dev , " Can't connect to the NFC INFO ME ret = %d \n " ,
ret ) ;
goto out ;
2013-04-11 03:03:29 +02:00
}
2015-07-23 15:08:33 +03:00
mutex_unlock ( & bus - > device_lock ) ;
2013-04-11 03:03:29 +02:00
2015-07-23 15:08:47 +03:00
ret = mei_nfc_if_version ( cl , & ver ) ;
if ( ret )
goto disconnect ;
2015-07-23 15:08:46 +03:00
2015-07-23 15:08:47 +03:00
radio_name = mei_nfc_radio_name ( & ver ) ;
2013-04-11 03:03:30 +02:00
2015-07-23 15:08:47 +03:00
if ( ! radio_name ) {
ret = - ENOENT ;
dev_err ( & cldev - > dev , " Can't get the NFC interface version ret = %d \n " ,
ret ) ;
goto disconnect ;
2013-04-11 03:03:30 +02:00
}
2015-07-23 15:08:47 +03:00
dev_dbg ( bus - > dev , " nfc radio %s \n " , radio_name ) ;
2022-08-18 23:00:31 +02:00
strscpy ( cldev - > name , radio_name , sizeof ( cldev - > name ) ) ;
2013-04-11 03:03:29 +02:00
2015-07-23 15:08:47 +03:00
disconnect :
2015-07-23 15:08:33 +03:00
mutex_lock ( & bus - > device_lock ) ;
2015-07-23 15:08:47 +03:00
if ( mei_cl_disconnect ( cl ) < 0 )
dev_err ( bus - > dev , " Can't disconnect the NFC INFO ME \n " ) ;
2013-04-11 03:03:29 +02:00
2015-07-23 15:08:47 +03:00
mei_cl_flush_queues ( cl , NULL ) ;
2013-04-11 03:03:29 +02:00
2015-07-23 15:08:47 +03:00
out :
mei_cl_unlink ( cl ) ;
mutex_unlock ( & bus - > device_lock ) ;
mei_me_cl_put ( me_cl ) ;
kfree ( cl ) ;
2013-04-11 03:03:29 +02:00
2015-07-23 15:08:47 +03:00
if ( ret )
cldev - > do_match = 0 ;
2015-07-08 00:22:03 +03:00
2015-07-23 15:08:47 +03:00
dev_dbg ( bus - > dev , " end of fixup match = %d \n " , cldev - > do_match ) ;
2014-02-17 15:13:19 +02:00
}
2013-11-11 13:26:06 +02:00
2020-08-18 14:51:44 +03:00
/**
* vt_support - enable on bus clients with vtag support
*
* @ cldev : me clients device
*/
static void vt_support ( struct mei_cl_device * cldev )
{
if ( cldev - > me_cl - > props . vt_supported = = 1 )
cldev - > do_match = 1 ;
}
2022-09-08 00:51:08 +03:00
/**
* pxp_is_ready - enable bus client if pxp is ready
*
* @ cldev : me clients device
*/
static void pxp_is_ready ( struct mei_cl_device * cldev )
{
struct mei_device * bus = cldev - > bus ;
switch ( bus - > pxp_mode ) {
case MEI_DEV_PXP_READY :
case MEI_DEV_PXP_DEFAULT :
cldev - > do_match = 1 ;
break ;
default :
cldev - > do_match = 0 ;
break ;
}
}
2015-07-23 15:08:43 +03:00
# define MEI_FIXUP(_uuid, _hook) { _uuid, _hook }
static struct mei_fixup {
const uuid_le uuid ;
void ( * hook ) ( struct mei_cl_device * cldev ) ;
2015-07-23 15:08:44 +03:00
} mei_fixups [ ] = {
2015-07-23 15:08:45 +03:00
MEI_FIXUP ( MEI_UUID_ANY , number_of_connections ) ,
2015-07-23 15:08:44 +03:00
MEI_FIXUP ( MEI_UUID_NFC_INFO , blacklist ) ,
2015-07-23 15:08:47 +03:00
MEI_FIXUP ( MEI_UUID_NFC_HCI , mei_nfc ) ,
2016-01-08 00:49:24 +02:00
MEI_FIXUP ( MEI_UUID_WD , mei_wd ) ,
2016-11-10 18:38:57 +02:00
MEI_FIXUP ( MEI_UUID_MKHIF_FIX , mei_mkhi_fix ) ,
2022-04-19 12:33:12 -07:00
MEI_FIXUP ( MEI_UUID_IGSC_MKHI , mei_gsc_mkhi_ver ) ,
2022-09-08 00:51:08 +03:00
MEI_FIXUP ( MEI_UUID_IGSC_MKHI_FIX , mei_gsc_mkhi_fix_ver ) ,
2019-02-21 23:41:55 +05:30
MEI_FIXUP ( MEI_UUID_HDCP , whitelist ) ,
2020-08-18 14:51:44 +03:00
MEI_FIXUP ( MEI_UUID_ANY , vt_support ) ,
2022-09-08 00:51:08 +03:00
MEI_FIXUP ( MEI_UUID_PAVP , pxp_is_ready ) ,
2015-07-23 15:08:44 +03:00
} ;
2015-07-23 15:08:43 +03:00
/**
2021-06-21 22:37:55 +03:00
* mei_cl_bus_dev_fixup - run fixup handlers
2015-07-23 15:08:43 +03:00
*
* @ cldev : me client device
*/
2015-09-10 10:18:06 +03:00
void mei_cl_bus_dev_fixup ( struct mei_cl_device * cldev )
2015-07-23 15:08:43 +03:00
{
struct mei_fixup * f ;
const uuid_le * uuid = mei_me_cl_uuid ( cldev - > me_cl ) ;
2018-07-12 17:10:09 +03:00
size_t i ;
2015-07-23 15:08:43 +03:00
for ( i = 0 ; i < ARRAY_SIZE ( mei_fixups ) ; i + + ) {
f = & mei_fixups [ i ] ;
if ( uuid_le_cmp ( f - > uuid , MEI_UUID_ANY ) = = 0 | |
uuid_le_cmp ( f - > uuid , * uuid ) = = 0 )
f - > hook ( cldev ) ;
}
}
2013-04-11 03:03:30 +02:00