diff options
author | Ben Hutchings <bhutchings@solarflare.com> | 2010-12-02 08:47:10 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-12-03 12:08:06 -0500 |
commit | 6a8872c54d177abd900a0cf165b76ecb4803f052 (patch) | |
tree | befd3690b9c73a7ae6342345c2a205a345d78028 | |
parent | 6c88b0b6dc886e49c0e6ee21d677c2e380bde688 (diff) |
sfc: Expose Falcon BootROM config through MTD, not ethtool
The ethtool EEPROM interface is really meant for exposing chip
configuration, not BootROM configuration.
Signed-off-by: Ben Hutchings <bhutchings@solarflare.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | drivers/net/sfc/ethtool.c | 59 | ||||
-rw-r--r-- | drivers/net/sfc/mtd.c | 77 |
2 files changed, 54 insertions, 82 deletions
diff --git a/drivers/net/sfc/ethtool.c b/drivers/net/sfc/ethtool.c index edb9d16b8b47..00fb6743c8a6 100644 --- a/drivers/net/sfc/ethtool.c +++ b/drivers/net/sfc/ethtool.c | |||
@@ -17,7 +17,6 @@ | |||
17 | #include "efx.h" | 17 | #include "efx.h" |
18 | #include "filter.h" | 18 | #include "filter.h" |
19 | #include "nic.h" | 19 | #include "nic.h" |
20 | #include "spi.h" | ||
21 | #include "mdio_10g.h" | 20 | #include "mdio_10g.h" |
22 | 21 | ||
23 | struct ethtool_string { | 22 | struct ethtool_string { |
@@ -629,61 +628,6 @@ static u32 efx_ethtool_get_link(struct net_device *net_dev) | |||
629 | return efx->link_state.up; | 628 | return efx->link_state.up; |
630 | } | 629 | } |
631 | 630 | ||
632 | static int efx_ethtool_get_eeprom_len(struct net_device *net_dev) | ||
633 | { | ||
634 | struct efx_nic *efx = netdev_priv(net_dev); | ||
635 | struct efx_spi_device *spi = efx->spi_eeprom; | ||
636 | |||
637 | if (!spi) | ||
638 | return 0; | ||
639 | return min(spi->size, EFX_EEPROM_BOOTCONFIG_END) - | ||
640 | min(spi->size, EFX_EEPROM_BOOTCONFIG_START); | ||
641 | } | ||
642 | |||
643 | static int efx_ethtool_get_eeprom(struct net_device *net_dev, | ||
644 | struct ethtool_eeprom *eeprom, u8 *buf) | ||
645 | { | ||
646 | struct efx_nic *efx = netdev_priv(net_dev); | ||
647 | struct efx_spi_device *spi = efx->spi_eeprom; | ||
648 | size_t len; | ||
649 | int rc; | ||
650 | |||
651 | rc = mutex_lock_interruptible(&efx->spi_lock); | ||
652 | if (rc) | ||
653 | return rc; | ||
654 | rc = falcon_spi_read(efx, spi, | ||
655 | eeprom->offset + EFX_EEPROM_BOOTCONFIG_START, | ||
656 | eeprom->len, &len, buf); | ||
657 | mutex_unlock(&efx->spi_lock); | ||
658 | |||
659 | eeprom->magic = EFX_ETHTOOL_EEPROM_MAGIC; | ||
660 | eeprom->len = len; | ||
661 | return rc; | ||
662 | } | ||
663 | |||
664 | static int efx_ethtool_set_eeprom(struct net_device *net_dev, | ||
665 | struct ethtool_eeprom *eeprom, u8 *buf) | ||
666 | { | ||
667 | struct efx_nic *efx = netdev_priv(net_dev); | ||
668 | struct efx_spi_device *spi = efx->spi_eeprom; | ||
669 | size_t len; | ||
670 | int rc; | ||
671 | |||
672 | if (eeprom->magic != EFX_ETHTOOL_EEPROM_MAGIC) | ||
673 | return -EINVAL; | ||
674 | |||
675 | rc = mutex_lock_interruptible(&efx->spi_lock); | ||
676 | if (rc) | ||
677 | return rc; | ||
678 | rc = falcon_spi_write(efx, spi, | ||
679 | eeprom->offset + EFX_EEPROM_BOOTCONFIG_START, | ||
680 | eeprom->len, &len, buf); | ||
681 | mutex_unlock(&efx->spi_lock); | ||
682 | |||
683 | eeprom->len = len; | ||
684 | return rc; | ||
685 | } | ||
686 | |||
687 | static int efx_ethtool_get_coalesce(struct net_device *net_dev, | 631 | static int efx_ethtool_get_coalesce(struct net_device *net_dev, |
688 | struct ethtool_coalesce *coalesce) | 632 | struct ethtool_coalesce *coalesce) |
689 | { | 633 | { |
@@ -1116,9 +1060,6 @@ const struct ethtool_ops efx_ethtool_ops = { | |||
1116 | .set_msglevel = efx_ethtool_set_msglevel, | 1060 | .set_msglevel = efx_ethtool_set_msglevel, |
1117 | .nway_reset = efx_ethtool_nway_reset, | 1061 | .nway_reset = efx_ethtool_nway_reset, |
1118 | .get_link = efx_ethtool_get_link, | 1062 | .get_link = efx_ethtool_get_link, |
1119 | .get_eeprom_len = efx_ethtool_get_eeprom_len, | ||
1120 | .get_eeprom = efx_ethtool_get_eeprom, | ||
1121 | .set_eeprom = efx_ethtool_set_eeprom, | ||
1122 | .get_coalesce = efx_ethtool_get_coalesce, | 1063 | .get_coalesce = efx_ethtool_get_coalesce, |
1123 | .set_coalesce = efx_ethtool_set_coalesce, | 1064 | .set_coalesce = efx_ethtool_set_coalesce, |
1124 | .get_ringparam = efx_ethtool_get_ringparam, | 1065 | .get_ringparam = efx_ethtool_get_ringparam, |
diff --git a/drivers/net/sfc/mtd.c b/drivers/net/sfc/mtd.c index 02e54b4f701f..d44c74584e0f 100644 --- a/drivers/net/sfc/mtd.c +++ b/drivers/net/sfc/mtd.c | |||
@@ -387,35 +387,66 @@ static struct efx_mtd_ops falcon_mtd_ops = { | |||
387 | 387 | ||
388 | static int falcon_mtd_probe(struct efx_nic *efx) | 388 | static int falcon_mtd_probe(struct efx_nic *efx) |
389 | { | 389 | { |
390 | struct efx_spi_device *spi = efx->spi_flash; | 390 | struct efx_spi_device *spi; |
391 | struct efx_mtd *efx_mtd; | 391 | struct efx_mtd *efx_mtd; |
392 | int rc; | 392 | int rc = -ENODEV; |
393 | 393 | ||
394 | ASSERT_RTNL(); | 394 | ASSERT_RTNL(); |
395 | 395 | ||
396 | if (!spi || spi->size <= FALCON_FLASH_BOOTCODE_START) | 396 | spi = efx->spi_flash; |
397 | return -ENODEV; | 397 | if (spi && spi->size > FALCON_FLASH_BOOTCODE_START) { |
398 | 398 | efx_mtd = kzalloc(sizeof(*efx_mtd) + sizeof(efx_mtd->part[0]), | |
399 | efx_mtd = kzalloc(sizeof(*efx_mtd) + sizeof(efx_mtd->part[0]), | 399 | GFP_KERNEL); |
400 | GFP_KERNEL); | 400 | if (!efx_mtd) |
401 | if (!efx_mtd) | 401 | return -ENOMEM; |
402 | return -ENOMEM; | 402 | |
403 | 403 | efx_mtd->spi = spi; | |
404 | efx_mtd->spi = spi; | 404 | efx_mtd->name = "flash"; |
405 | efx_mtd->name = "flash"; | 405 | efx_mtd->ops = &falcon_mtd_ops; |
406 | efx_mtd->ops = &falcon_mtd_ops; | 406 | |
407 | efx_mtd->n_parts = 1; | ||
408 | efx_mtd->part[0].mtd.type = MTD_NORFLASH; | ||
409 | efx_mtd->part[0].mtd.flags = MTD_CAP_NORFLASH; | ||
410 | efx_mtd->part[0].mtd.size = spi->size - FALCON_FLASH_BOOTCODE_START; | ||
411 | efx_mtd->part[0].mtd.erasesize = spi->erase_size; | ||
412 | efx_mtd->part[0].offset = FALCON_FLASH_BOOTCODE_START; | ||
413 | efx_mtd->part[0].type_name = "sfc_flash_bootrom"; | ||
414 | |||
415 | rc = efx_mtd_probe_device(efx, efx_mtd); | ||
416 | if (rc) { | ||
417 | kfree(efx_mtd); | ||
418 | return rc; | ||
419 | } | ||
420 | } | ||
407 | 421 | ||
408 | efx_mtd->n_parts = 1; | 422 | spi = efx->spi_eeprom; |
409 | efx_mtd->part[0].mtd.type = MTD_NORFLASH; | 423 | if (spi && spi->size > EFX_EEPROM_BOOTCONFIG_START) { |
410 | efx_mtd->part[0].mtd.flags = MTD_CAP_NORFLASH; | 424 | efx_mtd = kzalloc(sizeof(*efx_mtd) + sizeof(efx_mtd->part[0]), |
411 | efx_mtd->part[0].mtd.size = spi->size - FALCON_FLASH_BOOTCODE_START; | 425 | GFP_KERNEL); |
412 | efx_mtd->part[0].mtd.erasesize = spi->erase_size; | 426 | if (!efx_mtd) |
413 | efx_mtd->part[0].offset = FALCON_FLASH_BOOTCODE_START; | 427 | return -ENOMEM; |
414 | efx_mtd->part[0].type_name = "sfc_flash_bootrom"; | 428 | |
429 | efx_mtd->spi = spi; | ||
430 | efx_mtd->name = "EEPROM"; | ||
431 | efx_mtd->ops = &falcon_mtd_ops; | ||
432 | |||
433 | efx_mtd->n_parts = 1; | ||
434 | efx_mtd->part[0].mtd.type = MTD_RAM; | ||
435 | efx_mtd->part[0].mtd.flags = MTD_CAP_RAM; | ||
436 | efx_mtd->part[0].mtd.size = | ||
437 | min(spi->size, EFX_EEPROM_BOOTCONFIG_END) - | ||
438 | EFX_EEPROM_BOOTCONFIG_START; | ||
439 | efx_mtd->part[0].mtd.erasesize = spi->erase_size; | ||
440 | efx_mtd->part[0].offset = EFX_EEPROM_BOOTCONFIG_START; | ||
441 | efx_mtd->part[0].type_name = "sfc_bootconfig"; | ||
442 | |||
443 | rc = efx_mtd_probe_device(efx, efx_mtd); | ||
444 | if (rc) { | ||
445 | kfree(efx_mtd); | ||
446 | return rc; | ||
447 | } | ||
448 | } | ||
415 | 449 | ||
416 | rc = efx_mtd_probe_device(efx, efx_mtd); | ||
417 | if (rc) | ||
418 | kfree(efx_mtd); | ||
419 | return rc; | 450 | return rc; |
420 | } | 451 | } |
421 | 452 | ||