2018-02-07 09:05:46 -05:00
/* SPDX-License-Identifier: GPL-2.0-only */
2016-11-14 11:55:20 -02:00
/*
* cec - notifier . h - notify CEC drivers of physical address changes
*
* Copyright 2016 Russell King < rmk + kernel @ arm . linux . org . uk >
* Copyright 2016 - 2017 Cisco Systems , Inc . and / or its affiliates . All rights reserved .
*/
# ifndef LINUX_CEC_NOTIFIER_H
# define LINUX_CEC_NOTIFIER_H
2019-04-10 05:13:28 -04:00
# include <linux/err.h>
2017-04-17 07:54:37 -03:00
# include <media/cec.h>
2016-11-14 11:55:20 -02:00
struct device ;
struct edid ;
struct cec_adapter ;
struct cec_notifier ;
2017-05-28 05:58:04 -03:00
# if IS_REACHABLE(CONFIG_CEC_CORE) && IS_ENABLED(CONFIG_CEC_NOTIFIER)
2016-11-14 11:55:20 -02:00
/**
2018-07-04 17:08:16 +02:00
* cec_notifier_get_conn - find or create a new cec_notifier for the given
* device and connector tuple .
2016-11-14 11:55:20 -02:00
* @ dev : device that sends the events .
2018-07-04 17:08:16 +02:00
* @ conn : the connector name from which the event occurs
2016-11-14 11:55:20 -02:00
*
* If a notifier for device @ dev already exists , then increase the refcount
* and return that notifier .
*
* If it doesn ' t exist , then allocate a new notifier struct and return a
* pointer to that new struct .
*
* Return NULL if the memory could not be allocated .
*/
2018-07-04 17:08:16 +02:00
struct cec_notifier * cec_notifier_get_conn ( struct device * dev ,
const char * conn ) ;
2016-11-14 11:55:20 -02:00
/**
* cec_notifier_put - decrease refcount and delete when the refcount reaches 0.
* @ n : notifier
*/
void cec_notifier_put ( struct cec_notifier * n ) ;
2019-06-20 06:10:00 -04:00
/**
* cec_notifier_conn_register - find or create a new cec_notifier for the given
* HDMI device and connector tuple .
* @ hdmi_dev : HDMI device that sends the events .
* @ conn_name : the connector name from which the event occurs . May be NULL
* if there is always only one HDMI connector created by the HDMI device .
* @ conn_info : the connector info from which the event occurs ( may be NULL )
*
* If a notifier for device @ dev and connector @ conn_name already exists , then
* increase the refcount and return that notifier .
*
* If it doesn ' t exist , then allocate a new notifier struct and return a
* pointer to that new struct .
*
* Return NULL if the memory could not be allocated .
*/
struct cec_notifier *
cec_notifier_conn_register ( struct device * hdmi_dev , const char * conn_name ,
const struct cec_connector_info * conn_info ) ;
/**
* cec_notifier_conn_unregister - decrease refcount and delete when the
* refcount reaches 0.
* @ n : notifier . If NULL , then this function does nothing .
*/
void cec_notifier_conn_unregister ( struct cec_notifier * n ) ;
/**
* cec_notifier_cec_adap_register - find or create a new cec_notifier for the
* given device .
* @ hdmi_dev : HDMI device that sends the events .
* @ conn_name : the connector name from which the event occurs . May be NULL
* if there is always only one HDMI connector created by the HDMI device .
* @ adap : the cec adapter that registered this notifier .
*
* If a notifier for device @ dev and connector @ conn_name already exists , then
* increase the refcount and return that notifier .
*
* If it doesn ' t exist , then allocate a new notifier struct and return a
* pointer to that new struct .
*
* Return NULL if the memory could not be allocated .
*/
struct cec_notifier *
cec_notifier_cec_adap_register ( struct device * hdmi_dev , const char * conn_name ,
struct cec_adapter * adap ) ;
/**
* cec_notifier_cec_adap_unregister - decrease refcount and delete when the
* refcount reaches 0.
* @ n : notifier . If NULL , then this function does nothing .
2019-10-04 13:04:24 +02:00
* @ adap : the cec adapter that registered this notifier .
2019-06-20 06:10:00 -04:00
*/
2019-10-04 13:04:24 +02:00
void cec_notifier_cec_adap_unregister ( struct cec_notifier * n ,
struct cec_adapter * adap ) ;
2019-06-20 06:10:00 -04:00
2016-11-14 11:55:20 -02:00
/**
* cec_notifier_set_phys_addr - set a new physical address .
* @ n : the CEC notifier
* @ pa : the CEC physical address
*
* Set a new CEC physical address .
2017-07-15 09:32:56 -03:00
* Does nothing if @ n = = NULL .
2016-11-14 11:55:20 -02:00
*/
void cec_notifier_set_phys_addr ( struct cec_notifier * n , u16 pa ) ;
/**
* cec_notifier_set_phys_addr_from_edid - set parse the PA from the EDID .
* @ n : the CEC notifier
* @ edid : the struct edid pointer
*
* Parses the EDID to obtain the new CEC physical address and set it .
2017-07-15 09:32:56 -03:00
* Does nothing if @ n = = NULL .
2016-11-14 11:55:20 -02:00
*/
void cec_notifier_set_phys_addr_from_edid ( struct cec_notifier * n ,
const struct edid * edid ) ;
2019-04-10 05:13:28 -04:00
/**
* cec_notifier_parse_hdmi_phandle - find the hdmi device from " hdmi-phandle "
* @ dev : the device with the " hdmi-phandle " device tree property
*
* Returns the device pointer referenced by the " hdmi-phandle " property .
* Note that the refcount of the returned device is not incremented .
* This device pointer is only used as a key value in the notifier
* list , but it is never accessed by the CEC driver .
*/
struct device * cec_notifier_parse_hdmi_phandle ( struct device * dev ) ;
2016-11-14 11:55:20 -02:00
# else
2018-07-04 17:08:16 +02:00
static inline struct cec_notifier * cec_notifier_get_conn ( struct device * dev ,
const char * conn )
2016-11-14 11:55:20 -02:00
{
/* A non-NULL pointer is expected on success */
return ( struct cec_notifier * ) 0xdeadfeed ;
}
static inline void cec_notifier_put ( struct cec_notifier * n )
{
}
2019-06-20 06:10:00 -04:00
static inline struct cec_notifier *
cec_notifier_conn_register ( struct device * hdmi_dev , const char * conn_name ,
const struct cec_connector_info * conn_info )
{
/* A non-NULL pointer is expected on success */
return ( struct cec_notifier * ) 0xdeadfeed ;
}
static inline void cec_notifier_conn_unregister ( struct cec_notifier * n )
{
}
static inline struct cec_notifier *
cec_notifier_cec_adap_register ( struct device * hdmi_dev , const char * conn_name ,
struct cec_adapter * adap )
{
/* A non-NULL pointer is expected on success */
return ( struct cec_notifier * ) 0xdeadfeed ;
}
2019-10-04 13:04:24 +02:00
static inline void cec_notifier_cec_adap_unregister ( struct cec_notifier * n ,
struct cec_adapter * adap )
2019-06-20 06:10:00 -04:00
{
}
2016-11-14 11:55:20 -02:00
static inline void cec_notifier_set_phys_addr ( struct cec_notifier * n , u16 pa )
{
}
static inline void cec_notifier_set_phys_addr_from_edid ( struct cec_notifier * n ,
const struct edid * edid )
{
}
2019-04-10 05:13:28 -04:00
static inline struct device * cec_notifier_parse_hdmi_phandle ( struct device * dev )
{
return ERR_PTR ( - ENODEV ) ;
}
2016-11-14 11:55:20 -02:00
# endif
2018-07-04 17:08:16 +02:00
/**
* cec_notifier_get - find or create a new cec_notifier for the given device .
* @ dev : device that sends the events .
*
* If a notifier for device @ dev already exists , then increase the refcount
* and return that notifier .
*
* If it doesn ' t exist , then allocate a new notifier struct and return a
* pointer to that new struct .
*
* Return NULL if the memory could not be allocated .
*/
static inline struct cec_notifier * cec_notifier_get ( struct device * dev )
{
return cec_notifier_get_conn ( dev , NULL ) ;
}
2017-07-15 09:32:56 -03:00
/**
* cec_notifier_phys_addr_invalidate ( ) - set the physical address to INVALID
*
* @ n : the CEC notifier
*
* This is a simple helper function to invalidate the physical
* address . Does nothing if @ n = = NULL .
*/
static inline void cec_notifier_phys_addr_invalidate ( struct cec_notifier * n )
{
cec_notifier_set_phys_addr ( n , CEC_PHYS_ADDR_INVALID ) ;
}
2016-11-14 11:55:20 -02:00
# endif