FPGA Manager fixes for 5.15

Tom and Jiapeng's fixes address smatch warnings around missing return
 values in error cases.
 
 Russ' change addresses an issue where registers are being accessed too
 early resulting in invalid data being read.
 
 All patches have been reviewed on the mailing list, and have been in the
 last few linux-next releases (as part of my fixes branch) without issues.
 
 Signed-off-by: Moritz Fischer <mdf@kernel.org>
 -----BEGIN PGP SIGNATURE-----
 
 iIUEABYIAC0WIQSdhnt2PwibB65UG0C3mJX/Vsn7uQUCYUe/xg8cbWRmQGtlcm5l
 bC5vcmcACgkQt5iV/1bJ+7mCOAD/dh1bfDDLSrvqyOgvu5cmDN6/E3XqYDGHXQn9
 g9tvve8A/2otyCvGYH/18+85hs03HPVAf8b4MQyYZapso4uJIvMK
 =LMcp
 -----END PGP SIGNATURE-----

Merge tag 'fpga-fixes-5.15' of git://git.kernel.org/pub/scm/linux/kernel/git/mdf/linux-fpga into char-misc-linus

FPGA Manager fixes for 5.15

Tom and Jiapeng's fixes address smatch warnings around missing return
values in error cases.

Russ' change addresses an issue where registers are being accessed too
early resulting in invalid data being read.

All patches have been reviewed on the mailing list, and have been in the
last few linux-next releases (as part of my fixes branch) without issues.

Signed-off-by: Moritz Fischer <mdf@kernel.org>

* tag 'fpga-fixes-5.15' of git://git.kernel.org/pub/scm/linux/kernel/git/mdf/linux-fpga:
  fpga: dfl: Avoid reads to AFU CSRs during enumeration
  fpga: machxo2-spi: Fix missing error code in machxo2_write_complete()
  fpga: machxo2-spi: Return an error on failure
This commit is contained in:
Greg Kroah-Hartman 2021-09-20 09:04:54 +02:00
commit 50c7ad36e6
2 changed files with 13 additions and 7 deletions

View File

@ -1019,16 +1019,18 @@ create_feature_instance(struct build_feature_devs_info *binfo,
{ {
unsigned int irq_base, nr_irqs; unsigned int irq_base, nr_irqs;
struct dfl_feature_info *finfo; struct dfl_feature_info *finfo;
u8 revision = 0;
int ret; int ret;
u8 revision;
u64 v; u64 v;
v = readq(binfo->ioaddr + ofst); if (fid != FEATURE_ID_AFU) {
revision = FIELD_GET(DFH_REVISION, v); v = readq(binfo->ioaddr + ofst);
revision = FIELD_GET(DFH_REVISION, v);
/* read feature size and id if inputs are invalid */ /* read feature size and id if inputs are invalid */
size = size ? size : feature_size(v); size = size ? size : feature_size(v);
fid = fid ? fid : feature_id(v); fid = fid ? fid : feature_id(v);
}
if (binfo->len - ofst < size) if (binfo->len - ofst < size)
return -EINVAL; return -EINVAL;

View File

@ -225,8 +225,10 @@ static int machxo2_write_init(struct fpga_manager *mgr,
goto fail; goto fail;
get_status(spi, &status); get_status(spi, &status);
if (test_bit(FAIL, &status)) if (test_bit(FAIL, &status)) {
ret = -EINVAL;
goto fail; goto fail;
}
dump_status_reg(&status); dump_status_reg(&status);
spi_message_init(&msg); spi_message_init(&msg);
@ -313,6 +315,7 @@ static int machxo2_write_complete(struct fpga_manager *mgr,
dump_status_reg(&status); dump_status_reg(&status);
if (!test_bit(DONE, &status)) { if (!test_bit(DONE, &status)) {
machxo2_cleanup(mgr); machxo2_cleanup(mgr);
ret = -EINVAL;
goto fail; goto fail;
} }
@ -335,6 +338,7 @@ static int machxo2_write_complete(struct fpga_manager *mgr,
break; break;
if (++refreshloop == MACHXO2_MAX_REFRESH_LOOP) { if (++refreshloop == MACHXO2_MAX_REFRESH_LOOP) {
machxo2_cleanup(mgr); machxo2_cleanup(mgr);
ret = -EINVAL;
goto fail; goto fail;
} }
} while (1); } while (1);