2017-12-14 11:19:34 +05:30
// SPDX-License-Identifier: (GPL-2.0 OR BSD-3-Clause)
// Copyright(c) 2015-17 Intel Corporation.
# ifndef __SDW_BUS_H
# define __SDW_BUS_H
# if IS_ENABLED(CONFIG_ACPI)
int sdw_acpi_find_slaves ( struct sdw_bus * bus ) ;
# else
static inline int sdw_acpi_find_slaves ( struct sdw_bus * bus )
{
return - ENOTSUPP ;
}
# endif
void sdw_extract_slave_id ( struct sdw_bus * bus ,
u64 addr , struct sdw_slave_id * id ) ;
2017-12-14 11:19:37 +05:30
enum {
SDW_MSG_FLAG_READ = 0 ,
SDW_MSG_FLAG_WRITE ,
} ;
/**
* struct sdw_msg - Message structure
* @ addr : Register address accessed in the Slave
* @ len : number of messages
* @ dev_num : Slave device number
* @ addr_page1 : SCP address page 1 Slave register
* @ addr_page2 : SCP address page 2 Slave register
* @ flags : transfer flags , indicate if xfer is read or write
* @ buf : message data buffer
* @ ssp_sync : Send message at SSP ( Stream Synchronization Point )
* @ page : address requires paging
*/
struct sdw_msg {
u16 addr ;
u16 len ;
u8 dev_num ;
u8 addr_page1 ;
u8 addr_page2 ;
u8 flags ;
u8 * buf ;
bool ssp_sync ;
bool page ;
} ;
2018-04-26 18:38:08 +05:30
/**
* sdw_slave_runtime : Runtime Stream parameters for Slave
*
* @ slave : Slave handle
* @ direction : Data direction for Slave
* @ ch_count : Number of channels handled by the Slave for
* this stream
* @ m_rt_node : sdw_master_runtime list node
*/
struct sdw_slave_runtime {
struct sdw_slave * slave ;
enum sdw_data_direction direction ;
unsigned int ch_count ;
struct list_head m_rt_node ;
} ;
/**
* sdw_master_runtime : Runtime stream parameters for Master
*
* @ bus : Bus handle
* @ stream : Stream runtime handle
* @ direction : Data direction for Master
* @ ch_count : Number of channels handled by the Master for
* this stream , can be zero .
* @ slave_rt_list : Slave runtime list
* @ bus_node : sdw_bus m_rt_list node
*/
struct sdw_master_runtime {
struct sdw_bus * bus ;
struct sdw_stream_runtime * stream ;
enum sdw_data_direction direction ;
unsigned int ch_count ;
struct list_head slave_rt_list ;
struct list_head bus_node ;
} ;
2017-12-14 11:19:37 +05:30
int sdw_transfer ( struct sdw_bus * bus , struct sdw_msg * msg ) ;
int sdw_transfer_defer ( struct sdw_bus * bus , struct sdw_msg * msg ,
struct sdw_defer * defer ) ;
2017-12-14 11:19:40 +05:30
# define SDW_READ_INTR_CLEAR_RETRY 10
2017-12-14 11:19:37 +05:30
int sdw_fill_msg ( struct sdw_msg * msg , struct sdw_slave * slave ,
u32 addr , size_t count , u16 dev_num , u8 flags , u8 * buf ) ;
2017-12-14 11:19:39 +05:30
/* Read-Modify-Write Slave register */
static inline int
sdw_update ( struct sdw_slave * slave , u32 addr , u8 mask , u8 val )
{
int tmp ;
tmp = sdw_read ( slave , addr ) ;
if ( tmp < 0 )
return tmp ;
tmp = ( tmp & ~ mask ) | val ;
return sdw_write ( slave , addr , tmp ) ;
}
2017-12-14 11:19:34 +05:30
# endif /* __SDW_BUS_H */