Lines Matching full:slave
85 * enum sdw_slave_status - Slave status
86 * @SDW_SLAVE_UNATTACHED: Slave is not attached with the bus.
87 * @SDW_SLAVE_ATTACHED: Slave is attached with bus.
88 * @SDW_SLAVE_ALERT: Some alert condition on the Slave
200 * enum sdw_p15_behave - Slave Port 15 behaviour when the Master attempts a
227 * @SDW_CLK_STOP_MODE0: Slave can continue operation seamlessly on clock
229 * @SDW_CLK_STOP_MODE1: Slave may have entered a deeper power-saving mode,
246 * @BRA_flow_controlled: Slave implementation results in an OK_NotReady
330 * struct sdw_slave_prop - SoundWire Slave properties
343 * @reset_behave: Slave keeps the status of the SlaveStopClockPrepare
345 * @high_PHY_capable: Slave is HighPHY capable
346 * @paging_support: Slave implements paging registers SCP_AddrPage1 and
348 * @bank_delay_support: Slave implements bank delay/bridge support registers
350 * @lane_control_support: Slave supports lane control
351 * @p15_behave: Slave behavior when the Master attempts a read to the Port15
353 * @master_count: Number of Masters present on this Slave
361 * @lane_maps: Lane mapping for the slave, only valid if lane_control_support is set
365 * @use_domain_irq: call actual IRQ handler on slave, as well as callback
446 * Some Slave devices have known issues with incorrect parity errors
448 * parity errors can be reported by Slave devices, possibly due to electrical
456 int sdw_slave_read_prop(struct sdw_slave *slave);
457 int sdw_slave_read_lane_mapping(struct sdw_slave *slave);
460 * SDW Slave Structures and APIs
466 * struct sdw_slave_id - Slave ID
518 * struct sdw_slave_intr_status - Slave interrupt status
519 * @sdca_cascade: set if the Slave device reports an SDCA interrupt
545 * @bank: Register bank, which bank Slave/Master driver should program for
583 * @s_data_mode: NORMAL, STATIC or PRBS mode for all Slave ports
601 * struct sdw_slave_ops: Slave driver callback ops
603 * @read_prop: Read Slave properties
606 * @update_status: Update Slave status
607 * @bus_config: Update the bus config for Slave
613 int (*interrupt_callback)(struct sdw_slave *slave,
615 int (*update_status)(struct sdw_slave *slave,
617 int (*bus_config)(struct sdw_slave *slave,
619 int (*port_prep)(struct sdw_slave *slave,
622 int (*clk_stop)(struct sdw_slave *slave,
628 * struct sdw_slave - SoundWire Slave
632 * @status: Status reported by the Slave
634 * @prop: Slave properties
635 * @debugfs: Slave debugfs
637 * @port_ready: Port ready completion flag for each Slave port
638 * @m_port_map: static Master port map for each Slave port
644 * Slave device
647 * @unattach_request: mask field to keep track why the Slave re-attached and
650 * when the Master triggered a reset the Slave is properly enumerated and
653 * for a Slave happens for the first time after enumeration
851 int (*get_device_num)(struct sdw_bus *bus, struct sdw_slave *slave);
852 void (*put_device_num)(struct sdw_bus *bus, struct sdw_slave *slave);
854 struct sdw_slave *slave,
865 * sdw_port_config: Master or Slave Port configuration
876 * sdw_stream_config: Master or Slave stream configuration
975 * @assigned: Bitmap for Slave device numbers.
1042 int sdw_compare_devid(struct sdw_slave *slave, struct sdw_slave_id id);
1044 bool is_clock_scaling_supported_by_slave(struct sdw_slave *slave);
1048 int sdw_stream_add_slave(struct sdw_slave *slave,
1053 int sdw_stream_remove_slave(struct sdw_slave *slave,
1056 int sdw_slave_get_scale_index(struct sdw_slave *slave, u8 *base);
1059 int sdw_read(struct sdw_slave *slave, u32 addr);
1060 int sdw_write(struct sdw_slave *slave, u32 addr, u8 value);
1061 int sdw_write_no_pm(struct sdw_slave *slave, u32 addr, u8 value);
1062 int sdw_read_no_pm(struct sdw_slave *slave, u32 addr);
1063 int sdw_nread(struct sdw_slave *slave, u32 addr, size_t count, u8 *val);
1064 int sdw_nread_no_pm(struct sdw_slave *slave, u32 addr, size_t count, u8 *val);
1065 int sdw_nwrite(struct sdw_slave *slave, u32 addr, size_t count, const u8 *val);
1066 int sdw_nwrite_no_pm(struct sdw_slave *slave, u32 addr, size_t count, const u8 *val);
1067 int sdw_update(struct sdw_slave *slave, u32 addr, u8 mask, u8 val);
1068 int sdw_update_no_pm(struct sdw_slave *slave, u32 addr, u8 mask, u8 val);
1072 static inline int sdw_stream_add_slave(struct sdw_slave *slave, in sdw_stream_add_slave() argument
1082 static inline int sdw_stream_remove_slave(struct sdw_slave *slave, in sdw_stream_remove_slave() argument
1090 static inline int sdw_read(struct sdw_slave *slave, u32 addr) in sdw_read() argument
1096 static inline int sdw_write(struct sdw_slave *slave, u32 addr, u8 value) in sdw_write() argument
1102 static inline int sdw_write_no_pm(struct sdw_slave *slave, u32 addr, u8 value) in sdw_write_no_pm() argument
1108 static inline int sdw_read_no_pm(struct sdw_slave *slave, u32 addr) in sdw_read_no_pm() argument
1114 static inline int sdw_nread(struct sdw_slave *slave, u32 addr, size_t count, u8 *val) in sdw_nread() argument
1120 static inline int sdw_nread_no_pm(struct sdw_slave *slave, u32 addr, size_t count, u8 *val) in sdw_nread_no_pm() argument
1126 static inline int sdw_nwrite(struct sdw_slave *slave, u32 addr, size_t count, const u8 *val) in sdw_nwrite() argument
1132 static inline int sdw_nwrite_no_pm(struct sdw_slave *slave, u32 addr, size_t count, const u8 *val) in sdw_nwrite_no_pm() argument
1138 static inline int sdw_update(struct sdw_slave *slave, u32 addr, u8 mask, u8 val) in sdw_update() argument
1144 static inline int sdw_update_no_pm(struct sdw_slave *slave, u32 addr, u8 mask, u8 val) in sdw_update_no_pm() argument