regmap: Update for v5.16
This update has a single change which will use the maximum transfer and message sizes advertised by SPI controllers to configure limits within the regmap core, ensuring better interoperation. -----BEGIN PGP SIGNATURE----- iQEzBAABCgAdFiEEreZoqmdXGLWf4p/qJNaLcl1Uh9AFAmF/6F8ACgkQJNaLcl1U h9Calgf+PaI6wr17nU0/m4N50Vjat0bL7iBuEQYPKFWu963M0QasPZEKteJV7sa+ 8XVxcBh43E2unQkY+iMfldmBIEfZJwmsaWecdxSair6cWcm8MT6agOOkl6KjiCHM AQiPI2+UbXDHnPociBmyA+MqI3hWSPZIMirVC+3WAFGLs8wHuRe0G97egkcPh88a doQ5f2Ei7eCgP4uy+p93S4QWXbsbQVm/yszw0BH0gaqnBylwUfQtU1vdlLyBXW4y 9bB1MnzCdlLbKf4bQd7NcjB2bA8lgAuZ3t5rJoRjZtnf+//fRTB1cu/UkLRFlZme vsrt60wo52r2v5tiLKA4wrgcvEFR+A== =8MR4 -----END PGP SIGNATURE----- Merge tag 'regmap-v5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/regmap Pull regmap update from Mark Brown: "A single change to use the maximum transfer and message sizes advertised by SPI controllers to configure limits within the regmap core, ensuring better interoperation" * tag 'regmap-v5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/regmap: regmap: spi: Set regmap max raw r/w from max_transfer_size
This commit is contained in:
Коммит
d2cdb12231
|
@ -109,13 +109,37 @@ static const struct regmap_bus regmap_spi = {
|
|||
.val_format_endian_default = REGMAP_ENDIAN_BIG,
|
||||
};
|
||||
|
||||
static const struct regmap_bus *regmap_get_spi_bus(struct spi_device *spi,
|
||||
const struct regmap_config *config)
|
||||
{
|
||||
size_t max_size = spi_max_transfer_size(spi);
|
||||
struct regmap_bus *bus;
|
||||
|
||||
if (max_size != SIZE_MAX) {
|
||||
bus = kmemdup(®map_spi, sizeof(*bus), GFP_KERNEL);
|
||||
if (!bus)
|
||||
return ERR_PTR(-ENOMEM);
|
||||
|
||||
bus->free_on_exit = true;
|
||||
bus->max_raw_read = max_size;
|
||||
bus->max_raw_write = max_size;
|
||||
return bus;
|
||||
}
|
||||
|
||||
return ®map_spi;
|
||||
}
|
||||
|
||||
struct regmap *__regmap_init_spi(struct spi_device *spi,
|
||||
const struct regmap_config *config,
|
||||
struct lock_class_key *lock_key,
|
||||
const char *lock_name)
|
||||
{
|
||||
return __regmap_init(&spi->dev, ®map_spi, &spi->dev, config,
|
||||
lock_key, lock_name);
|
||||
const struct regmap_bus *bus = regmap_get_spi_bus(spi, config);
|
||||
|
||||
if (IS_ERR(bus))
|
||||
return ERR_CAST(bus);
|
||||
|
||||
return __regmap_init(&spi->dev, bus, &spi->dev, config, lock_key, lock_name);
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(__regmap_init_spi);
|
||||
|
||||
|
@ -124,8 +148,12 @@ struct regmap *__devm_regmap_init_spi(struct spi_device *spi,
|
|||
struct lock_class_key *lock_key,
|
||||
const char *lock_name)
|
||||
{
|
||||
return __devm_regmap_init(&spi->dev, ®map_spi, &spi->dev, config,
|
||||
lock_key, lock_name);
|
||||
const struct regmap_bus *bus = regmap_get_spi_bus(spi, config);
|
||||
|
||||
if (IS_ERR(bus))
|
||||
return ERR_CAST(bus);
|
||||
|
||||
return __devm_regmap_init(&spi->dev, bus, &spi->dev, config, lock_key, lock_name);
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(__devm_regmap_init_spi);
|
||||
|
||||
|
|
Загрузка…
Ссылка в новой задаче