svn commit: r285809 - in stable/10/sys: amd64/conf conf dev/pms dev/pms/RefTisa/discovery/api dev/pms/RefTisa/discovery/dm dev/pms/RefTisa/sallsdk/api dev/pms/RefTisa/sallsdk/hda/64k dev/pms/RefTis...

Scott Long scottl at FreeBSD.org
Thu Jul 23 05:26:13 UTC 2015


Author: scottl
Date: Thu Jul 23 05:26:09 2015
New Revision: 285809
URL: https://svnweb.freebsd.org/changeset/base/285809

Log:
  Merge driver for PMC Sierra's range of SAS/SATA HBAs.
  
  Submitted by:   Achim Leubner <Achim.Leubner at pmcs.com>
  Approved by: re

Added:
  stable/10/sys/dev/pms/RefTisa/discovery/api/dm.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/discovery/api/dmapi.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/discovery/api/tddmapi.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/discovery/dm/dmdefs.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/discovery/dm/dmdisc.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/discovery/dm/dminit.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/discovery/dm/dmlist.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/discovery/dm/dmmisc.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/discovery/dm/dmport.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/discovery/dm/dmproto.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/discovery/dm/dmsmp.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/discovery/dm/dmtimer.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/discovery/dm/dmtypes.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/api/sa.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/api/sa_err.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/api/sa_spec.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/api/saapi.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/api/saosapi.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/hda/64k/aap18008.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/hda/64k/aap1img.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/hda/64k/ila8008.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/hda/64k/ila8070.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/hda/64k/ilaimg.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/hda/64k/iop8008.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/hda/64k/iop8070.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/hda/64k/iopimg.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/hda/64k/istrimg.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/hda/64k/raae8070.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/mpi.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/mpi.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/mpidebug.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/mpidebug.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/sadefs.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/sadisc.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/saframe.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/saglobal.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/sahw.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/sahwreg.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/sainit.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/saint.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/saioctlcmd.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/sallist.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/samacro.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/sampicmd.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/sampidefs.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/sampirsp.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/saphy.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/saport.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/saproto.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/sasata.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/sasmp.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/sassp.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/satimer.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/satypes.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/sautil.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/spcdefs.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sat/api/sm.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sat/api/smapi.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sat/api/tdsmapi.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sat/src/smdefs.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sat/src/sminit.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sat/src/smlist.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sat/src/smmisc.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sat/src/smproto.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sat/src/smsat.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sat/src/smsatcb.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sat/src/smsathw.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sat/src/smtimer.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/sat/src/smtypes.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/api/ostiapi.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/api/tiapi.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/api/tidefs.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/api/tiglobal.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/api/tiscsi.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/api/titypes.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/common/ossa.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/common/ossacmnapi.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/common/tddefs.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/common/tddmcmnapi.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/common/tdesgl.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/common/tdhw.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/common/tdinit.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/common/tdint.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/common/tdioctl.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/common/tdioctl.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/common/tdlist.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/common/tdmisc.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/common/tdport.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/common/tdproto.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/common/tdsatypes.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/common/tdsmcmnapi.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/common/tdtimers.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/common/tdutil.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/common/wcs.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/common/tdtypes.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/ini/itdcb.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/ini/itddefs.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/ini/itddisc.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/ini/itdglobl.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/ini/itdinit.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/ini/itdio.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/ini/itdtypes.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/tgt/ttdcb.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/tgt/ttdglobl.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/tgt/ttdinit.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/tgt/ttdio.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/tgt/ttdreset.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/tgt/ttdsmp.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/tgt/ttdtimer.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/tgt/ttdtxchg.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/tgt/ttdtypes.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sata/host/ossasat.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sata/host/sat.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sata/host/sat.h   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sata/host/sathw.c   (contents, props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sata/host/satproto.h   (contents, props changed)
  stable/10/sys/dev/pms/config.h   (contents, props changed)
  stable/10/sys/dev/pms/freebsd/driver/common/encrypt_ioctl.h   (contents, props changed)
  stable/10/sys/dev/pms/freebsd/driver/common/lxcommon.h   (contents, props changed)
  stable/10/sys/dev/pms/freebsd/driver/common/lxencrypt.c   (contents, props changed)
  stable/10/sys/dev/pms/freebsd/driver/common/lxencrypt.h   (contents, props changed)
  stable/10/sys/dev/pms/freebsd/driver/common/lxosapi.c   (contents, props changed)
  stable/10/sys/dev/pms/freebsd/driver/common/lxproto.h   (contents, props changed)
  stable/10/sys/dev/pms/freebsd/driver/common/lxutil.c   (contents, props changed)
  stable/10/sys/dev/pms/freebsd/driver/common/osdebug.h   (contents, props changed)
  stable/10/sys/dev/pms/freebsd/driver/common/osenv.h   (contents, props changed)
  stable/10/sys/dev/pms/freebsd/driver/common/osstring.h   (contents, props changed)
  stable/10/sys/dev/pms/freebsd/driver/common/ostypes.h   (contents, props changed)
  stable/10/sys/dev/pms/freebsd/driver/ini/src/Readme.freebsd.txt   (contents, props changed)
  stable/10/sys/dev/pms/freebsd/driver/ini/src/agdef.h   (contents, props changed)
  stable/10/sys/dev/pms/freebsd/driver/ini/src/agtiapi.c   (contents, props changed)
  stable/10/sys/dev/pms/freebsd/driver/ini/src/agtiapi.h   (contents, props changed)
  stable/10/sys/dev/pms/freebsd/driver/ini/src/agtiproto.h   (contents, props changed)
  stable/10/sys/dev/pms/freebsd/driver/ini/src/osapi.c   (contents, props changed)
  stable/10/sys/modules/pms/
  stable/10/sys/modules/pms/Makefile   (contents, props changed)
  stable/10/sys/modules/pms/Makefile.inc   (contents, props changed)
Directory Properties:
  stable/10/sys/dev/pms/   (props changed)
  stable/10/sys/dev/pms/RefTisa/   (props changed)
  stable/10/sys/dev/pms/RefTisa/discovery/   (props changed)
  stable/10/sys/dev/pms/RefTisa/discovery/api/   (props changed)
  stable/10/sys/dev/pms/RefTisa/discovery/dm/   (props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/   (props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/api/   (props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/hda/   (props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/hda/64k/   (props changed)
  stable/10/sys/dev/pms/RefTisa/sallsdk/spc/   (props changed)
  stable/10/sys/dev/pms/RefTisa/sat/   (props changed)
  stable/10/sys/dev/pms/RefTisa/sat/api/   (props changed)
  stable/10/sys/dev/pms/RefTisa/sat/src/   (props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/   (props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/api/   (props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/   (props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/common/   (props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/   (props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/common/   (props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/ini/   (props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sas/tgt/   (props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sata/   (props changed)
  stable/10/sys/dev/pms/RefTisa/tisa/sassata/sata/host/   (props changed)
  stable/10/sys/dev/pms/freebsd/   (props changed)
  stable/10/sys/dev/pms/freebsd/driver/   (props changed)
  stable/10/sys/dev/pms/freebsd/driver/common/   (props changed)
  stable/10/sys/dev/pms/freebsd/driver/ini/   (props changed)
  stable/10/sys/dev/pms/freebsd/driver/ini/src/   (props changed)
Modified:
  stable/10/sys/amd64/conf/GENERIC
  stable/10/sys/amd64/conf/NOTES
  stable/10/sys/conf/files
  stable/10/sys/i386/conf/GENERIC
  stable/10/sys/i386/conf/NOTES
  stable/10/sys/modules/Makefile

Modified: stable/10/sys/amd64/conf/GENERIC
==============================================================================
--- stable/10/sys/amd64/conf/GENERIC	Thu Jul 23 02:20:41 2015	(r285808)
+++ stable/10/sys/amd64/conf/GENERIC	Thu Jul 23 05:26:09 2015	(r285809)
@@ -160,6 +160,7 @@ device		ida			# Compaq Smart RAID
 device		mfi			# LSI MegaRAID SAS
 device		mlx			# Mylex DAC960 family
 device		mrsas			# LSI/Avago MegaRAID SAS/SATA, 6Gb/s and 12Gb/s
+device		pmspcv			# PMC-Sierra SAS/SATA Controller driver
 #XXX pointer/int warnings
 #device		pst			# Promise Supertrak SX6000
 device		twe			# 3ware ATA RAID

Modified: stable/10/sys/amd64/conf/NOTES
==============================================================================
--- stable/10/sys/amd64/conf/NOTES	Thu Jul 23 02:20:41 2015	(r285808)
+++ stable/10/sys/amd64/conf/NOTES	Thu Jul 23 05:26:09 2015	(r285809)
@@ -454,6 +454,10 @@ device         nvme    # base NVMe drive
 device         nvd     # expose NVMe namespaces as disks, depends on nvme
 
 #
+# PMC-Sierra SAS/SATA controller
+device		pmspcv
+
+#
 # SafeNet crypto driver: can be moved to the MI NOTES as soon as
 # it's tested on a big-endian machine
 #

Modified: stable/10/sys/conf/files
==============================================================================
--- stable/10/sys/conf/files	Thu Jul 23 02:20:41 2015	(r285808)
+++ stable/10/sys/conf/files	Thu Jul 23 05:26:09 2015	(r285809)
@@ -2015,6 +2015,102 @@ dev/pdq/if_fea.c		optional fea eisa
 dev/pdq/if_fpa.c		optional fpa pci
 dev/pdq/pdq.c			optional nowerror fea eisa | fpa pci
 dev/pdq/pdq_ifsubr.c		optional nowerror fea eisa | fpa pci
+dev/pms/freebsd/driver/ini/src/agtiapi.c		optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sallsdk/spc/sadisc.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sallsdk/spc/mpi.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sallsdk/spc/saframe.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sallsdk/spc/sahw.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sallsdk/spc/sainit.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sallsdk/spc/saint.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sallsdk/spc/sampicmd.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sallsdk/spc/sampirsp.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sallsdk/spc/saphy.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sallsdk/spc/saport.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sallsdk/spc/sasata.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sallsdk/spc/sasmp.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sallsdk/spc/sassp.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sallsdk/spc/satimer.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sallsdk/spc/sautil.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sallsdk/spc/saioctlcmd.c		optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sallsdk/spc/mpidebug.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/discovery/dm/dminit.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/discovery/dm/dmsmp.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/discovery/dm/dmdisc.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/discovery/dm/dmport.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/discovery/dm/dmtimer.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/discovery/dm/dmmisc.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sat/src/sminit.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sat/src/smmisc.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sat/src/smsat.c				optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sat/src/smsatcb.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sat/src/smsathw.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/sat/src/smtimer.c			optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/tisa/sassata/common/tdinit.c		optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/tisa/sassata/common/tdmisc.c		optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/tisa/sassata/common/tdesgl.c		optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/tisa/sassata/common/tdport.c		optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/tisa/sassata/common/tdint.c		optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/tisa/sassata/common/tdioctl.c		optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/tisa/sassata/common/tdhw.c		optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/tisa/sassata/common/ossacmnapi.c	optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/tisa/sassata/common/tddmcmnapi.c	optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/tisa/sassata/common/tdsmcmnapi.c	optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/tisa/sassata/common/tdtimers.c		optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/tisa/sassata/sas/ini/itdio.c		optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/tisa/sassata/sas/ini/itdcb.c		optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/tisa/sassata/sas/ini/itdinit.c		optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/tisa/sassata/sas/ini/itddisc.c		optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/tisa/sassata/sata/host/sat.c		optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/tisa/sassata/sata/host/ossasat.c	optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
+dev/pms/RefTisa/tisa/sassata/sata/host/sathw.c		optional pmspcv \
+	compile-with "${NORMAL_C} -Wunused-variable -Woverflow -Wparentheses -w"
 dev/ppbus/if_plip.c		optional plip
 dev/ppbus/immio.c		optional vpo
 dev/ppbus/lpbb.c		optional lpbb

Added: stable/10/sys/dev/pms/RefTisa/discovery/api/dm.h
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ stable/10/sys/dev/pms/RefTisa/discovery/api/dm.h	Thu Jul 23 05:26:09 2015	(r285809)
@@ -0,0 +1,163 @@
+/*******************************************************************************
+**
+*Copyright (c) 2014 PMC-Sierra, Inc.  All rights reserved. 
+*
+*Redistribution and use in source and binary forms, with or without modification, are permitted provided 
+*that the following conditions are met: 
+*1. Redistributions of source code must retain the above copyright notice, this list of conditions and the
+*following disclaimer. 
+*2. Redistributions in binary form must reproduce the above copyright notice, 
+*this list of conditions and the following disclaimer in the documentation and/or other materials provided
+*with the distribution. 
+*
+*THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED 
+*WARRANTIES,INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
+*FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
+*FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 
+*NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR 
+*BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 
+*LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 
+*SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE
+*
+* $FreeBSD$
+*
+********************************************************************************/
+/********************************************************************************
+**    
+*   dm.h 
+*
+*   Abstract:   This module defines the contants, enum and #define definition used
+*               by Discovery Moduled (DM).
+*     
+********************************************************************************/
+
+#ifndef DM_H
+
+#define DM_H
+
+/*************************************************
+ *   constants for type field in agsaMem_t
+ *************************************************/
+#define DM_CACHED_MEM                             0x00     /**< CACHED memory type */
+#define DM_DMA_MEM                                0x01     /**< DMA memory type */
+#define DM_CACHED_DMA_MEM                         0x02     /**< CACHED DMA memory type */
+
+/*************************************************
+ *   constants for API return values
+ *************************************************/
+#define DM_RC_SUCCESS                             0x00     /**< Successful function return value */
+#define DM_RC_FAILURE                             0x01     /**< Failed function return value */
+#define DM_RC_BUSY                                0x02     /**< Busy function return value */
+#define DM_RC_VERSION_INCOMPATIBLE                0x03     /**< Version miss match */
+#define DM_RC_VERSION_UNTESTED                    0x04     /**< Version not tested */
+
+
+
+/*************************************************
+ *   Discovery option
+ *************************************************/
+#define DM_DISCOVERY_OPTION_FULL_START			0x00     /**< Full discovery */
+#define DM_DISCOVERY_OPTION_INCREMENTAL_START		0x01     /**< Incremental discovery */
+#define DM_DISCOVERY_OPTION_ABORT			0x02     /**< Discovery abort */
+
+
+/*************************************************
+ *   Discovery status
+ *************************************************/
+enum dmDiscoveryState_e
+{
+  dmDiscCompleted  = 0,
+  dmDiscFailed,
+  dmDiscAborted,
+  dmDiscAbortFailed,
+  dmDiscInProgress,
+  dmDiscAbortInvalid, /* no discovery to abort */   
+  dmDiscAbortInProgress, /* abort in progress */   
+
+};
+
+/*************************************************
+ *   Device status
+ *************************************************/
+enum dmDeviceState_e
+{
+  dmDeviceNoChange = 0,
+  dmDeviceArrival,
+  dmDeviceRemoval,
+  dmDeviceMCNChange,
+  dmDeviceRateChange,
+};
+
+typedef struct  dmContext_s {
+		void		*tdData;
+		void		*dmData;
+} dmContext_t;
+
+typedef struct{
+        bit16	smpTimeout;
+        bit16	it_NexusTimeout;
+        bit16	firstBurstSize;
+        bit8	 flag;
+        bit8	 devType_S_Rate;
+        bit8 	sasAddressHi[4]; 
+        bit8 	sasAddressLo[4];
+        bit8    initiator_ssp_stp_smp;
+        bit8    target_ssp_stp_smp;
+        /* bit8 - bit14 are set by the user of DM such as TDM for directly attached expander
+           0 - 7; PhyID 
+           8: non SMP or not
+           9 - 10: types of expander, valid only when bit8 is set
+                   10b (2): edge expander
+                   11b (3): fanout expander
+           11 - 14: MCN
+        */
+        bit16   ext;
+        bit8    sataDeviceType;
+        bit8    reserved;
+} dmDeviceInfo_t;
+
+
+typedef struct{
+	void 	*virtPtr;
+	void 	*osHandle;
+	bit32 	physAddrUpper;
+	bit32 	physAddrLower;
+	bit32 	totalLength;
+	bit32 	numElements;
+	bit32 	singleElementLength;
+	bit32 	alignment;
+	bit32 	type;
+	bit32 	reserved;
+} dmMem_t;
+
+#define DM_NUM_MEM_CHUNKS 8
+
+typedef struct{
+	bit32 		count;
+	dmMem_t 	dmMemory[DM_NUM_MEM_CHUNKS];
+} dmMemoryRequirement_t;
+
+typedef    dmContext_t    dmPortContext_t;
+
+typedef    dmContext_t    dmRoot_t;
+
+typedef struct{
+ bit32   numDevHandles;
+ bit32   tbd1;
+ bit32   tbd2;
+#ifdef DM_DEBUG
+ bit32   DMDebugLevel;
+#endif
+ bit32   itNexusTimeout;
+} dmSwConfig_t;
+
+typedef struct{
+               bit8  	sasRemoteAddressHi[4]; 
+               bit8  	sasRemoteAddressLo[4]; 
+               bit8  	sasLocalAddressHi[4]; 
+               bit8  	sasLocalAddressLo[4]; 
+               bit32    flag;
+} dmPortInfo_t;
+
+
+#endif  /* DM_H */

Added: stable/10/sys/dev/pms/RefTisa/discovery/api/dmapi.h
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ stable/10/sys/dev/pms/RefTisa/discovery/api/dmapi.h	Thu Jul 23 05:26:09 2015	(r285809)
@@ -0,0 +1,89 @@
+/*******************************************************************************
+**
+*Copyright (c) 2014 PMC-Sierra, Inc.  All rights reserved. 
+*
+*Redistribution and use in source and binary forms, with or without modification, are permitted provided 
+*that the following conditions are met: 
+*1. Redistributions of source code must retain the above copyright notice, this list of conditions and the
+*following disclaimer. 
+*2. Redistributions in binary form must reproduce the above copyright notice, 
+*this list of conditions and the following disclaimer in the documentation and/or other materials provided
+*with the distribution. 
+*
+*THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED 
+*WARRANTIES,INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
+*FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
+*FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 
+*NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR 
+*BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 
+*LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 
+*SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE
+**
+* $FreeBSD$
+*
+********************************************************************************/
+/********************************************************************************
+*   dmapi.h 
+*
+*   Abstract:   This module contains function prototype of the Discovery
+*               Module (DM) API for initiator.
+*******************************************************************************/
+
+#ifndef DMAPI_H
+#define DMAPI_H
+
+#include <dev/pms/RefTisa/discovery/api/dm.h>
+#include <dev/pms/RefTisa/sallsdk/api/sa.h>
+
+osGLOBAL bit32  dmCreatePort(  
+       dmRoot_t        *dmRoot,
+       dmPortContext_t *dmPortContext,
+       dmPortInfo_t    *dmPortInfo);
+
+osGLOBAL bit32  dmDestroyPort(  
+       dmRoot_t        *dmRoot,
+       dmPortContext_t *dmPortContext,
+       dmPortInfo_t    *dmPortInfo);
+
+osGLOBAL bit32  dmRegisterDevice(  
+       dmRoot_t        *dmRoot,
+       dmPortContext_t *dmPortContext,
+       dmDeviceInfo_t  *dmDeviceInfo,
+       agsaDevHandle_t *agDevHandle);
+
+osGLOBAL bit32  dmDiscover(  
+       dmRoot_t        *dmRoot,
+       dmPortContext_t *dmPortContext,
+       bit32            option);
+
+osGLOBAL void dmGetRequirements(
+       dmRoot_t              *dmRoot,
+       dmSwConfig_t          *swConfig,
+       dmMemoryRequirement_t *memoryRequirement,
+       bit32                 *usecsPerTick,
+       bit32                 *maxNumLocks);
+
+osGLOBAL void dmNotifyBC(
+       dmRoot_t        *dmRoot,
+       dmPortContext_t *dmPortContext,
+       bit32            type);
+
+osGLOBAL bit32  dmQueryDiscovery(  
+       dmRoot_t        *dmRoot,
+       dmPortContext_t *dmPortContext);
+       
+osGLOBAL bit32 	
+dmResetFailedDiscovery(  
+                 dmRoot_t               *dmRoot,
+                 dmPortContext_t        *dmPortContext);
+
+osGLOBAL bit32  dmInitialize(
+       dmRoot_t             *dmRoot,
+       agsaRoot_t           *agRoot,
+       dmMemoryRequirement_t *memoryAllocated,
+       dmSwConfig_t          *swConfig,
+       bit32                 usecsPerTick );
+
+osGLOBAL void   dmTimerTick ( dmRoot_t  *dmRoot );
+
+#endif  /* DMAPI_H */

Added: stable/10/sys/dev/pms/RefTisa/discovery/api/tddmapi.h
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ stable/10/sys/dev/pms/RefTisa/discovery/api/tddmapi.h	Thu Jul 23 05:26:09 2015	(r285809)
@@ -0,0 +1,119 @@
+/*******************************************************************************
+*Copyright (c) 2014 PMC-Sierra, Inc.  All rights reserved. 
+*
+*Redistribution and use in source and binary forms, with or without modification, are permitted provided 
+*that the following conditions are met: 
+*1. Redistributions of source code must retain the above copyright notice, this list of conditions and the
+*following disclaimer. 
+*2. Redistributions in binary form must reproduce the above copyright notice, 
+*this list of conditions and the following disclaimer in the documentation and/or other materials provided
+*with the distribution. 
+*
+*THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED 
+*WARRANTIES,INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
+*FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
+*FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 
+*NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR 
+*BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 
+*LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 
+*SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE
+*
+* $FreeBSD$
+*
+********************************************************************************/
+/********************************************************************************
+*   tmdmapi.h 
+*
+*   Abstract:   This module contains function prototype of the Discovery
+*               Module (DM) API callback for initiator.
+*******************************************************************************/
+
+#ifndef TDDMAPI_H
+
+#define TDDMAPI_H
+
+osGLOBAL void tddmCacheFlush(
+				dmRoot_t 	*dmRoot,
+				void 		*tdMemHandle,
+				void 		*virtPtr,
+				bit32 		length
+				);
+
+osGLOBAL void tddmCacheInvalidate(
+				dmRoot_t 	*dmRoot,
+				void 		*tdMemHandle,
+				void 		*virtPtr,
+				bit32 		length
+				);
+
+osGLOBAL void tddmCachePreFlush(
+				dmRoot_t 	*dmRoot,
+				void 		*tdMemHandle,
+				void 		*virtPtr,
+				bit32 		length
+				);
+
+osGLOBAL void tddmDiscoverCB(
+				dmRoot_t 		*dmRoot,
+				dmPortContext_t		*dmPortContext,
+				bit32			eventStatus
+				);
+
+osGLOBAL void tddmQueryDiscoveryCB(
+				dmRoot_t 		*dmRoot,
+				dmPortContext_t		*dmPortContext,
+				bit32          		discType,
+				bit32			discState
+				);
+
+osGLOBAL void tddmReportDevice(
+				dmRoot_t 		*dmRoot,
+				dmPortContext_t		*dmPortContext,
+				dmDeviceInfo_t		*dmDeviceInfo,
+                                dmDeviceInfo_t		*dmExpDeviceInfo,
+				bit32                   flag				
+				);
+
+osGLOBAL bit8 tddmSATADeviceTypeDecode(bit8 * pSignature);
+
+osGLOBAL void tddmSingleThreadedEnter(
+				       dmRoot_t 		*dmRoot,
+				       bit32    		syncLockId
+				      );
+				      
+osGLOBAL void tddmSingleThreadedLeave(
+				       dmRoot_t 		*dmRoot,
+				       bit32    		syncLockId
+				      );
+osGLOBAL bit32 tddmGetTransportParam(
+                        dmRoot_t    *dmRoot,
+                        char        *key,
+                        char        *subkey1,
+                        char        *subkey2,
+                        char        *subkey3,
+                        char        *subkey4,
+                        char        *subkey5,
+                        char        *valueName,
+                        char        *buffer,
+                        bit32       bufferLen,
+                        bit32       *lenReceived
+                        );
+osGLOBAL bit32 
+tddmRotateQnumber(
+                  dmRoot_t          *dmRoot,
+                  agsaDevHandle_t   *agDevHandle
+                 );
+#ifndef tddmLogDebugString 
+GLOBAL void tddmLogDebugString(
+                         dmRoot_t     *dmRoot,
+                         bit32        level,
+                         char         *string,
+                         void         *ptr1,
+                         void         *ptr2,
+                         bit32        value1,
+                         bit32        value2
+                         );
+#endif
+
+
+#endif  /* TDDMAPI_H */

Added: stable/10/sys/dev/pms/RefTisa/discovery/dm/dmdefs.h
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ stable/10/sys/dev/pms/RefTisa/discovery/dm/dmdefs.h	Thu Jul 23 05:26:09 2015	(r285809)
@@ -0,0 +1,1229 @@
+/*******************************************************************************
+**
+* Copyright (c) 2014 PMC-Sierra, Inc.  All rights reserved. 
+*
+*Redistribution and use in source and binary forms, with or without modification, are permitted provided 
+*that the following conditions are met: 
+*1. Redistributions of source code must retain the above copyright notice, this list of conditions and the
+*following disclaimer. 
+*2. Redistributions in binary form must reproduce the above copyright notice, 
+*this list of conditions and the following disclaimer in the documentation and/or other materials provided
+*with the distribution. 
+*
+*THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED 
+*WARRANTIES,INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
+*FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
+*FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 
+*NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR 
+*BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 
+*LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 
+*SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE
+**
+* $FreeBSD$
+*
+********************************************************************************/
+#ifndef __DMDEFS_H__
+#define __DMDEFS_H__
+
+#include <dev/pms/RefTisa/tisa/sassata/common/ossa.h>
+
+#define DIRECT_SMP
+//#undef DIRECT_SMP
+
+/* the index for memory requirement, must be continious */
+#define DM_ROOT_MEM_INDEX                          0                       /**< the index of dm root memory */
+#define DM_PORT_MEM_INDEX                          1                       /**< the index of port context memory */
+#define DM_DEVICE_MEM_INDEX                        2                       /**< the index of Device descriptors memory */
+#define DM_EXPANDER_MEM_INDEX                      3                       /**< the index of Expander device descriptors memory */
+#define DM_SMP_MEM_INDEX                           4                       /**< the index of SMP command descriptors memory */
+#define DM_INDIRECT_SMP_MEM_INDEX                  5                       /**< the index of Indirect SMP command descriptors memory */
+
+
+
+#define DM_MAX_NUM_PHYS                         16
+#define DM_MAX_EXPANDER_PHYS                    256
+#define DM_MAX_DEV                              2048
+#define DM_MAX_EXPANDER_DEV                     32
+#define DM_MAX_PORT_CONTEXT                     16
+#define DM_MAX_SMP                              32
+#define DM_MAX_INDIRECT_SMP                     DM_MAX_SMP
+
+#define DM_USECS_PER_TICK                       1000000                   /**< defines the heart beat of the LL layer 10ms */
+
+/*
+*  FIS type 
+*/
+#define PIO_SETUP_DEV_TO_HOST_FIS   0x5F
+#define REG_DEV_TO_HOST_FIS         0x34 
+#define SET_DEV_BITS_FIS            0xA1
+
+#define DEFAULT_KEY_BUFFER_SIZE     64
+ 
+enum dm_locks_e
+{
+  DM_PORT_LOCK = 0,
+  DM_DEVICE_LOCK,
+  DM_EXPANDER_LOCK,
+  DM_TIMER_LOCK,
+  DM_SMP_LOCK,
+  DM_MAX_LOCKS
+};
+/* default SMP timeout: 0xFFFF is the Maximum Allowed */
+#define DEFAULT_SMP_TIMEOUT       0xFFFF
+
+/* SMP direct payload size limit: IOMB direct payload size = 48 */
+#define SMP_DIRECT_PAYLOAD_LIMIT 44
+
+#define SMP_INDIRECT_PAYLOAD	512
+
+/* SMP maximum payload size allowed by SAS spec withtout CRC 4 bytes */
+#define SMP_MAXIMUM_PAYLOAD      1024
+
+/*! \def MIN(a,b)
+* \brief MIN macro
+*
+* use to find MIN of two values
+*/
+#ifndef MIN
+#define MIN(a,b) ((a) < (b) ? (a) : (b))
+#endif
+
+/*! \def MAX(a,b)
+* \brief MAX macro
+*
+* use to find MAX of two values
+*/
+#ifndef MAX
+#define MAX(a,b) ((a) < (b) ? (b) : (a))
+#endif
+
+#ifndef agNULL
+#define agNULL     ((void *)0)
+#endif
+
+/* for debugging print */
+#if defined(DM_DEBUG)
+
+/*
+* for debugging purposes.  
+*/
+extern bit32 gDMDebugLevel;
+
+#define DM_DBG0(format) tddmLogDebugString(gDMDebugLevel, 0, format)
+#define DM_DBG1(format) tddmLogDebugString(gDMDebugLevel, 1, format)
+#define DM_DBG2(format) tddmLogDebugString(gDMDebugLevel, 2, format)
+#define DM_DBG3(format) tddmLogDebugString(gDMDebugLevel, 3, format)
+#define DM_DBG4(format) tddmLogDebugString(gDMDebugLevel, 4, format)
+#define DM_DBG5(format) tddmLogDebugString(gDMDebugLevel, 5, format)
+#define DM_DBG6(format) tddmLogDebugString(gDMDebugLevel, 6, format)
+
+
+#else
+
+#define DM_DBG0(format)
+#define DM_DBG1(format)
+#define DM_DBG2(format)
+#define DM_DBG3(format)
+#define DM_DBG4(format)
+#define DM_DBG5(format)
+#define DM_DBG6(format)
+
+#endif /* DM_DEBUG */
+
+//#define DM_ASSERT OS_ASSERT
+//#define tddmLogDebugString TIDEBUG_MSG
+
+/* discovery related state */
+#define DM_DSTATE_NOT_STARTED                 0 
+#define DM_DSTATE_STARTED                     1
+#define DM_DSTATE_COMPLETED                   2
+#define DM_DSTATE_COMPLETED_WITH_FAILURE      3
+
+/* SAS/SATA discovery status */
+#define DISCOVERY_NOT_START                       0                       /**< status indicates discovery not started */
+#define DISCOVERY_UP_STREAM                       1                       /**< status indicates discover upstream */
+#define DISCOVERY_DOWN_STREAM                     2                       /**< status indicates discover downstream */
+#define DISCOVERY_CONFIG_ROUTING                  3                       /**< status indicates discovery config routing table */
+#define DISCOVERY_SAS_DONE                        4                       /**< status indicates discovery done */
+#define DISCOVERY_REPORT_PHY_SATA                 5                       /**< status indicates discovery report phy sata */
+
+/* SMP function */
+#define SMP_REPORT_GENERAL                         0x00
+#define SMP_REPORT_MANUFACTURE_INFORMATION         0x01
+#define SMP_READ_GPIO_REGISTER                     0x02
+#define SMP_DISCOVER                               0x10
+#define SMP_REPORT_PHY_ERROR_LOG                   0x11
+#define SMP_REPORT_PHY_SATA                        0x12
+#define SMP_REPORT_ROUTING_INFORMATION             0x13
+#define SMP_WRITE_GPIO_REGISTER                    0x82
+#define SMP_CONFIGURE_ROUTING_INFORMATION          0x90
+#define SMP_PHY_CONTROL                            0x91
+#define SMP_PHY_TEST_FUNCTION                      0x92
+#define SMP_PMC_SPECIFIC                           0xC0
+#define SMP_DISCOVER_LIST                          0x20
+
+
+/* SMP function results */
+#define SMP_FUNCTION_ACCEPTED                      0x00
+#define UNKNOWN_SMP_FUNCTION                       0x01
+#define SMP_FUNCTION_FAILED                        0x02
+#define INVALID_REQUEST_FRAME_LENGTH               0x03
+#define INVALID_EXPANDER_CHANGE_COUNT              0x04
+#define SMP_FN_BUSY                                0x05
+#define INCOMPLETE_DESCRIPTOR_LIST                 0x06
+#define PHY_DOES_NOT_EXIST                         0x10
+#define INDEX_DOES_NOT_EXIST                       0x11
+#define PHY_DOES_NOT_SUPPORT_SATA                  0x12
+#define UNKNOWN_PHY_OPERATION                      0x13
+#define UNKNOWN_PHY_TEST_FUNCTION                  0x14
+#define PHY_TEST_FUNCTION_IN_PROGRESS              0x15
+#define PHY_VACANT                                 0x16
+#define UNKNOWN_PHY_EVENT_SOURCE                   0x17
+#define UNKNOWN_DESCRIPTOT_TYPE                    0x18
+#define UNKNOWN_PHY_FILETER                        0x19
+#define AFFILIATION_VIOLATION                      0x1A
+#define SMP_ZONE_VIOLATION                         0x20
+#define NO_MANAGEMENT_ACCESS_RIGHTS                0x21
+#define UNKNOWN_ENABLE_DISABLE_ZONING_VALUE        0x22
+#define ZONE_LOCK_VIOLATION                        0x23
+#define NOT_ACTIVATED                              0x24
+#define ZONE_GROUP_OUT_OF_RANGE                    0x25
+#define NO_PHYSICAL_PRESENCE                       0x26
+#define SAVING_NOT_SUPPORTED                       0x27
+#define SOURCE_ZONE_GROUP_DOES_NOT_EXIST           0x28
+#define DISABLED_PASSWORD_NOT_SUPPORTED            0x29
+
+/* SMP PHY CONTROL OPERATION */
+#define SMP_PHY_CONTROL_NOP                        0x00
+#define SMP_PHY_CONTROL_LINK_RESET                 0x01
+#define SMP_PHY_CONTROL_HARD_RESET                 0x02
+#define SMP_PHY_CONTROL_DISABLE                    0x03
+#define SMP_PHY_CONTROL_CLEAR_ERROR_LOG            0x05
+#define SMP_PHY_CONTROL_CLEAR_AFFILIATION          0x06
+#define SMP_PHY_CONTROL_XMIT_SATA_PS_SIGNAL        0x07
+
+#define DM_VEN_DEV_SPC                               0x80010000
+#define DM_VEN_DEV_ADAPSPC                           0x80810000
+#define DM_VEN_DEV_SPCv                              0x80080000
+#define DM_VEN_DEV_SPCve                             0x80090000
+#define DM_VEN_DEV_SPCvplus                          0x80180000
+#define DM_VEN_DEV_SPCveplus                         0x80190000
+#define DM_VEN_DEV_ADAPvplus                         0x80880000
+#define DM_VEN_DEV_ADAPveplus                        0x80890000
+
+#define DMIsSPC(agr)           (DM_VEN_DEV_SPC        == (ossaHwRegReadConfig32(agr,0 ) & 0xFFFF0000) ? 1 : 0) /* returns true config space read is SPC */
+#define DMIsSPCADAP(agr)       (DM_VEN_DEV_SPC        == (ossaHwRegReadConfig32(agr,0 ) & 0xFFFF0000) ? 1 : 0) /* returns true config space read is SPC */
+#define DMIsSPCv(agr)          (DM_VEN_DEV_SPCv       == (ossaHwRegReadConfig32(agr,0 ) & 0xFFFF0000) ? 1 : 0) /* returns true config space read is SPCv */
+#define DMIsSPCve(agr)         (DM_VEN_DEV_SPCve      == (ossaHwRegReadConfig32(agr,0 ) & 0xFFFF0000) ? 1 : 0) /* returns true config space read is SPCve */
+#define DMIsSPCvplus(agr)      (DM_VEN_DEV_SPCvplus   == (ossaHwRegReadConfig32(agr,0 ) & 0xFFFF0000) ? 1 : 0) /* returns true config space read is SPCv+ */
+#define DMIsSPCveplus(agr)     (DM_VEN_DEV_SPCveplus  == (ossaHwRegReadConfig32(agr,0 ) & 0xFFFF0000) ? 1 : 0) /* returns true config space read is SPCve+ */
+#define DMIsSPCADAPvplus(agr)  (DM_VEN_DEV_ADAPvplus  == (ossaHwRegReadConfig32(agr,0 ) & 0xFFFF0000) ? 1 : 0) /* returns true config space read is SPCv+ */
+#define DMIsSPCADAPveplus(agr) (DM_VEN_DEV_ADAPveplus == (ossaHwRegReadConfig32(agr,0 ) & 0xFFFF0000) ? 1 : 0) /* returns true config space read is SPCve+ */
+
+/****************************************************************
+ *            SAS 1.1 Spec
+ ****************************************************************/
+/* SMP header definition */
+typedef struct dmSMPFrameHeader_s
+{
+    bit8   smpFrameType;      /* The first byte of SMP frame represents the SMP FRAME TYPE */ 
+    bit8   smpFunction;       /* The second byte of the SMP frame represents the SMP FUNCTION */
+    bit8   smpFunctionResult; /* The third byte of SMP frame represents FUNCTION RESULT of the SMP response. */
+    bit8   smpReserved;       /* reserved */
+} dmSMPFrameHeader_t;
+
+/****************************************************************
+ *            report general request
+ ****************************************************************/
+#ifdef FOR_COMPLETENESS
+typedef struct smpReqReportGeneral_s 
+{
+  /* nothing. some compiler disallowed structure with no member */
+} smpReqReportGeneral_t; 
+#endif
+
+/****************************************************************
+ *            report general response
+ ****************************************************************/
+#define REPORT_GENERAL_CONFIGURING_BIT     0x2
+#define REPORT_GENERAL_CONFIGURABLE_BIT    0x1
+#define REPORT_GENERAL_LONG_RESPONSE_BIT   0x80
+
+typedef struct smpRespReportGeneral_s
+{
+  bit8   expanderChangeCount16[2];
+  bit8   expanderRouteIndexes16[2];
+  bit8   reserved1; /* byte 9; has LONG Response for SAS 2 at bit 8 */
+  bit8   numOfPhys;
+  bit8   configuring_configurable;  
+    /* B7-2 : reserved */
+    /* B1   : configuring */
+    /* B0   : configurable */
+  bit8   reserved4[17];
+} smpRespReportGeneral_t;
+
+#define REPORT_GENERAL_IS_CONFIGURING(pResp) \
+  (((pResp)->configuring_configurable & REPORT_GENERAL_CONFIGURING_BIT) == \
+      REPORT_GENERAL_CONFIGURING_BIT)
+
+#define REPORT_GENERAL_IS_CONFIGURABLE(pResp) \
+  (((pResp)->configuring_configurable & REPORT_GENERAL_CONFIGURABLE_BIT) == \
+      REPORT_GENERAL_CONFIGURABLE_BIT)
+
+#define REPORT_GENERAL_GET_ROUTEINDEXES(pResp) \
+  DMA_BEBIT16_TO_BIT16(*(bit16 *)((pResp)->expanderRouteIndexes16))
+
+#define REPORT_GENERAL_IS_LONG_RESPONSE(pResp) \
+  (((pResp)->reserved1 & REPORT_GENERAL_LONG_RESPONSE_BIT) == \
+      REPORT_GENERAL_LONG_RESPONSE_BIT)
+            
+/****************************************************************
+ *            report manufacturer info response
+ ****************************************************************/
+typedef struct smpRespReportManufactureInfo_s 
+{
+  bit8    reserved1[8];
+  bit8    vendorIdentification[8];
+  bit8    productIdentification[16];
+  bit8    productRevisionLevel[4];
+  bit8    vendorSpecific[20];
+} smpRespReportManufactureInfo_t;
+
+/****************************************************************
+ *           discover request
+ ****************************************************************/
+typedef struct smpReqDiscover_s 
+{
+  bit32   reserved1;
+  bit8    reserved2;
+  bit8    phyIdentifier;
+  bit8    ignored;  
+  bit8    reserved3;  
+} smpReqDiscover_t;
+
+/****************************************************************
+ *           discover response
+ ****************************************************************/
+typedef struct smpRespDiscover_s
+{
+  bit8   reserved1[4];
+  bit8   reserved2;
+  bit8   phyIdentifier;
+  bit8   reserved3[2];  
+  bit8   attachedDeviceType; /* byte 12 */
+    /* B7   : reserved */
+    /* B6-4 : attachedDeviceType */
+    /* B3-0 : reserved */
+  bit8   negotiatedPhyLinkRate; /* byte 11 */
+    /* B7-4 : reserved */
+    /* B3-0 : negotiatedPhyLinkRate */
+  bit8   attached_Ssp_Stp_Smp_Sata_Initiator; /* byte 14 */
+    /* B7-4 : reserved */
+    /* B3   : attachedSspInitiator */
+    /* B2   : attachedStpInitiator */
+    /* B1   : attachedSmpInitiator */
+    /* B0   : attachedSataHost */
+  bit8   attached_SataPS_Ssp_Stp_Smp_Sata_Target; /* byte 15 */
+    /* B7   : attachedSataPortSelector */
+    /* B6-4 : reserved */
+    /* B3   : attachedSspTarget */
+    /* B2   : attachedStpTarget */
+    /* B1   : attachedSmpTarget */
+    /* B0   : attachedSatadevice */
+  bit8   sasAddressHi[4];
+  bit8   sasAddressLo[4];
+  bit8   attachedSasAddressHi[4];
+  bit8   attachedSasAddressLo[4];
+  bit8   attachedPhyIdentifier;
+  bit8   reserved9[7];
+  bit8   programmedAndHardware_MinPhyLinkRate;
+    /* B7-4 : programmedMinPhyLinkRate */
+    /* B3-0 : hardwareMinPhyLinkRate */
+  bit8   programmedAndHardware_MaxPhyLinkRate;
+    /* B7-4 : programmedMaxPhyLinkRate */
+    /* B3-0 : hardwareMaxPhyLinkRate */
+  bit8   phyChangeCount;
+  bit8   virtualPhy_partialPathwayTimeout; /* byte 43 */
+    /* B7   : virtualPhy*/
+    /* B6-4 : reserved */
+    /* B3-0 : partialPathwayTimeout */
+  bit8   routingAttribute;
+    /* B7-4 : reserved */
+    /* B3-0 : routingAttribute */
+  bit8   reserved13[5];
+  bit8   vendorSpecific[2];
+} smpRespDiscover_t;
+
+#define DISCRSP_SSP_BIT    0x08
+#define DISCRSP_STP_BIT    0x04
+#define DISCRSP_SMP_BIT    0x02
+#define DISCRSP_SATA_BIT   0x01
+
+#define DISCRSP_SATA_PS_BIT   0x80
+
+#define DISCRSP_GET_ATTACHED_DEVTYPE(pResp) \
+  (((pResp)->attachedDeviceType & 0x70) >> 4)
+#define DISCRSP_GET_LINKRATE(pResp) \
+  ((pResp)->negotiatedPhyLinkRate & 0x0F)
+
+#define DISCRSP_IS_SSP_INITIATOR(pResp) \
+  (((pResp)->attached_Ssp_Stp_Smp_Sata_Initiator & DISCRSP_SSP_BIT) == DISCRSP_SSP_BIT)
+#define DISCRSP_IS_STP_INITIATOR(pResp) \
+  (((pResp)->attached_Ssp_Stp_Smp_Sata_Initiator & DISCRSP_STP_BIT) == DISCRSP_STP_BIT)
+#define DISCRSP_IS_SMP_INITIATOR(pResp) \
+  (((pResp)->attached_Ssp_Stp_Smp_Sata_Initiator & DISCRSP_SMP_BIT) == DISCRSP_SMP_BIT)
+#define DISCRSP_IS_SATA_HOST(pResp) \
+  (((pResp)->attached_Ssp_Stp_Smp_Sata_Initiator & DISCRSP_SATA_BIT) == DISCRSP_SATA_BIT)
+
+#define DISCRSP_IS_SSP_TARGET(pResp) \
+  (((pResp)->attached_SataPS_Ssp_Stp_Smp_Sata_Target & DISCRSP_SSP_BIT) == DISCRSP_SSP_BIT)
+#define DISCRSP_IS_STP_TARGET(pResp) \
+  (((pResp)->attached_SataPS_Ssp_Stp_Smp_Sata_Target & DISCRSP_STP_BIT) == DISCRSP_STP_BIT)
+#define DISCRSP_IS_SMP_TARGET(pResp) \
+  (((pResp)->attached_SataPS_Ssp_Stp_Smp_Sata_Target & DISCRSP_SMP_BIT) == DISCRSP_SMP_BIT)
+#define DISCRSP_IS_SATA_DEVICE(pResp) \
+  (((pResp)->attached_SataPS_Ssp_Stp_Smp_Sata_Target & DISCRSP_SATA_BIT) == DISCRSP_SATA_BIT)
+#define DISCRSP_IS_SATA_PORTSELECTOR(pResp) \
+  (((pResp)->attached_SataPS_Ssp_Stp_Smp_Sata_Target & DISCRSP_SATA_PS_BIT) == DISCRSP_SATA_PS_BIT)
+
+/* bit8 array[4] -> bit32 */
+#define DISCRSP_GET_SAS_ADDRESSHI(pResp) \
+  DMA_BEBIT32_TO_BIT32(*(bit32 *)(pResp)->sasAddressHi)
+#define DISCRSP_GET_SAS_ADDRESSLO(pResp) \
+  DMA_BEBIT32_TO_BIT32(*(bit32 *)(pResp)->sasAddressLo)
+
+/* bit8 array[4] -> bit32 */
+#define DISCRSP_GET_ATTACHED_SAS_ADDRESSHI(pResp) \
+  DMA_BEBIT32_TO_BIT32(*(bit32 *)(pResp)->attachedSasAddressHi)
+#define DISCRSP_GET_ATTACHED_SAS_ADDRESSLO(pResp) \
+  DMA_BEBIT32_TO_BIT32(*(bit32 *)(pResp)->attachedSasAddressLo)
+
+#define DISCRSP_VIRTUALPHY_BIT 0x80
+#define DISCRSP_IS_VIRTUALPHY(pResp) \
+  (((pResp)->virtualPhy_partialPathwayTimeout & DISCRSP_VIRTUALPHY_BIT) == DISCRSP_VIRTUALPHY_BIT)
+
+#define DISCRSP_GET_ROUTINGATTRIB(pResp) \
+  ((pResp)->routingAttribute & 0x0F)
+
+/****************************************************************
+ *            report route table request
+ ****************************************************************/
+typedef struct smpReqReportRouteTable_s
+{
+  bit8   reserved1[2];
+  bit8   expanderRouteIndex16[20];
+  bit8   reserved2;
+  bit8   phyIdentifier;
+  bit8   reserved3[2];
+} smpReqReportRouteTable_t;
+
+/****************************************************************
+ *            report route response
+ ****************************************************************/
+typedef struct smpRespReportRouteTable_s 
+{
+  bit8   reserved1[2];
+  bit8   expanderRouteIndex16[2];
+  bit8   reserved2;
+  bit8   phyIdentifier;
+  bit8   reserved3[2];
+  bit8   disabled;
+    /* B7   : expander route entry disabled */
+    /* B6-0 : reserved */
+  bit8   reserved5[3];
+  bit8   routedSasAddressHi32[4];
+  bit8   routedSasAddressLo32[4];
+  bit8   reserved6[16];
+} smpRespReportRouteTable_t;
+
+/****************************************************************
+ *            configure route information request
+ ****************************************************************/
+typedef struct smpReqConfigureRouteInformation_s
+{
+  bit8   reserved1[2];
+  bit8   expanderRouteIndex[2];
+  bit8   reserved2;
+  bit8   phyIdentifier;
+  bit8   reserved3[2];
+  bit8   disabledBit_reserved4;
+  bit8   reserved5[3];
+  bit8   routedSasAddressHi[4];
+  bit8   routedSasAddressLo[4];
+  bit8   reserved6[16];
+} smpReqConfigureRouteInformation_t;
+
+/****************************************************************
+ *            configure route response
+ ****************************************************************/
+#ifdef FOR_COMPLETENESS
+typedef struct smpRespConfigureRouteInformation_s 
+{
+  /* nothing. some compiler disallowed structure with no member */
+} smpRespConfigureRouteInformation_t;
+#endif
+
+/****************************************************************
+ *            report Phy Sata request
+ ****************************************************************/
+typedef struct smpReqReportPhySata_s
+{
+  bit8   reserved1[4];
+  bit8   reserved2;
+  bit8   phyIdentifier;
+  bit8   reserved3[2];
+} smpReqReportPhySata_t;
+
+/****************************************************************
+ *            report Phy Sata response
+ ****************************************************************/
+typedef struct smpRespReportPhySata_s 
+{
+  bit8   reserved1[4];
+  bit8   reserved2;
+  bit8   phyIdentifier;
+  bit8   reserved3;
+  bit8   affiliations_sup_valid;
+    /* b7-2 : reserved */
+    /* b1   : Affiliations supported */
+    /* b0   : Affiliation valid */

*** DIFF OUTPUT TRUNCATED AT 1000 LINES ***


More information about the svn-src-stable mailing list