aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/scsi/aacraid/commsup.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/scsi/aacraid/commsup.c')
-rw-r--r--drivers/scsi/aacraid/commsup.c43
1 files changed, 22 insertions, 21 deletions
diff --git a/drivers/scsi/aacraid/commsup.c b/drivers/scsi/aacraid/commsup.c
index cb9a92f894ab..310fd80b8c06 100644
--- a/drivers/scsi/aacraid/commsup.c
+++ b/drivers/scsi/aacraid/commsup.c
@@ -796,13 +796,13 @@ static void aac_handle_aif(struct aac_dev * dev, struct fib * fibptr)
796 */ 796 */
797 switch (le32_to_cpu(aifcmd->command)) { 797 switch (le32_to_cpu(aifcmd->command)) {
798 case AifCmdDriverNotify: 798 case AifCmdDriverNotify:
799 switch (le32_to_cpu(((u32 *)aifcmd->data)[0])) { 799 switch (le32_to_cpu(((__le32 *)aifcmd->data)[0])) {
800 /* 800 /*
801 * Morph or Expand complete 801 * Morph or Expand complete
802 */ 802 */
803 case AifDenMorphComplete: 803 case AifDenMorphComplete:
804 case AifDenVolumeExtendComplete: 804 case AifDenVolumeExtendComplete:
805 container = le32_to_cpu(((u32 *)aifcmd->data)[1]); 805 container = le32_to_cpu(((__le32 *)aifcmd->data)[1]);
806 if (container >= dev->maximum_num_containers) 806 if (container >= dev->maximum_num_containers)
807 break; 807 break;
808 808
@@ -835,25 +835,25 @@ static void aac_handle_aif(struct aac_dev * dev, struct fib * fibptr)
835 if (container >= dev->maximum_num_containers) 835 if (container >= dev->maximum_num_containers)
836 break; 836 break;
837 if ((dev->fsa_dev[container].config_waiting_on == 837 if ((dev->fsa_dev[container].config_waiting_on ==
838 le32_to_cpu(*(u32 *)aifcmd->data)) && 838 le32_to_cpu(*(__le32 *)aifcmd->data)) &&
839 time_before(jiffies, dev->fsa_dev[container].config_waiting_stamp + AIF_SNIFF_TIMEOUT)) 839 time_before(jiffies, dev->fsa_dev[container].config_waiting_stamp + AIF_SNIFF_TIMEOUT))
840 dev->fsa_dev[container].config_waiting_on = 0; 840 dev->fsa_dev[container].config_waiting_on = 0;
841 } else for (container = 0; 841 } else for (container = 0;
842 container < dev->maximum_num_containers; ++container) { 842 container < dev->maximum_num_containers; ++container) {
843 if ((dev->fsa_dev[container].config_waiting_on == 843 if ((dev->fsa_dev[container].config_waiting_on ==
844 le32_to_cpu(*(u32 *)aifcmd->data)) && 844 le32_to_cpu(*(__le32 *)aifcmd->data)) &&
845 time_before(jiffies, dev->fsa_dev[container].config_waiting_stamp + AIF_SNIFF_TIMEOUT)) 845 time_before(jiffies, dev->fsa_dev[container].config_waiting_stamp + AIF_SNIFF_TIMEOUT))
846 dev->fsa_dev[container].config_waiting_on = 0; 846 dev->fsa_dev[container].config_waiting_on = 0;
847 } 847 }
848 break; 848 break;
849 849
850 case AifCmdEventNotify: 850 case AifCmdEventNotify:
851 switch (le32_to_cpu(((u32 *)aifcmd->data)[0])) { 851 switch (le32_to_cpu(((__le32 *)aifcmd->data)[0])) {
852 /* 852 /*
853 * Add an Array. 853 * Add an Array.
854 */ 854 */
855 case AifEnAddContainer: 855 case AifEnAddContainer:
856 container = le32_to_cpu(((u32 *)aifcmd->data)[1]); 856 container = le32_to_cpu(((__le32 *)aifcmd->data)[1]);
857 if (container >= dev->maximum_num_containers) 857 if (container >= dev->maximum_num_containers)
858 break; 858 break;
859 dev->fsa_dev[container].config_needed = ADD; 859 dev->fsa_dev[container].config_needed = ADD;
@@ -866,7 +866,7 @@ static void aac_handle_aif(struct aac_dev * dev, struct fib * fibptr)
866 * Delete an Array. 866 * Delete an Array.
867 */ 867 */
868 case AifEnDeleteContainer: 868 case AifEnDeleteContainer:
869 container = le32_to_cpu(((u32 *)aifcmd->data)[1]); 869 container = le32_to_cpu(((__le32 *)aifcmd->data)[1]);
870 if (container >= dev->maximum_num_containers) 870 if (container >= dev->maximum_num_containers)
871 break; 871 break;
872 dev->fsa_dev[container].config_needed = DELETE; 872 dev->fsa_dev[container].config_needed = DELETE;
@@ -880,7 +880,7 @@ static void aac_handle_aif(struct aac_dev * dev, struct fib * fibptr)
880 * waiting on something else, setup to wait on a Config Change. 880 * waiting on something else, setup to wait on a Config Change.
881 */ 881 */
882 case AifEnContainerChange: 882 case AifEnContainerChange:
883 container = le32_to_cpu(((u32 *)aifcmd->data)[1]); 883 container = le32_to_cpu(((__le32 *)aifcmd->data)[1]);
884 if (container >= dev->maximum_num_containers) 884 if (container >= dev->maximum_num_containers)
885 break; 885 break;
886 if (dev->fsa_dev[container].config_waiting_on && 886 if (dev->fsa_dev[container].config_waiting_on &&
@@ -905,13 +905,13 @@ static void aac_handle_aif(struct aac_dev * dev, struct fib * fibptr)
905 if (container >= dev->maximum_num_containers) 905 if (container >= dev->maximum_num_containers)
906 break; 906 break;
907 if ((dev->fsa_dev[container].config_waiting_on == 907 if ((dev->fsa_dev[container].config_waiting_on ==
908 le32_to_cpu(*(u32 *)aifcmd->data)) && 908 le32_to_cpu(*(__le32 *)aifcmd->data)) &&
909 time_before(jiffies, dev->fsa_dev[container].config_waiting_stamp + AIF_SNIFF_TIMEOUT)) 909 time_before(jiffies, dev->fsa_dev[container].config_waiting_stamp + AIF_SNIFF_TIMEOUT))
910 dev->fsa_dev[container].config_waiting_on = 0; 910 dev->fsa_dev[container].config_waiting_on = 0;
911 } else for (container = 0; 911 } else for (container = 0;
912 container < dev->maximum_num_containers; ++container) { 912 container < dev->maximum_num_containers; ++container) {
913 if ((dev->fsa_dev[container].config_waiting_on == 913 if ((dev->fsa_dev[container].config_waiting_on ==
914 le32_to_cpu(*(u32 *)aifcmd->data)) && 914 le32_to_cpu(*(__le32 *)aifcmd->data)) &&
915 time_before(jiffies, dev->fsa_dev[container].config_waiting_stamp + AIF_SNIFF_TIMEOUT)) 915 time_before(jiffies, dev->fsa_dev[container].config_waiting_stamp + AIF_SNIFF_TIMEOUT))
916 dev->fsa_dev[container].config_waiting_on = 0; 916 dev->fsa_dev[container].config_waiting_on = 0;
917 } 917 }
@@ -926,9 +926,9 @@ static void aac_handle_aif(struct aac_dev * dev, struct fib * fibptr)
926 * wait for a container change. 926 * wait for a container change.
927 */ 927 */
928 928
929 if ((((u32 *)aifcmd->data)[1] == cpu_to_le32(AifJobCtrZero)) 929 if (((__le32 *)aifcmd->data)[1] == cpu_to_le32(AifJobCtrZero) &&
930 && ((((u32 *)aifcmd->data)[6] == ((u32 *)aifcmd->data)[5]) 930 (((__le32 *)aifcmd->data)[6] == ((__le32 *)aifcmd->data)[5] ||
931 || (((u32 *)aifcmd->data)[4] == cpu_to_le32(AifJobStsSuccess)))) { 931 ((__le32 *)aifcmd->data)[4] == cpu_to_le32(AifJobStsSuccess))) {
932 for (container = 0; 932 for (container = 0;
933 container < dev->maximum_num_containers; 933 container < dev->maximum_num_containers;
934 ++container) { 934 ++container) {
@@ -943,9 +943,9 @@ static void aac_handle_aif(struct aac_dev * dev, struct fib * fibptr)
943 jiffies; 943 jiffies;
944 } 944 }
945 } 945 }
946 if ((((u32 *)aifcmd->data)[1] == cpu_to_le32(AifJobCtrZero)) 946 if (((__le32 *)aifcmd->data)[1] == cpu_to_le32(AifJobCtrZero) &&
947 && (((u32 *)aifcmd->data)[6] == 0) 947 ((__le32 *)aifcmd->data)[6] == 0 &&
948 && (((u32 *)aifcmd->data)[4] == cpu_to_le32(AifJobStsRunning))) { 948 ((__le32 *)aifcmd->data)[4] == cpu_to_le32(AifJobStsRunning)) {
949 for (container = 0; 949 for (container = 0;
950 container < dev->maximum_num_containers; 950 container < dev->maximum_num_containers;
951 ++container) { 951 ++container) {
@@ -1373,9 +1373,10 @@ int aac_check_health(struct aac_dev * aac)
1373 1373
1374 printk(KERN_ERR "%s: Host adapter BLINK LED 0x%x\n", aac->name, BlinkLED); 1374 printk(KERN_ERR "%s: Host adapter BLINK LED 0x%x\n", aac->name, BlinkLED);
1375 1375
1376 if (!aac_check_reset || ((aac_check_reset != 1) && 1376 if (!aac_check_reset ||
1377 (aac->supplement_adapter_info.SupportedOptions2 & 1377 ((aac_check_reset != 1) &&
1378 le32_to_cpu(AAC_OPTION_IGNORE_RESET)))) 1378 (aac->supplement_adapter_info.SupportedOptions2 &
1379 cpu_to_le32(AAC_OPTION_IGNORE_RESET))))
1379 goto out; 1380 goto out;
1380 host = aac->scsi_host_ptr; 1381 host = aac->scsi_host_ptr;
1381 if (aac->thread->pid != current->pid) 1382 if (aac->thread->pid != current->pid)
@@ -1656,11 +1657,11 @@ int aac_command_thread(void *data)
1656 struct fib *fibptr; 1657 struct fib *fibptr;
1657 1658
1658 if ((fibptr = aac_fib_alloc(dev))) { 1659 if ((fibptr = aac_fib_alloc(dev))) {
1659 u32 * info; 1660 __le32 *info;
1660 1661
1661 aac_fib_init(fibptr); 1662 aac_fib_init(fibptr);
1662 1663
1663 info = (u32 *) fib_data(fibptr); 1664 info = (__le32 *) fib_data(fibptr);
1664 if (now.tv_usec > 500000) 1665 if (now.tv_usec > 500000)
1665 ++now.tv_sec; 1666 ++now.tv_sec;
1666 1667