diff options
author | Akeem G. Abodunrin <akeem.g.abodunrin@intel.com> | 2013-01-29 05:15:10 -0500 |
---|---|---|
committer | Jeff Kirsher <jeffrey.t.kirsher@intel.com> | 2013-02-15 04:40:45 -0500 |
commit | a6053d76bd893a8bd7ecb8681d85b35cd4b45936 (patch) | |
tree | 4e2d3e1209282b2a272817c60c0ff225121436c7 | |
parent | a1bf1f44c6ee3ddf803063692a2f1d5ed483efdc (diff) |
igb: Refractoring function pointers in igb_get_invariants function
This patch simplifies igb_get_invariants function by moving all implemented
function pointers in this function to individual separate functions,
based on their functionalities, this would make debugging much easier.
Signed-off-by: Akeem G Abodunrin <akeem.g.abodunrin@intel.com>
Tested-by: Aaron Brown <aaron.f.brown@intel.com>
Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
-rw-r--r-- | drivers/net/ethernet/intel/igb/e1000_82575.c | 262 |
1 files changed, 11 insertions, 251 deletions
diff --git a/drivers/net/ethernet/intel/igb/e1000_82575.c b/drivers/net/ethernet/intel/igb/e1000_82575.c index 8604013a21b5..84e7e0909def 100644 --- a/drivers/net/ethernet/intel/igb/e1000_82575.c +++ b/drivers/net/ethernet/intel/igb/e1000_82575.c | |||
@@ -395,13 +395,9 @@ static s32 igb_init_mac_params_82575(struct e1000_hw *hw) | |||
395 | 395 | ||
396 | static s32 igb_get_invariants_82575(struct e1000_hw *hw) | 396 | static s32 igb_get_invariants_82575(struct e1000_hw *hw) |
397 | { | 397 | { |
398 | struct e1000_phy_info *phy = &hw->phy; | ||
399 | struct e1000_nvm_info *nvm = &hw->nvm; | ||
400 | struct e1000_mac_info *mac = &hw->mac; | 398 | struct e1000_mac_info *mac = &hw->mac; |
401 | struct e1000_dev_spec_82575 * dev_spec = &hw->dev_spec._82575; | 399 | struct e1000_dev_spec_82575 * dev_spec = &hw->dev_spec._82575; |
402 | u32 eecd; | ||
403 | s32 ret_val; | 400 | s32 ret_val; |
404 | u16 size; | ||
405 | u32 ctrl_ext = 0; | 401 | u32 ctrl_ext = 0; |
406 | 402 | ||
407 | switch (hw->device_id) { | 403 | switch (hw->device_id) { |
@@ -462,7 +458,7 @@ static s32 igb_get_invariants_82575(struct e1000_hw *hw) | |||
462 | * SerDes mode on the 82575. There can be an external PHY attached | 458 | * SerDes mode on the 82575. There can be an external PHY attached |
463 | * on the SGMII interface. For this, we'll set sgmii_active to true. | 459 | * on the SGMII interface. For this, we'll set sgmii_active to true. |
464 | */ | 460 | */ |
465 | phy->media_type = e1000_media_type_copper; | 461 | hw->phy.media_type = e1000_media_type_copper; |
466 | dev_spec->sgmii_active = false; | 462 | dev_spec->sgmii_active = false; |
467 | 463 | ||
468 | ctrl_ext = rd32(E1000_CTRL_EXT); | 464 | ctrl_ext = rd32(E1000_CTRL_EXT); |
@@ -478,154 +474,15 @@ static s32 igb_get_invariants_82575(struct e1000_hw *hw) | |||
478 | break; | 474 | break; |
479 | } | 475 | } |
480 | 476 | ||
481 | /* Set mta register count */ | 477 | /* mac initialization and operations */ |
482 | mac->mta_reg_count = 128; | 478 | ret_val = igb_init_mac_params_82575(hw); |
483 | /* Set rar entry count */ | 479 | if (ret_val) |
484 | switch (mac->type) { | 480 | goto out; |
485 | case e1000_82576: | ||
486 | mac->rar_entry_count = E1000_RAR_ENTRIES_82576; | ||
487 | break; | ||
488 | case e1000_82580: | ||
489 | mac->rar_entry_count = E1000_RAR_ENTRIES_82580; | ||
490 | break; | ||
491 | case e1000_i350: | ||
492 | mac->rar_entry_count = E1000_RAR_ENTRIES_I350; | ||
493 | break; | ||
494 | default: | ||
495 | mac->rar_entry_count = E1000_RAR_ENTRIES_82575; | ||
496 | break; | ||
497 | } | ||
498 | /* reset */ | ||
499 | if (mac->type >= e1000_82580) | ||
500 | mac->ops.reset_hw = igb_reset_hw_82580; | ||
501 | else | ||
502 | mac->ops.reset_hw = igb_reset_hw_82575; | ||
503 | |||
504 | if (mac->type >= e1000_i210) { | ||
505 | mac->ops.acquire_swfw_sync = igb_acquire_swfw_sync_i210; | ||
506 | mac->ops.release_swfw_sync = igb_release_swfw_sync_i210; | ||
507 | } else { | ||
508 | mac->ops.acquire_swfw_sync = igb_acquire_swfw_sync_82575; | ||
509 | mac->ops.release_swfw_sync = igb_release_swfw_sync_82575; | ||
510 | } | ||
511 | |||
512 | /* Set if part includes ASF firmware */ | ||
513 | mac->asf_firmware_present = true; | ||
514 | /* Set if manageability features are enabled. */ | ||
515 | mac->arc_subsystem_valid = | ||
516 | (rd32(E1000_FWSM) & E1000_FWSM_MODE_MASK) | ||
517 | ? true : false; | ||
518 | /* enable EEE on i350 parts and later parts */ | ||
519 | if (mac->type >= e1000_i350) | ||
520 | dev_spec->eee_disable = false; | ||
521 | else | ||
522 | dev_spec->eee_disable = true; | ||
523 | /* physical interface link setup */ | ||
524 | mac->ops.setup_physical_interface = | ||
525 | (hw->phy.media_type == e1000_media_type_copper) | ||
526 | ? igb_setup_copper_link_82575 | ||
527 | : igb_setup_serdes_link_82575; | ||
528 | 481 | ||
529 | /* NVM initialization */ | 482 | /* NVM initialization */ |
530 | eecd = rd32(E1000_EECD); | 483 | ret_val = igb_init_nvm_params_82575(hw); |
531 | size = (u16)((eecd & E1000_EECD_SIZE_EX_MASK) >> | 484 | if (ret_val) |
532 | E1000_EECD_SIZE_EX_SHIFT); | 485 | goto out; |
533 | |||
534 | /* | ||
535 | * Added to a constant, "size" becomes the left-shift value | ||
536 | * for setting word_size. | ||
537 | */ | ||
538 | size += NVM_WORD_SIZE_BASE_SHIFT; | ||
539 | |||
540 | /* | ||
541 | * Check for invalid size | ||
542 | */ | ||
543 | if ((hw->mac.type == e1000_82576) && (size > 15)) { | ||
544 | pr_notice("The NVM size is not valid, defaulting to 32K\n"); | ||
545 | size = 15; | ||
546 | } | ||
547 | |||
548 | nvm->word_size = 1 << size; | ||
549 | if (hw->mac.type < e1000_i210) { | ||
550 | nvm->opcode_bits = 8; | ||
551 | nvm->delay_usec = 1; | ||
552 | switch (nvm->override) { | ||
553 | case e1000_nvm_override_spi_large: | ||
554 | nvm->page_size = 32; | ||
555 | nvm->address_bits = 16; | ||
556 | break; | ||
557 | case e1000_nvm_override_spi_small: | ||
558 | nvm->page_size = 8; | ||
559 | nvm->address_bits = 8; | ||
560 | break; | ||
561 | default: | ||
562 | nvm->page_size = eecd | ||
563 | & E1000_EECD_ADDR_BITS ? 32 : 8; | ||
564 | nvm->address_bits = eecd | ||
565 | & E1000_EECD_ADDR_BITS ? 16 : 8; | ||
566 | break; | ||
567 | } | ||
568 | if (nvm->word_size == (1 << 15)) | ||
569 | nvm->page_size = 128; | ||
570 | |||
571 | nvm->type = e1000_nvm_eeprom_spi; | ||
572 | } else | ||
573 | nvm->type = e1000_nvm_flash_hw; | ||
574 | |||
575 | /* NVM Function Pointers */ | ||
576 | switch (hw->mac.type) { | ||
577 | case e1000_82580: | ||
578 | nvm->ops.validate = igb_validate_nvm_checksum_82580; | ||
579 | nvm->ops.update = igb_update_nvm_checksum_82580; | ||
580 | nvm->ops.acquire = igb_acquire_nvm_82575; | ||
581 | nvm->ops.release = igb_release_nvm_82575; | ||
582 | if (nvm->word_size < (1 << 15)) | ||
583 | nvm->ops.read = igb_read_nvm_eerd; | ||
584 | else | ||
585 | nvm->ops.read = igb_read_nvm_spi; | ||
586 | nvm->ops.write = igb_write_nvm_spi; | ||
587 | break; | ||
588 | case e1000_i350: | ||
589 | nvm->ops.validate = igb_validate_nvm_checksum_i350; | ||
590 | nvm->ops.update = igb_update_nvm_checksum_i350; | ||
591 | nvm->ops.acquire = igb_acquire_nvm_82575; | ||
592 | nvm->ops.release = igb_release_nvm_82575; | ||
593 | if (nvm->word_size < (1 << 15)) | ||
594 | nvm->ops.read = igb_read_nvm_eerd; | ||
595 | else | ||
596 | nvm->ops.read = igb_read_nvm_spi; | ||
597 | nvm->ops.write = igb_write_nvm_spi; | ||
598 | break; | ||
599 | case e1000_i210: | ||
600 | nvm->ops.validate = igb_validate_nvm_checksum_i210; | ||
601 | nvm->ops.update = igb_update_nvm_checksum_i210; | ||
602 | nvm->ops.acquire = igb_acquire_nvm_i210; | ||
603 | nvm->ops.release = igb_release_nvm_i210; | ||
604 | nvm->ops.read = igb_read_nvm_srrd_i210; | ||
605 | nvm->ops.write = igb_write_nvm_srwr_i210; | ||
606 | nvm->ops.valid_led_default = igb_valid_led_default_i210; | ||
607 | break; | ||
608 | case e1000_i211: | ||
609 | nvm->ops.acquire = igb_acquire_nvm_i210; | ||
610 | nvm->ops.release = igb_release_nvm_i210; | ||
611 | nvm->ops.read = igb_read_nvm_i211; | ||
612 | nvm->ops.valid_led_default = igb_valid_led_default_i210; | ||
613 | nvm->ops.validate = NULL; | ||
614 | nvm->ops.update = NULL; | ||
615 | nvm->ops.write = NULL; | ||
616 | break; | ||
617 | default: | ||
618 | nvm->ops.validate = igb_validate_nvm_checksum; | ||
619 | nvm->ops.update = igb_update_nvm_checksum; | ||
620 | nvm->ops.acquire = igb_acquire_nvm_82575; | ||
621 | nvm->ops.release = igb_release_nvm_82575; | ||
622 | if (nvm->word_size < (1 << 15)) | ||
623 | nvm->ops.read = igb_read_nvm_eerd; | ||
624 | else | ||
625 | nvm->ops.read = igb_read_nvm_spi; | ||
626 | nvm->ops.write = igb_write_nvm_spi; | ||
627 | break; | ||
628 | } | ||
629 | 486 | ||
630 | /* if part supports SR-IOV then initialize mailbox parameters */ | 487 | /* if part supports SR-IOV then initialize mailbox parameters */ |
631 | switch (mac->type) { | 488 | switch (mac->type) { |
@@ -638,107 +495,10 @@ static s32 igb_get_invariants_82575(struct e1000_hw *hw) | |||
638 | } | 495 | } |
639 | 496 | ||
640 | /* setup PHY parameters */ | 497 | /* setup PHY parameters */ |
641 | if (phy->media_type != e1000_media_type_copper) { | 498 | ret_val = igb_init_phy_params_82575(hw); |
642 | phy->type = e1000_phy_none; | ||
643 | return 0; | ||
644 | } | ||
645 | |||
646 | phy->autoneg_mask = AUTONEG_ADVERTISE_SPEED_DEFAULT; | ||
647 | phy->reset_delay_us = 100; | ||
648 | |||
649 | ctrl_ext = rd32(E1000_CTRL_EXT); | ||
650 | |||
651 | /* PHY function pointers */ | ||
652 | if (igb_sgmii_active_82575(hw)) { | ||
653 | phy->ops.reset = igb_phy_hw_reset_sgmii_82575; | ||
654 | ctrl_ext |= E1000_CTRL_I2C_ENA; | ||
655 | } else { | ||
656 | phy->ops.reset = igb_phy_hw_reset; | ||
657 | ctrl_ext &= ~E1000_CTRL_I2C_ENA; | ||
658 | } | ||
659 | |||
660 | wr32(E1000_CTRL_EXT, ctrl_ext); | ||
661 | igb_reset_mdicnfg_82580(hw); | ||
662 | |||
663 | if (igb_sgmii_active_82575(hw) && !igb_sgmii_uses_mdio_82575(hw)) { | ||
664 | phy->ops.read_reg = igb_read_phy_reg_sgmii_82575; | ||
665 | phy->ops.write_reg = igb_write_phy_reg_sgmii_82575; | ||
666 | } else if ((hw->mac.type == e1000_82580) | ||
667 | || (hw->mac.type == e1000_i350)) { | ||
668 | phy->ops.read_reg = igb_read_phy_reg_82580; | ||
669 | phy->ops.write_reg = igb_write_phy_reg_82580; | ||
670 | } else if (hw->phy.type >= e1000_phy_i210) { | ||
671 | phy->ops.read_reg = igb_read_phy_reg_gs40g; | ||
672 | phy->ops.write_reg = igb_write_phy_reg_gs40g; | ||
673 | } else { | ||
674 | phy->ops.read_reg = igb_read_phy_reg_igp; | ||
675 | phy->ops.write_reg = igb_write_phy_reg_igp; | ||
676 | } | ||
677 | |||
678 | /* set lan id */ | ||
679 | hw->bus.func = (rd32(E1000_STATUS) & E1000_STATUS_FUNC_MASK) >> | ||
680 | E1000_STATUS_FUNC_SHIFT; | ||
681 | 499 | ||
682 | /* Set phy->phy_addr and phy->id. */ | 500 | out: |
683 | ret_val = igb_get_phy_id_82575(hw); | 501 | return ret_val; |
684 | if (ret_val) | ||
685 | return ret_val; | ||
686 | |||
687 | /* Verify phy id and set remaining function pointers */ | ||
688 | switch (phy->id) { | ||
689 | case I347AT4_E_PHY_ID: | ||
690 | case M88E1112_E_PHY_ID: | ||
691 | case M88E1111_I_PHY_ID: | ||
692 | phy->type = e1000_phy_m88; | ||
693 | phy->ops.get_phy_info = igb_get_phy_info_m88; | ||
694 | |||
695 | if (phy->id == I347AT4_E_PHY_ID || | ||
696 | phy->id == M88E1112_E_PHY_ID) | ||
697 | phy->ops.get_cable_length = igb_get_cable_length_m88_gen2; | ||
698 | else | ||
699 | phy->ops.get_cable_length = igb_get_cable_length_m88; | ||
700 | |||
701 | if (phy->id == I210_I_PHY_ID) { | ||
702 | phy->ops.get_cable_length = | ||
703 | igb_get_cable_length_m88_gen2; | ||
704 | phy->ops.set_d0_lplu_state = | ||
705 | igb_set_d0_lplu_state_82580; | ||
706 | phy->ops.set_d3_lplu_state = | ||
707 | igb_set_d3_lplu_state_82580; | ||
708 | } | ||
709 | phy->ops.force_speed_duplex = igb_phy_force_speed_duplex_m88; | ||
710 | break; | ||
711 | case IGP03E1000_E_PHY_ID: | ||
712 | phy->type = e1000_phy_igp_3; | ||
713 | phy->ops.get_phy_info = igb_get_phy_info_igp; | ||
714 | phy->ops.get_cable_length = igb_get_cable_length_igp_2; | ||
715 | phy->ops.force_speed_duplex = igb_phy_force_speed_duplex_igp; | ||
716 | phy->ops.set_d0_lplu_state = igb_set_d0_lplu_state_82575; | ||
717 | phy->ops.set_d3_lplu_state = igb_set_d3_lplu_state; | ||
718 | break; | ||
719 | case I82580_I_PHY_ID: | ||
720 | case I350_I_PHY_ID: | ||
721 | phy->type = e1000_phy_82580; | ||
722 | phy->ops.force_speed_duplex = igb_phy_force_speed_duplex_82580; | ||
723 | phy->ops.get_cable_length = igb_get_cable_length_82580; | ||
724 | phy->ops.get_phy_info = igb_get_phy_info_82580; | ||
725 | phy->ops.set_d0_lplu_state = igb_set_d0_lplu_state_82580; | ||
726 | phy->ops.set_d3_lplu_state = igb_set_d3_lplu_state_82580; | ||
727 | break; | ||
728 | case I210_I_PHY_ID: | ||
729 | phy->type = e1000_phy_i210; | ||
730 | phy->ops.get_phy_info = igb_get_phy_info_m88; | ||
731 | phy->ops.check_polarity = igb_check_polarity_m88; | ||
732 | phy->ops.get_cable_length = igb_get_cable_length_m88_gen2; | ||
733 | phy->ops.set_d0_lplu_state = igb_set_d0_lplu_state_82580; | ||
734 | phy->ops.set_d3_lplu_state = igb_set_d3_lplu_state_82580; | ||
735 | phy->ops.force_speed_duplex = igb_phy_force_speed_duplex_m88; | ||
736 | break; | ||
737 | default: | ||
738 | return -E1000_ERR_PHY; | ||
739 | } | ||
740 | |||
741 | return 0; | ||
742 | } | 502 | } |
743 | 503 | ||
744 | /** | 504 | /** |