Merge branch 'master' of git://git.kernel.org/pub/scm/linux/storage/multipath-tools/
[platform/upstream/multipath-tools.git] / libmultipath / hwtable.c
1 #include <stdio.h>
2
3 #include "checkers.h"
4 #include "vector.h"
5 #include "defaults.h"
6 #include "structs.h"
7 #include "config.h"
8 #include "pgpolicies.h"
9 #include "prio.h"
10
11 /*
12  * Tuning suggestions on these parameters should go to
13  * dm-devel@redhat.com
14  * 
15  * You are welcome to claim maintainership over a controller
16  * family. Please mail the currently enlisted maintainer and
17  * the upstream package maintainer.
18  */
19 static struct hwentry default_hw[] = {
20         /*
21          * Apple controller family
22          *
23          * Maintainer : Shyam Sundar
24          * Mail : g.shyamsundar@yahoo.co.in
25          */
26         {
27                 .vendor        = "APPLE*",
28                 .product       = "Xserve RAID ",
29                 .getuid        = DEFAULT_GETUID,
30                 .features      = DEFAULT_FEATURES,
31                 .hwhandler     = DEFAULT_HWHANDLER,
32                 .selector      = DEFAULT_SELECTOR,
33                 .pgpolicy      = MULTIBUS,
34                 .pgfailback    = FAILBACK_UNDEF,
35                 .rr_weight     = RR_WEIGHT_NONE,
36                 .no_path_retry = NO_PATH_RETRY_UNDEF,
37                 .minio         = DEFAULT_MINIO,
38                 .checker_name  = DEFAULT_CHECKER,
39                 .prio_name     = DEFAULT_PRIO,
40         },
41         /*
42          * StorageWorks controller family
43          *
44          * Maintainer : Christophe Varoqui
45          * Mail : christophe.varoqui@free.fr
46          */
47         {
48                 .vendor        = "3PARdata",
49                 .product       = "VV",
50                 .getuid        = DEFAULT_GETUID,
51                 .features      = DEFAULT_FEATURES,
52                 .hwhandler     = DEFAULT_HWHANDLER,
53                 .selector      = DEFAULT_SELECTOR,
54                 .pgpolicy      = MULTIBUS,
55                 .pgfailback    = FAILBACK_UNDEF,
56                 .rr_weight     = RR_WEIGHT_NONE,
57                 .no_path_retry = NO_PATH_RETRY_UNDEF,
58                 .minio         = DEFAULT_MINIO,
59                 .checker_name  = DEFAULT_CHECKER,
60                 .prio_name     = DEFAULT_PRIO,
61         },
62         {
63                 .vendor        = "DEC",
64                 .product       = "HSG80",
65                 .getuid        = DEFAULT_GETUID,
66                 .features      = "1 queue_if_no_path",
67                 .hwhandler     = "1 hp-sw",
68                 .selector      = DEFAULT_SELECTOR,
69                 .pgpolicy      = GROUP_BY_PRIO,
70                 .pgfailback    = FAILBACK_UNDEF,
71                 .rr_weight     = RR_WEIGHT_NONE,
72                 .no_path_retry = NO_PATH_RETRY_UNDEF,
73                 .minio         = DEFAULT_MINIO,
74                 .checker_name  = HP_SW,
75                 .prio_name     = PRIO_HP_SW,
76         },
77         {
78                 .vendor        = "HP",
79                 .product       = "A6189A",
80                 .getuid        = DEFAULT_GETUID,
81                 .features      = DEFAULT_FEATURES,
82                 .hwhandler     = DEFAULT_HWHANDLER,
83                 .selector      = DEFAULT_SELECTOR,
84                 .pgpolicy      = MULTIBUS,
85                 .pgfailback    = FAILBACK_UNDEF,
86                 .rr_weight     = RR_WEIGHT_NONE,
87                 .no_path_retry = 12,
88                 .minio         = DEFAULT_MINIO,
89                 .checker_name  = DIRECTIO,
90                 .prio_name     = DEFAULT_PRIO,
91         },
92         {
93                 /* MSA 1000/MSA1500 EVA 3000/5000 with old firmware */
94                 .vendor        = "(COMPAQ|HP)",
95                 .product       = "(MSA|HSV)1.0.*",
96                 .getuid        = DEFAULT_GETUID,
97                 .features      = "1 queue_if_no_path",
98                 .hwhandler     = "1 hp-sw",
99                 .selector      = DEFAULT_SELECTOR,
100                 .pgpolicy      = GROUP_BY_PRIO,
101                 .pgfailback    = FAILBACK_UNDEF,
102                 .rr_weight     = RR_WEIGHT_NONE,
103                 .no_path_retry = 12,
104                 .minio         = DEFAULT_MINIO,
105                 .checker_name  = HP_SW,
106                 .prio_name     = PRIO_HP_SW,
107         },
108         {
109                 /* MSA 1000/1500 with new firmware */
110                 .vendor        = "HP",
111                 .product       = "MSA VOLUME",
112                 .getuid        = DEFAULT_GETUID,
113                 .features      = DEFAULT_FEATURES,
114                 .hwhandler     = DEFAULT_HWHANDLER,
115                 .selector      = DEFAULT_SELECTOR,
116                 .pgpolicy      = GROUP_BY_PRIO,
117                 .pgfailback    = -FAILBACK_IMMEDIATE,
118                 .rr_weight     = RR_WEIGHT_NONE,
119                 .no_path_retry = 12,
120                 .minio         = DEFAULT_MINIO,
121                 .checker_name  = TUR,
122                 .prio_name     = PRIO_ALUA,
123         },
124         {
125                 .vendor        = "HP",
126                 .product       = "MSA2000s*",
127                 .getuid        = "/sbin/cciss_id %n",
128                 .features      = DEFAULT_FEATURES,
129                 .hwhandler     = DEFAULT_HWHANDLER,
130                 .selector      = DEFAULT_SELECTOR,
131                 .pgpolicy      = GROUP_BY_PRIO,
132                 .pgfailback    = -FAILBACK_IMMEDIATE,
133                 .rr_weight     = RR_WEIGHT_NONE,
134                 .no_path_retry = 12,
135                 .minio         = DEFAULT_MINIO,
136                 .checker_name  = TUR,
137                 .prio_name     = DEFAULT_PRIO,
138         },
139         {
140                 /* EVA 3000/5000 with new firmware, EVA 4000/6000/8000 */
141                 .vendor        = "(COMPAQ|HP)",
142                 .product       = "HSV1[01]1|HSV2[01]0|HSV300",
143                 .getuid        = DEFAULT_GETUID,
144                 .features      = DEFAULT_FEATURES,
145                 .hwhandler     = DEFAULT_HWHANDLER,
146                 .selector      = DEFAULT_SELECTOR,
147                 .pgpolicy      = GROUP_BY_PRIO,
148                 .pgfailback    = -FAILBACK_IMMEDIATE,
149                 .rr_weight     = RR_WEIGHT_NONE,
150                 .no_path_retry = 12,
151                 .minio         = DEFAULT_MINIO,
152                 .checker_name  = TUR,
153                 .prio_name     = PRIO_ALUA,
154         },
155         {
156                 /* HP MSA2000 product family */
157                 .vendor        = "HP",
158                 .product       = "MSA2[02]12*",
159                 .getuid        = DEFAULT_GETUID,
160                 .features      = DEFAULT_FEATURES,
161                 .hwhandler     = DEFAULT_HWHANDLER,
162                 .selector      = DEFAULT_SELECTOR,
163                 .pgpolicy      = MULTIBUS,
164                 .pgfailback    = -FAILBACK_IMMEDIATE,
165                 .rr_weight     = RR_WEIGHT_NONE,
166                 .no_path_retry = 12,
167                 .minio         = DEFAULT_MINIO,
168                 .checker_name  = TUR,
169                 .prio_name     = DEFAULT_PRIO,
170         },
171         {
172                 /* HP Smart Array */
173                 .vendor        = "HP",
174                 .product       = "LOGICAL VOLUME.*",
175                 .getuid        = "/lib/udev/scsi_id -n -g -u -s /block/%n",
176                 .features      = DEFAULT_FEATURES,
177                 .hwhandler     = DEFAULT_HWHANDLER,
178                 .selector      = DEFAULT_SELECTOR,
179                 .pgpolicy      = MULTIBUS,
180                 .pgfailback    = FAILBACK_UNDEF,
181                 .rr_weight     = RR_WEIGHT_NONE,
182                 .no_path_retry = 12,
183                 .minio         = DEFAULT_MINIO,
184                 .checker_name  = CCISS_TUR,
185                 .prio_name     = DEFAULT_PRIO,
186         },
187         /*
188          * DDN controller family
189          *
190          * Maintainer : Christophe Varoqui
191          * Mail : christophe.varoqui@free.fr
192          */
193         {
194                 .vendor        = "DDN",
195                 .product       = "SAN DataDirector",
196                 .getuid        = DEFAULT_GETUID,
197                 .features      = DEFAULT_FEATURES,
198                 .hwhandler     = DEFAULT_HWHANDLER,
199                 .selector      = DEFAULT_SELECTOR,
200                 .pgpolicy      = MULTIBUS,
201                 .pgfailback    = FAILBACK_UNDEF,
202                 .rr_weight     = RR_WEIGHT_NONE,
203                 .no_path_retry = NO_PATH_RETRY_UNDEF,
204                 .minio         = DEFAULT_MINIO,
205                 .checker_name  = DIRECTIO,
206                 .prio_name     = DEFAULT_PRIO,
207         },
208         /*
209          * EMC / Clariion controller family
210          *
211          * Maintainer : Edward Goggin, EMC
212          * Mail : egoggin@emc.com
213          */
214         {
215                 .vendor        = "EMC",
216                 .product       = "SYMMETRIX",
217                 .getuid        = "/lib/udev/scsi_id -g -u -ppre-spc3-83 -s /block/%n",
218                 .features      = DEFAULT_FEATURES,
219                 .hwhandler     = DEFAULT_HWHANDLER,
220                 .selector      = DEFAULT_SELECTOR,
221                 .pgpolicy      = MULTIBUS,
222                 .pgfailback    = FAILBACK_UNDEF,
223                 .rr_weight     = RR_WEIGHT_NONE,
224                 .no_path_retry = NO_PATH_RETRY_UNDEF,
225                 .minio         = DEFAULT_MINIO,
226                 .checker_name  = DIRECTIO,
227                 .prio_name     = DEFAULT_PRIO,
228         },
229         {
230                 .vendor        = "DGC",
231                 .product       = ".*",
232                 .bl_product    = "LUNZ",
233                 .getuid        = DEFAULT_GETUID,
234                 .features      = "1 queue_if_no_path",
235                 .hwhandler     = "1 emc",
236                 .selector      = DEFAULT_SELECTOR,
237                 .pgpolicy      = GROUP_BY_PRIO,
238                 .pgfailback    = -FAILBACK_IMMEDIATE,
239                 .rr_weight     = RR_WEIGHT_NONE,
240                 .no_path_retry = (300 / DEFAULT_CHECKINT),
241                 .minio         = DEFAULT_MINIO,
242                 .checker_name  = EMC_CLARIION,
243                 .prio_name     = PRIO_EMC,
244         },
245         /*
246          * Fujitsu controller family
247          *
248          * Maintainer : Christophe Varoqui
249          * Mail : christophe.varoqui@free.fr
250          */
251         {
252                 .vendor        = "FSC",
253                 .product       = "CentricStor",
254                 .getuid        = DEFAULT_GETUID,
255                 .features      = DEFAULT_FEATURES,
256                 .hwhandler     = DEFAULT_HWHANDLER,
257                 .selector      = DEFAULT_SELECTOR,
258                 .pgpolicy      = GROUP_BY_SERIAL,
259                 .pgfailback    = FAILBACK_UNDEF,
260                 .rr_weight     = RR_WEIGHT_NONE,
261                 .no_path_retry = NO_PATH_RETRY_UNDEF,
262                 .minio         = DEFAULT_MINIO,
263                 .checker_name  = DIRECTIO,
264                 .prio_name     = DEFAULT_PRIO,
265         },
266         /*
267          * Hitachi controller family
268          *
269          * Maintainer : Matthias Rudolph
270          * Mail : matthias.rudolph@hds.com
271          */
272         {
273                 .vendor        = "(HITACHI|HP)",
274                 .product       = "OPEN-.*",
275                 .getuid        = DEFAULT_GETUID,
276                 .features      = "1 queue_if_no_path",
277                 .hwhandler     = DEFAULT_HWHANDLER,
278                 .selector      = DEFAULT_SELECTOR,
279                 .pgpolicy      = MULTIBUS,
280                 .pgfailback    = FAILBACK_UNDEF,
281                 .rr_weight     = RR_WEIGHT_NONE,
282                 .no_path_retry = NO_PATH_RETRY_UNDEF,
283                 .minio         = DEFAULT_MINIO,
284                 .checker_name  = TUR,
285                 .prio_name     = DEFAULT_PRIO,
286         },
287         {
288                 .vendor        = "HITACHI",
289                 .product       = "DF.*",
290                 .getuid        = DEFAULT_GETUID,
291                 .features      = "1 queue_if_no_path",
292                 .hwhandler     = DEFAULT_HWHANDLER,
293                 .selector      = DEFAULT_SELECTOR,
294                 .pgpolicy      = GROUP_BY_PRIO,
295                 .pgfailback    = -FAILBACK_IMMEDIATE,
296                 .rr_weight     = RR_WEIGHT_NONE,
297                 .no_path_retry = NO_PATH_RETRY_UNDEF,
298                 .minio         = DEFAULT_MINIO,
299                 .checker_name  = TUR,
300                 .prio_name     = PRIO_HDS,
301         },
302         /*
303          * IBM controller family
304          *
305          * Maintainer : Hannes Reinecke, SuSE
306          * Mail : hare@suse.de
307          */
308         {
309                 .vendor        = "IBM",
310                 .product       = "ProFibre 4000R",
311                 .getuid        = DEFAULT_GETUID,
312                 .features      = DEFAULT_FEATURES,
313                 .hwhandler     = DEFAULT_HWHANDLER,
314                 .selector      = DEFAULT_SELECTOR,
315                 .pgpolicy      = MULTIBUS,
316                 .pgfailback    = FAILBACK_UNDEF,
317                 .rr_weight     = RR_WEIGHT_NONE,
318                 .no_path_retry = NO_PATH_RETRY_UNDEF,
319                 .minio         = DEFAULT_MINIO,
320                 .checker_name  = DIRECTIO,
321                 .prio_name     = DEFAULT_PRIO,
322         },
323         {
324                 /* IBM FAStT 1722-600 */
325                 .vendor        = "IBM",
326                 .product       = "1722-600",
327                 .getuid        = DEFAULT_GETUID,
328                 .features      = "1 queue_if_no_path",
329                 .hwhandler     = "1 rdac",
330                 .selector      = DEFAULT_SELECTOR,
331                 .pgpolicy      = GROUP_BY_PRIO,
332                 .pgfailback    = -FAILBACK_IMMEDIATE,
333                 .rr_weight     = RR_WEIGHT_NONE,
334                 .no_path_retry = 300,
335                 .minio         = DEFAULT_MINIO,
336                 .checker_name  = RDAC,
337                 .prio_name     = PRIO_RDAC,
338         },
339         {
340                 /* IBM DS4400 / FAStT700 */
341                 .vendor        = "IBM",
342                 .product       = "1742",
343                 .getuid        = DEFAULT_GETUID,
344                 .features      = DEFAULT_FEATURES,
345                 .hwhandler     = "1 rdac",
346                 .selector      = DEFAULT_SELECTOR,
347                 .pgpolicy      = GROUP_BY_PRIO,
348                 .pgfailback    = -FAILBACK_IMMEDIATE,
349                 .rr_weight     = RR_WEIGHT_NONE,
350                 .no_path_retry = NO_PATH_RETRY_QUEUE,
351                 .minio         = DEFAULT_MINIO,
352                 .checker_name  = RDAC,
353                 .prio_name     = PRIO_RDAC,
354         },
355         {
356             /* IBM DS4700 */
357                 .vendor        = "IBM",
358                 .product       = "1814",
359                 .getuid        = DEFAULT_GETUID,
360                 .features      = DEFAULT_FEATURES,
361                 .hwhandler     = "1 rdac",
362                 .selector      = DEFAULT_SELECTOR,
363                 .pgpolicy      = GROUP_BY_PRIO,
364                 .pgfailback    = -FAILBACK_IMMEDIATE,
365                 .rr_weight     = RR_WEIGHT_NONE,
366                 .no_path_retry = NO_PATH_RETRY_QUEUE,
367                 .minio         = DEFAULT_MINIO,
368                 .checker_name  = RDAC,
369                 .prio_name     = PRIO_RDAC,
370         },
371         {
372             /* IBM DS4800 */
373                 .vendor        = "IBM",
374                 .product       = "1815",
375                 .getuid        = DEFAULT_GETUID,
376                 .features      = DEFAULT_FEATURES,
377                 .hwhandler     = "1 rdac",
378                 .selector      = DEFAULT_SELECTOR,
379                 .pgpolicy      = GROUP_BY_PRIO,
380                 .pgfailback    = -FAILBACK_IMMEDIATE,
381                 .rr_weight     = RR_WEIGHT_NONE,
382                 .no_path_retry = NO_PATH_RETRY_QUEUE,
383                 .minio         = DEFAULT_MINIO,
384                 .checker_name  = RDAC,
385                 .prio_name     = PRIO_RDAC,
386         },
387         {
388                 /* IBM Netfinity Fibre Channel RAID Controller Unit */
389                 .vendor        = "IBM",
390                 .product       = "3526",
391                 .getuid        = DEFAULT_GETUID,
392                 .features      = DEFAULT_FEATURES,
393                 .hwhandler     = "1 rdac",
394                 .selector      = DEFAULT_SELECTOR,
395                 .pgpolicy      = GROUP_BY_PRIO,
396                 .pgfailback    = -FAILBACK_IMMEDIATE,
397                 .rr_weight     = RR_WEIGHT_NONE,
398                 .no_path_retry = NO_PATH_RETRY_QUEUE,
399                 .minio         = DEFAULT_MINIO,
400                 .checker_name  = RDAC,
401                 .prio_name     = PRIO_RDAC,
402         },
403         {
404                 /* IBM DS4200 / FAStT200 */
405                 .vendor        = "IBM",
406                 .product       = "3542",
407                 .getuid        = DEFAULT_GETUID,
408                 .features      = DEFAULT_FEATURES,
409                 .hwhandler     = DEFAULT_HWHANDLER,
410                 .selector      = DEFAULT_SELECTOR,
411                 .pgpolicy      = GROUP_BY_SERIAL,
412                 .pgfailback    = FAILBACK_UNDEF,
413                 .rr_weight     = RR_WEIGHT_NONE,
414                 .no_path_retry = NO_PATH_RETRY_UNDEF,
415                 .minio         = DEFAULT_MINIO,
416                 .checker_name  = TUR,
417                 .prio_name     = DEFAULT_PRIO,
418         },
419         {
420                 /* IBM ESS F20 aka Shark */
421                 .vendor        = "IBM",
422                 .product       = "2105(800|F20)",
423                 .getuid        = DEFAULT_GETUID,
424                 .features      = "1 queue_if_no_path",
425                 .hwhandler     = DEFAULT_HWHANDLER,
426                 .selector      = DEFAULT_SELECTOR,
427                 .pgpolicy      = GROUP_BY_SERIAL,
428                 .pgfailback    = FAILBACK_UNDEF,
429                 .rr_weight     = RR_WEIGHT_NONE,
430                 .no_path_retry = NO_PATH_RETRY_UNDEF,
431                 .minio         = DEFAULT_MINIO,
432                 .checker_name  = TUR,
433                 .prio_name     = DEFAULT_PRIO,
434         },
435         {
436                 /* IBM DS6000 */
437                 .vendor        = "IBM",
438                 .product       = "1750500",
439                 .getuid        = DEFAULT_GETUID,
440                 .features      = "1 queue_if_no_path",
441                 .hwhandler     = DEFAULT_HWHANDLER,
442                 .selector      = DEFAULT_SELECTOR,
443                 .pgpolicy      = GROUP_BY_PRIO,
444                 .pgfailback    = -FAILBACK_IMMEDIATE,
445                 .rr_weight     = RR_WEIGHT_NONE,
446                 .no_path_retry = NO_PATH_RETRY_UNDEF,
447                 .minio         = DEFAULT_MINIO,
448                 .checker_name  = TUR,
449                 .prio_name     = PRIO_ALUA,
450         },
451         {
452                 /* IBM DS8000 */
453                 .vendor        = "IBM",
454                 .product       = "2107900",
455                 .getuid        = DEFAULT_GETUID,
456                 .features      = "1 queue_if_no_path",
457                 .hwhandler     = DEFAULT_HWHANDLER,
458                 .selector      = DEFAULT_SELECTOR,
459                 .pgpolicy      = MULTIBUS,
460                 .pgfailback    = FAILBACK_UNDEF,
461                 .rr_weight     = RR_WEIGHT_NONE,
462                 .no_path_retry = NO_PATH_RETRY_UNDEF,
463                 .minio         = DEFAULT_MINIO,
464                 .checker_name  = TUR,
465                 .prio_name     = DEFAULT_PRIO,
466         },
467         {
468                 /* IBM SAN Volume Controller */
469                 .vendor        = "IBM",
470                 .product       = "2145",
471                 .getuid        = DEFAULT_GETUID,
472                 .features      = "1 queue_if_no_path",
473                 .hwhandler     = DEFAULT_HWHANDLER,
474                 .selector      = DEFAULT_SELECTOR,
475                 .pgpolicy      = GROUP_BY_PRIO,
476                 .pgfailback    = -FAILBACK_IMMEDIATE,
477                 .rr_weight     = RR_WEIGHT_NONE,
478                 .no_path_retry = NO_PATH_RETRY_UNDEF,
479                 .minio         = DEFAULT_MINIO,
480                 .checker_name  = TUR,
481                 .prio_name     = PRIO_ALUA,
482         },
483         {
484                 /* IBM S/390 ECKD DASD */
485                 .vendor        = "IBM",
486                 .product       = "S/390 DASD ECKD",
487                 .bl_product       = "S/390.*",
488                 .getuid        = "/sbin/dasdinfo -u -b %n",
489                 .features      = "1 queue_if_no_path",
490                 .hwhandler     = DEFAULT_HWHANDLER,
491                 .selector      = DEFAULT_SELECTOR,
492                 .pgpolicy      = MULTIBUS,
493                 .pgfailback    = FAILBACK_UNDEF,
494                 .rr_weight     = RR_WEIGHT_NONE,
495                 .no_path_retry = NO_PATH_RETRY_UNDEF,
496                 .minio         = DEFAULT_MINIO,
497                 .checker_name  = DIRECTIO,
498                 .prio_name     = DEFAULT_PRIO,
499         },
500         /*
501          * NETAPP controller family
502          *
503          * Maintainer : Dave Wysochanski
504          * Mail : davidw@netapp.com
505          */
506         {
507                 .vendor        = "NETAPP",
508                 .product       = "LUN.*",
509                 .getuid        = DEFAULT_GETUID,
510                 .features      = "1 queue_if_no_path",
511                 .hwhandler     = DEFAULT_HWHANDLER,
512                 .selector      = DEFAULT_SELECTOR,
513                 .pgpolicy      = GROUP_BY_PRIO,
514                 .pgfailback    = -FAILBACK_IMMEDIATE,
515                 .rr_weight     = RR_WEIGHT_NONE,
516                 .no_path_retry = NO_PATH_RETRY_UNDEF,
517                 .minio         = 128,
518                 .checker_name  = DIRECTIO,
519                 .prio_name     = PRIO_NETAPP,
520         },
521         /*
522          * IBM NSeries (NETAPP) controller family
523          *
524          * Maintainer : Dave Wysochanski
525          * Mail : davidw@netapp.com
526          */
527         {
528                 .vendor        = "IBM",
529                 .product       = "Nseries.*",
530                 .getuid        = DEFAULT_GETUID,
531                 .features      = "1 queue_if_no_path",
532                 .hwhandler     = DEFAULT_HWHANDLER,
533                 .selector      = DEFAULT_SELECTOR,
534                 .pgpolicy      = GROUP_BY_PRIO,
535                 .pgfailback    = -FAILBACK_IMMEDIATE,
536                 .rr_weight     = RR_WEIGHT_NONE,
537                 .no_path_retry = NO_PATH_RETRY_UNDEF,
538                 .minio         = 128,
539                 .checker_name  = DIRECTIO,
540                 .prio_name     = PRIO_NETAPP,
541         },
542         /*
543          * Pillar Data controller family
544          *
545          * Maintainer : Srinivasan Ramani
546          * Mail : sramani@pillardata.com
547          */
548         {
549                 .vendor        = "Pillar",
550                 .product       = "Axiom.*",
551                 .getuid        = DEFAULT_GETUID,
552                 .features      = DEFAULT_FEATURES,
553                 .hwhandler     = DEFAULT_HWHANDLER,
554                 .selector      = DEFAULT_SELECTOR,
555                 .pgpolicy      = GROUP_BY_PRIO,
556                 .pgfailback    = FAILBACK_UNDEF,
557                 .rr_weight     = RR_WEIGHT_NONE,
558                 .no_path_retry = NO_PATH_RETRY_UNDEF,
559                 .minio         = DEFAULT_MINIO,
560                 .checker_name  = TUR,
561                 .prio_name     = PRIO_ALUA,
562         },
563         /*
564          * SGI arrays
565          *
566          * Maintainer : Christophe Varoqui
567          * Mail : christophe.varoqui@free.fr
568          */
569         {
570                 .vendor        = "SGI",
571                 .product       = "TP9[13]00",
572                 .getuid        = DEFAULT_GETUID,
573                 .features      = DEFAULT_FEATURES,
574                 .hwhandler     = DEFAULT_HWHANDLER,
575                 .selector      = DEFAULT_SELECTOR,
576                 .pgpolicy      = MULTIBUS,
577                 .pgfailback    = FAILBACK_UNDEF,
578                 .rr_weight     = RR_WEIGHT_NONE,
579                 .no_path_retry = NO_PATH_RETRY_UNDEF,
580                 .minio         = DEFAULT_MINIO,
581                 .checker_name  = DIRECTIO,
582                 .prio_name     = DEFAULT_PRIO,
583         },
584         {
585                 .vendor        = "SGI",
586                 .product       = "TP9[45]00",
587                 .getuid        = DEFAULT_GETUID,
588                 .features      = DEFAULT_FEATURES,
589                 .hwhandler     = "1 rdac",
590                 .selector      = DEFAULT_SELECTOR,
591                 .pgpolicy      = GROUP_BY_PRIO,
592                 .pgfailback    = -FAILBACK_IMMEDIATE,
593                 .rr_weight     = RR_WEIGHT_NONE,
594                 .no_path_retry = NO_PATH_RETRY_QUEUE,
595                 .minio         = DEFAULT_MINIO,
596                 .checker_name  = RDAC,
597                 .prio_name     = PRIO_RDAC,
598         },
599         {
600                 .vendor        = "SGI",
601                 .product       = "IS.*",
602                 .getuid        = DEFAULT_GETUID,
603                 .features      = DEFAULT_FEATURES,
604                 .hwhandler     = "1 rdac",
605                 .selector      = DEFAULT_SELECTOR,
606                 .pgpolicy      = GROUP_BY_PRIO,
607                 .pgfailback    = -FAILBACK_IMMEDIATE,
608                 .rr_weight     = RR_WEIGHT_NONE,
609                 .no_path_retry = NO_PATH_RETRY_QUEUE,
610                 .minio         = DEFAULT_MINIO,
611                 .checker_name  = RDAC,
612                 .prio_name     = PRIO_RDAC,
613         },
614         /*
615          * STK arrays
616          *
617          * Maintainer : Christophe Varoqui
618          * Mail : christophe.varoqui@free.fr
619          */
620         {
621                 .vendor        = "STK",
622                 .product       = "OPENstorage D280",
623                 .getuid        = DEFAULT_GETUID,
624                 .features      = DEFAULT_FEATURES,
625                 .hwhandler     = "1 rdac",
626                 .selector      = DEFAULT_SELECTOR,
627                 .pgpolicy      = GROUP_BY_PRIO,
628                 .pgfailback    = -FAILBACK_IMMEDIATE,
629                 .rr_weight     = RR_WEIGHT_NONE,
630                 .no_path_retry = NO_PATH_RETRY_UNDEF,
631                 .minio         = DEFAULT_MINIO,
632                 .checker_name  = TUR,
633                 .prio_name     = PRIO_RDAC,
634         },
635         /*
636          * SUN arrays
637          *
638          * Maintainer : Christophe Varoqui
639          * Mail : christophe.varoqui@free.fr
640          */
641         {
642                 .vendor        = "SUN",
643                 .product       = "(StorEdge 3510|T4)",
644                 .getuid        = DEFAULT_GETUID,
645                 .features      = DEFAULT_FEATURES,
646                 .hwhandler     = DEFAULT_HWHANDLER,
647                 .selector      = DEFAULT_SELECTOR,
648                 .pgpolicy      = MULTIBUS,
649                 .pgfailback    = FAILBACK_UNDEF,
650                 .rr_weight     = RR_WEIGHT_NONE,
651                 .no_path_retry = NO_PATH_RETRY_UNDEF,
652                 .minio         = DEFAULT_MINIO,
653                 .checker_name  = DIRECTIO,
654                 .prio_name     = DEFAULT_PRIO,
655         },
656         /*
657          * Pivot3 RAIGE
658          *
659          * Maintainer : Bart Brooks, Pivot3
660          * Mail : bartb@pivot3.com
661          */
662         {
663                 .vendor        = "PIVOT3",
664                 .product       = "RAIGE VOLUME",
665                 .getuid        = "/sbin/scsi_id -p 0x80 -g -u -s /block/%n",
666                 .features      = "1 queue_if_no_path",
667                 .hwhandler     = DEFAULT_HWHANDLER,
668                 .selector      = DEFAULT_SELECTOR,
669                 .pgpolicy      = MULTIBUS,
670                 .pgfailback    = FAILBACK_UNDEF,
671                 .rr_weight     = RR_WEIGHT_NONE,
672                 .no_path_retry = NO_PATH_RETRY_UNDEF,
673                 .minio         = 100,
674                 .checker_name  = TUR,
675                 .prio_name     = DEFAULT_PRIO,
676         },
677         {
678                 .vendor        = "SUN",
679                 .product       = "CSM200_R",
680                 .getuid        = DEFAULT_GETUID,
681                 .features      = DEFAULT_FEATURES,
682                 .hwhandler     = "1 rdac",
683                 .selector      = DEFAULT_SELECTOR,
684                 .pgpolicy      = GROUP_BY_PRIO,
685                 .pgfailback    = -FAILBACK_IMMEDIATE,
686                 .rr_weight     = RR_WEIGHT_NONE,
687                 .no_path_retry = NO_PATH_RETRY_QUEUE,
688                 .minio         = DEFAULT_MINIO,
689                 .checker_name  = RDAC,
690                 .prio_name     = PRIO_RDAC,
691         },
692         /* SUN/LSI 2540 */
693         {
694                 .vendor        = "SUN",
695                 .product       = "LCSM100_F",
696                 .getuid        = DEFAULT_GETUID,
697                 .features      = DEFAULT_FEATURES,
698                 .hwhandler     = "1 rdac",
699                 .selector      = DEFAULT_SELECTOR,
700                 .pgpolicy      = GROUP_BY_PRIO,
701                 .pgfailback    = -FAILBACK_IMMEDIATE,
702                 .rr_weight     = RR_WEIGHT_NONE,
703                 .no_path_retry = NO_PATH_RETRY_QUEUE,
704                 .minio         = DEFAULT_MINIO,
705                 .checker_name  = RDAC,
706                 .prio_name     = PRIO_RDAC,
707         },
708         /*
709          * EOL
710          */
711         {
712                 .vendor        = NULL,
713                 .product       = NULL,
714                 .getuid        = NULL,
715                 .features      = NULL,
716                 .hwhandler     = NULL,
717                 .selector      = NULL,
718                 .pgpolicy      = 0,
719                 .pgfailback    = 0,
720                 .rr_weight     = 0,
721                 .no_path_retry = 0,
722                 .minio         = 0,
723                 .checker_name  = NULL,
724                 .prio_name     = NULL,
725         },
726 };
727
728 extern int
729 setup_default_hwtable (vector hw)
730 {
731         int r = 0;
732         struct hwentry * hwe = default_hw;
733
734         while (hwe->vendor) {
735                 hwe->checker = checker_lookup(hwe->checker_name);
736                 hwe->prio = prio_lookup(hwe->prio_name);
737                 r += store_hwe(hw, hwe);
738                 hwe++;
739         }
740         return r;
741 }