I3C for 6.19 #2
Subsystem: - remove .priv_xfers -----BEGIN PGP SIGNATURE----- iQIzBAABCgAdFiEEBqsFVZXh8s/0O5JiY6TcMGxwOjIFAmk8nscACgkQY6TcMGxw OjL+1Q//Tg2EpJZPRjJaCjf9ohjcrgyFtse+5qeCypnRYFVD3Oy6r3AkiuacJ8jG ufQ8V03JTsOIH+BcyGgQgyDWEplcqFdoJPVpdiuJGYMSj8if3g7pUQFFbrzEGum2 mMRcrvidhCgGVpUYVmIAUxx7anf9bR4Tuq5q9ZZ1gexxjyMJ+sEiLHpTDfuxRfB+ JIiaDfHEWAzMdVjwtVX0+BidDlhdj4ioY7BJAh/6Zj5dcw1M3zbSBu/Vfj3+jgvj TBwV3MEd69t4uofnbh2OZ6YmH2+HrBDafPBIRmWxlU/qFcdSZBLsJE5mrWIhVfur mC0vNXF2C/ShFs5DNStCkBqNs8n2Gtv+8IwT1FnPOlzgya8pyphIl1x9uJcGdPBG k6GxIRAQHuWvYZEOS+X/rN4P9itKCVab2Z4Yo3Kwd2au4KXp6lZ7cSsVXgDz5QrU fXAXKtizc6Oz2ebU8r88Wh5G/oUeffOf2xls/nZ9gVVXdSNpx7Ehy9N5IbQou7dF doFOtWdascK5rmnjCowTwHSug+Jl9K8w0IzaF8w+lLPBo0twru0kFqgWLAc7lj+v hVzE6JHtnR4hth+sf5oynUwfjtZYT7nGoQnCSBUlr6f6UAOUQTT+TTqoyXOMxiqh 5PeeuK78QFcWRdjPeb1JX2mRk3Kj2oMFlmGpk8IQGY4U/zdVr3o= =tZor -----END PGP SIGNATURE----- Merge tag 'i3c/for-6.19-2' of git://git.kernel.org/pub/scm/linux/kernel/git/i3c/linux Pull further i3c update from Alexandre Belloni: "We are removing a legacy API callback and having this sooner rather than later will help ensuring no one introduces a new driver using it. I've also added patches removing the "__free(...) = NULL" pattern because I'm sure we won't avoid people sending those following the mailing list discussion..." * tag 'i3c/for-6.19-2' of git://git.kernel.org/pub/scm/linux/kernel/git/i3c/linux: i3c: adi: Fix confusing cleanup.h syntax i3c: master: Fix confusing cleanup.h syntax i3c: master: cleanup callback .priv_xfers() i3c: master: switch to use new callback .i3c_xfers() from .priv_xfers()master
commit
d8cc0b917b
|
|
@ -1742,11 +1742,10 @@ EXPORT_SYMBOL_GPL(i3c_master_do_daa);
|
|||
struct i3c_dma *i3c_master_dma_map_single(struct device *dev, void *buf,
|
||||
size_t len, bool force_bounce, enum dma_data_direction dir)
|
||||
{
|
||||
struct i3c_dma *dma_xfer __free(kfree) = NULL;
|
||||
void *bounce __free(kfree) = NULL;
|
||||
void *dma_buf = buf;
|
||||
|
||||
dma_xfer = kzalloc(sizeof(*dma_xfer), GFP_KERNEL);
|
||||
struct i3c_dma *dma_xfer __free(kfree) = kzalloc(sizeof(*dma_xfer), GFP_KERNEL);
|
||||
if (!dma_xfer)
|
||||
return NULL;
|
||||
|
||||
|
|
@ -2819,14 +2818,10 @@ EXPORT_SYMBOL_GPL(i3c_generic_ibi_recycle_slot);
|
|||
|
||||
static int i3c_master_check_ops(const struct i3c_master_controller_ops *ops)
|
||||
{
|
||||
if (!ops || !ops->bus_init ||
|
||||
if (!ops || !ops->bus_init || !ops->i3c_xfers ||
|
||||
!ops->send_ccc_cmd || !ops->do_daa || !ops->i2c_xfers)
|
||||
return -EINVAL;
|
||||
|
||||
/* Must provide one of priv_xfers (SDR only) or i3c_xfers (all modes) */
|
||||
if (!ops->priv_xfers && !ops->i3c_xfers)
|
||||
return -EINVAL;
|
||||
|
||||
if (ops->request_ibi &&
|
||||
(!ops->enable_ibi || !ops->disable_ibi || !ops->free_ibi ||
|
||||
!ops->recycle_ibi_slot))
|
||||
|
|
@ -3031,13 +3026,7 @@ int i3c_dev_do_xfers_locked(struct i3c_dev_desc *dev, struct i3c_xfer *xfers,
|
|||
if (mode != I3C_SDR && !(master->this->info.hdr_cap & BIT(mode)))
|
||||
return -EOPNOTSUPP;
|
||||
|
||||
if (master->ops->i3c_xfers)
|
||||
return master->ops->i3c_xfers(dev, xfers, nxfers, mode);
|
||||
|
||||
if (mode != I3C_SDR)
|
||||
return -EINVAL;
|
||||
|
||||
return master->ops->priv_xfers(dev, xfers, nxfers);
|
||||
return master->ops->i3c_xfers(dev, xfers, nxfers, mode);
|
||||
}
|
||||
|
||||
int i3c_dev_disable_ibi_locked(struct i3c_dev_desc *dev)
|
||||
|
|
|
|||
|
|
@ -332,10 +332,9 @@ static int adi_i3c_master_send_ccc_cmd(struct i3c_master_controller *m,
|
|||
struct i3c_ccc_cmd *cmd)
|
||||
{
|
||||
struct adi_i3c_master *master = to_adi_i3c_master(m);
|
||||
struct adi_i3c_xfer *xfer __free(kfree) = NULL;
|
||||
struct adi_i3c_cmd *ccmd;
|
||||
|
||||
xfer = adi_i3c_master_alloc_xfer(master, 1);
|
||||
struct adi_i3c_xfer *xfer __free(kfree) = adi_i3c_master_alloc_xfer(master, 1);
|
||||
if (!xfer)
|
||||
return -ENOMEM;
|
||||
|
||||
|
|
@ -365,19 +364,18 @@ static int adi_i3c_master_send_ccc_cmd(struct i3c_master_controller *m,
|
|||
return 0;
|
||||
}
|
||||
|
||||
static int adi_i3c_master_priv_xfers(struct i3c_dev_desc *dev,
|
||||
struct i3c_priv_xfer *xfers,
|
||||
int nxfers)
|
||||
static int adi_i3c_master_i3c_xfers(struct i3c_dev_desc *dev,
|
||||
struct i3c_xfer *xfers,
|
||||
int nxfers, enum i3c_xfer_mode mode)
|
||||
{
|
||||
struct i3c_master_controller *m = i3c_dev_get_master(dev);
|
||||
struct adi_i3c_master *master = to_adi_i3c_master(m);
|
||||
struct adi_i3c_xfer *xfer __free(kfree) = NULL;
|
||||
int i, ret;
|
||||
|
||||
if (!nxfers)
|
||||
return 0;
|
||||
|
||||
xfer = adi_i3c_master_alloc_xfer(master, nxfers);
|
||||
struct adi_i3c_xfer *xfer __free(kfree) = adi_i3c_master_alloc_xfer(master, nxfers);
|
||||
if (!xfer)
|
||||
return -ENOMEM;
|
||||
|
||||
|
|
@ -777,7 +775,6 @@ static int adi_i3c_master_i2c_xfers(struct i2c_dev_desc *dev,
|
|||
{
|
||||
struct i3c_master_controller *m = i2c_dev_get_master(dev);
|
||||
struct adi_i3c_master *master = to_adi_i3c_master(m);
|
||||
struct adi_i3c_xfer *xfer __free(kfree) = NULL;
|
||||
int i;
|
||||
|
||||
if (!nxfers)
|
||||
|
|
@ -786,7 +783,8 @@ static int adi_i3c_master_i2c_xfers(struct i2c_dev_desc *dev,
|
|||
if (xfers[i].flags & I2C_M_TEN)
|
||||
return -EOPNOTSUPP;
|
||||
}
|
||||
xfer = adi_i3c_master_alloc_xfer(master, nxfers);
|
||||
|
||||
struct adi_i3c_xfer *xfer __free(kfree) = adi_i3c_master_alloc_xfer(master, nxfers);
|
||||
if (!xfer)
|
||||
return -ENOMEM;
|
||||
|
||||
|
|
@ -919,7 +917,7 @@ static const struct i3c_master_controller_ops adi_i3c_master_ops = {
|
|||
.do_daa = adi_i3c_master_do_daa,
|
||||
.supports_ccc_cmd = adi_i3c_master_supports_ccc_cmd,
|
||||
.send_ccc_cmd = adi_i3c_master_send_ccc_cmd,
|
||||
.priv_xfers = adi_i3c_master_priv_xfers,
|
||||
.i3c_xfers = adi_i3c_master_i3c_xfers,
|
||||
.i2c_xfers = adi_i3c_master_i2c_xfers,
|
||||
.request_ibi = adi_i3c_master_request_ibi,
|
||||
.enable_ibi = adi_i3c_master_enable_ibi,
|
||||
|
|
|
|||
|
|
@ -902,9 +902,9 @@ rpm_out:
|
|||
return ret;
|
||||
}
|
||||
|
||||
static int dw_i3c_master_priv_xfers(struct i3c_dev_desc *dev,
|
||||
struct i3c_priv_xfer *i3c_xfers,
|
||||
int i3c_nxfers)
|
||||
static int dw_i3c_master_i3c_xfers(struct i3c_dev_desc *dev,
|
||||
struct i3c_xfer *i3c_xfers,
|
||||
int i3c_nxfers, enum i3c_xfer_mode mode)
|
||||
{
|
||||
struct dw_i3c_i2c_dev_data *data = i3c_dev_get_master_data(dev);
|
||||
struct i3c_master_controller *m = i3c_dev_get_master(dev);
|
||||
|
|
@ -1498,7 +1498,7 @@ static const struct i3c_master_controller_ops dw_mipi_i3c_ops = {
|
|||
.do_daa = dw_i3c_master_daa,
|
||||
.supports_ccc_cmd = dw_i3c_master_supports_ccc_cmd,
|
||||
.send_ccc_cmd = dw_i3c_master_send_ccc_cmd,
|
||||
.priv_xfers = dw_i3c_master_priv_xfers,
|
||||
.i3c_xfers = dw_i3c_master_i3c_xfers,
|
||||
.attach_i2c_dev = dw_i3c_master_attach_i2c_dev,
|
||||
.detach_i2c_dev = dw_i3c_master_detach_i2c_dev,
|
||||
.i2c_xfers = dw_i3c_master_i2c_xfers,
|
||||
|
|
|
|||
|
|
@ -720,9 +720,9 @@ static int cdns_i3c_master_send_ccc_cmd(struct i3c_master_controller *m,
|
|||
return ret;
|
||||
}
|
||||
|
||||
static int cdns_i3c_master_priv_xfers(struct i3c_dev_desc *dev,
|
||||
struct i3c_priv_xfer *xfers,
|
||||
int nxfers)
|
||||
static int cdns_i3c_master_i3c_xfers(struct i3c_dev_desc *dev,
|
||||
struct i3c_xfer *xfers,
|
||||
int nxfers, enum i3c_xfer_mode mode)
|
||||
{
|
||||
struct i3c_master_controller *m = i3c_dev_get_master(dev);
|
||||
struct cdns_i3c_master *master = to_cdns_i3c_master(m);
|
||||
|
|
@ -1519,7 +1519,7 @@ static const struct i3c_master_controller_ops cdns_i3c_master_ops = {
|
|||
.detach_i2c_dev = cdns_i3c_master_detach_i2c_dev,
|
||||
.supports_ccc_cmd = cdns_i3c_master_supports_ccc_cmd,
|
||||
.send_ccc_cmd = cdns_i3c_master_send_ccc_cmd,
|
||||
.priv_xfers = cdns_i3c_master_priv_xfers,
|
||||
.i3c_xfers = cdns_i3c_master_i3c_xfers,
|
||||
.i2c_xfers = cdns_i3c_master_i2c_xfers,
|
||||
.enable_ibi = cdns_i3c_master_enable_ibi,
|
||||
.disable_ibi = cdns_i3c_master_disable_ibi,
|
||||
|
|
|
|||
|
|
@ -266,9 +266,9 @@ static int i3c_hci_daa(struct i3c_master_controller *m)
|
|||
return hci->cmd->perform_daa(hci);
|
||||
}
|
||||
|
||||
static int i3c_hci_priv_xfers(struct i3c_dev_desc *dev,
|
||||
struct i3c_priv_xfer *i3c_xfers,
|
||||
int nxfers)
|
||||
static int i3c_hci_i3c_xfers(struct i3c_dev_desc *dev,
|
||||
struct i3c_xfer *i3c_xfers, int nxfers,
|
||||
enum i3c_xfer_mode mode)
|
||||
{
|
||||
struct i3c_master_controller *m = i3c_dev_get_master(dev);
|
||||
struct i3c_hci *hci = to_i3c_hci(m);
|
||||
|
|
@ -515,7 +515,7 @@ static const struct i3c_master_controller_ops i3c_hci_ops = {
|
|||
.bus_cleanup = i3c_hci_bus_cleanup,
|
||||
.do_daa = i3c_hci_daa,
|
||||
.send_ccc_cmd = i3c_hci_send_ccc_cmd,
|
||||
.priv_xfers = i3c_hci_priv_xfers,
|
||||
.i3c_xfers = i3c_hci_i3c_xfers,
|
||||
.i2c_xfers = i3c_hci_i2c_xfers,
|
||||
.attach_i3c_dev = i3c_hci_attach_i3c_dev,
|
||||
.reattach_i3c_dev = i3c_hci_reattach_i3c_dev,
|
||||
|
|
|
|||
|
|
@ -794,8 +794,8 @@ static int renesas_i3c_send_ccc_cmd(struct i3c_master_controller *m,
|
|||
return ret;
|
||||
}
|
||||
|
||||
static int renesas_i3c_priv_xfers(struct i3c_dev_desc *dev, struct i3c_priv_xfer *i3c_xfers,
|
||||
int i3c_nxfers)
|
||||
static int renesas_i3c_i3c_xfers(struct i3c_dev_desc *dev, struct i3c_xfer *i3c_xfers,
|
||||
int i3c_nxfers, enum i3c_xfer_mode mode)
|
||||
{
|
||||
struct i3c_master_controller *m = i3c_dev_get_master(dev);
|
||||
struct renesas_i3c *i3c = to_renesas_i3c(m);
|
||||
|
|
@ -1282,7 +1282,7 @@ static const struct i3c_master_controller_ops renesas_i3c_ops = {
|
|||
.do_daa = renesas_i3c_daa,
|
||||
.supports_ccc_cmd = renesas_i3c_supports_ccc_cmd,
|
||||
.send_ccc_cmd = renesas_i3c_send_ccc_cmd,
|
||||
.priv_xfers = renesas_i3c_priv_xfers,
|
||||
.i3c_xfers = renesas_i3c_i3c_xfers,
|
||||
.attach_i2c_dev = renesas_i3c_attach_i2c_dev,
|
||||
.detach_i2c_dev = renesas_i3c_detach_i2c_dev,
|
||||
.i2c_xfers = renesas_i3c_i2c_xfers,
|
||||
|
|
|
|||
|
|
@ -417,12 +417,8 @@ struct i3c_bus {
|
|||
* all CCC commands are supported.
|
||||
* @send_ccc_cmd: send a CCC command
|
||||
* This method is mandatory.
|
||||
* @priv_xfers: do one or several private I3C SDR transfers
|
||||
* This method is mandatory when i3c_xfers is not implemented. It
|
||||
* is deprecated.
|
||||
* @i3c_xfers: do one or several I3C SDR or HDR transfers
|
||||
* This method is mandatory when priv_xfers is not implemented but
|
||||
* should be implemented instead of priv_xfers.
|
||||
* @i3c_xfers: do one or several I3C SDR or HDR transfers.
|
||||
* This method is mandatory.
|
||||
* @attach_i2c_dev: called every time an I2C device is attached to the bus.
|
||||
* This is a good place to attach master controller specific
|
||||
* data to I2C devices.
|
||||
|
|
@ -478,10 +474,6 @@ struct i3c_master_controller_ops {
|
|||
const struct i3c_ccc_cmd *cmd);
|
||||
int (*send_ccc_cmd)(struct i3c_master_controller *master,
|
||||
struct i3c_ccc_cmd *cmd);
|
||||
/* Deprecated, please use i3c_xfers() */
|
||||
int (*priv_xfers)(struct i3c_dev_desc *dev,
|
||||
struct i3c_priv_xfer *xfers,
|
||||
int nxfers);
|
||||
int (*i3c_xfers)(struct i3c_dev_desc *dev,
|
||||
struct i3c_xfer *xfers,
|
||||
int nxfers, enum i3c_xfer_mode mode);
|
||||
|
|
|
|||
Loading…
Reference in New Issue