Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 28 Sep 2006 06:42:25 GMT
From:      Warner Losh <imp@FreeBSD.org>
To:        Perforce Change Reviews <perforce@freebsd.org>
Subject:   PERFORCE change 106807 for review
Message-ID:  <200609280642.k8S6gPoi042184@repoman.freebsd.org>

next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=106807

Change 106807 by imp@imp_lighthouse on 2006/09/28 06:42:06

	Initialize, per spec for this board
	XXX should work on making this generic.

Affected files ...

.. //depot/projects/arm/src/sys/arm/at91/at91_ssc.c#8 edit
.. //depot/projects/arm/src/sys/arm/at91/at91_sscreg.h#5 edit

Differences ...

==== //depot/projects/arm/src/sys/arm/at91/at91_ssc.c#8 (text+ko) ====

@@ -88,14 +88,16 @@
 /* cdev routines */
 static d_open_t at91_ssc_open;
 static d_close_t at91_ssc_close;
-static d_ioctl_t at91_ssc_ioctl;
+static d_read_t at91_ssc_read;
+static d_write_t at91_ssc_write;
 
 static struct cdevsw at91_ssc_cdevsw =
 {
 	.d_version = D_VERSION,
 	.d_open = at91_ssc_open,
 	.d_close = at91_ssc_close,
-	.d_ioctl = at91_ssc_ioctl
+	.d_read = at91_ssc_read,
+	.d_write = at91_ssc_write,
 };
 
 static int
@@ -134,6 +136,19 @@
 		goto out;
 	}
 	sc->cdev->si_drv1 = sc;
+
+	// Init for TSC needs
+	WR4(sc, SSC_CR, SSC_CR_SWRST);
+	WR4(sc, SSC_CMR, 0);		// clock divider unused
+	WR4(sc, SSC_RCMR,
+	    SSC_RCMR_CKS_RK | SSC_RCMR_CKO_NONE | SSC_RCMR_START_FALL_EDGE_RF);
+	WR4(sc, SSC_RFMR,
+	    0x1f | SSC_RFMR_MSFBF | SSC_RFMR_FSOS_NONE);
+	WR4(sc, SSC_TCMR,
+	    SSC_TCMR_CKS_TK | SSC_TCMR_CKO_NONE |  SSC_RCMR_START_CONT);
+	WR4(sc, SSC_TFMR,
+	    0x1f | SSC_TFMR_DATDEF | SSC_TFMR_MSFBF | SSC_TFMR_FSOS_NEG_PULSE);
+
 out:;
 	if (err)
 		at91_ssc_deactivate(dev);
@@ -241,10 +256,15 @@
 }
 
 static int
-at91_ssc_ioctl(struct cdev *dev, u_long cmd, caddr_t data, int fflag,
-    struct thread *td)
+at91_ssc_read(struct cdev *dev, struct uio *uio, int flag)
+{
+	return EIO;
+}
+
+static int
+at91_ssc_write(struct cdev *dev, struct uio *uio, int flag)
 {
-	return (ENXIO);
+	return EIO;
 }
 
 static device_method_t at91_ssc_methods[] = {

==== //depot/projects/arm/src/sys/arm/at91/at91_sscreg.h#5 (text+ko) ====

@@ -27,4 +27,109 @@
 #ifndef ARM_AT91_AT91_SSCREG_H
 #define ARM_AT91_AT91_SSCREG_H
 
+/* Registers */
+#define	SSC_CR		0x00		/* Control Register */
+#define	SSC_CMR		0x04		/* Clock Mode Register */
+		/*	0x08		Reserved */
+		/*	0x0c		Reserved */
+#define	SSC_RCMR	0x10		/* Receive Clock Mode Register */
+#define	SSC_RFMR	0x14		/* Receive Frame Mode Register */
+#define	SSC_TCMR	0x18		/* Transmit Clock Mode Register */
+#define	SSC_TFMR	0x1c		/* Transmit Frame Mode register */
+#define	SSC_RHR		0x20		/* Receive Holding Register */
+#define	SSC_THR		0x24		/* Transmit Holding Register */
+		/*	0x28		Reserved */
+		/*	0x2c		Reserved */
+#define	SSC_RSHR	0x30		/* Receive Sync Holding Register */
+#define	SSC_TSHR	0x34		/* Transmit Sync Holding Register */
+		/*	0x38		Reserved */
+		/*	0x3c		Reserved */
+#define	SSC_SR		0x40		/* Status Register */
+#define	SSC_IER		0x44		/* Interrupt Enable Register */
+#define	SSC_IDR		0x48		/* Interrupt Disable Register */
+#define	SSC_IMR		0x4c		/* Interrupt Mask Register */
+/* And PDC registers */
+
+/* SSC_CR */
+#define	SSC_CR_RXEN	(1u << 0)	/* RXEN: Receive Enable */
+#define	SSC_CR_RXDIS	(1u << 1)	/* RXDIS: Receive Disable */
+#define	SSC_CR_TXEN	(1u << 8)	/* TXEN: Transmit Enable */
+#define	SSC_CR_TXDIS	(1u << 9)	/* TXDIS: Transmit Disable */
+#define	SSC_CR_SWRST	(1u << 15)	/* SWRST: Software Reset */
+
+/* SSC_CMR */
+#define	SSC_CMR_DIV	0xfffu		/* DIV: Clock Divider mask */
+
+/* SSC_RCMR */
+#define	SSC_RCMR_PERIOD	(0xffu << 24)	/* PERIOD: Receive Period Divider sel*/
+#define	SSC_RCMR_STTDLY	(0xffu << 16)	/* STTDLY: Receive Start Delay */
+#define	SSC_RCMR_START	(0xfu << 8)	/* START: Receive Start Sel */
+#define		SSC_RCMR_START_CONT		(0u << 8)
+#define		SSC_RCMR_START_TX_START		(1u << 8)
+#define		SSC_RCMR_START_LOW_RF		(2u << 8)
+#define		SSC_RCMR_START_HIGH_RF		(3u << 8)
+#define		SSC_RCMR_START_FALL_EDGE_RF	(4u << 8)
+#define		SSC_RCMR_START_RISE_EDGE_RF	(5u << 8)
+#define		SSC_RCMR_START_LEVEL_CHANGE_RF	(6u << 8)
+#define		SSC_RCMR_START_ANY_EDGE_RF	(7u << 8)
+#define	SSC_RCMR_CKI	(1u << 5)	/* CKI: Receive Clock Inversion */
+#define	SSC_RCMR_CKO	(7u << 2)	/* CKO: Receive Clock Output Mode Sel*/
+#define		SSC_RCMR_CKO_NONE		(0u << 2)
+#define		SSC_RCMR_CKO_CONTINUOUS		(1u << 2)
+#define	SSC_RCMR_CKS	(3u)	       	/* CKS: Receive Clock Selection */
+#define		SSC_RCMR_CKS_DIVIDED		(0)
+#define		SSC_RCMR_CKS_TK_CLOCK		(1)
+#define		SSC_RCMR_CKS_RK			(2)
+
+/* SSC_RFMR */
+#define	SSC_RFMR_FSEDGE	(1u << 24)	/* FSEDGE: Frame Sync Edge Detection */
+#define	SSC_RFMR_FSOS	(7u << 20)	/* FSOS: Receive frame Sync Out sel */
+#define		SSC_RFMR_FSOS_NONE		(0u << 20)
+#define		SSC_RFMR_FSOS_NEG_PULSE		(1u << 20)
+#define		SSC_RFMR_FSOS_POS_PULSE		(2u << 20)
+#define		SSC_RFMR_FSOS_LOW		(3u << 20)
+#define		SSC_RFMR_FSOS_HIGH		(4u << 20)
+#define		SSC_RFMR_FSOS_TOGGLE		(5u << 20)
+#define	SSC_RFMR_FSLEN	(0xfu << 16)	/* FSLEN: Receive Frame Sync Length */
+#define	SSC_RFMR_DATNB	(0xfu << 8)	/* DATNB: Data Number per Frame */
+#define	SSC_RFMR_MSFBF	(1u << 7)	/* MSBF: Most Significant Bit First */
+#define	SSC_RFMR_LOOP	(1u << 5)	/* LOOP: Loop Mode */
+#define	SSC_RFMR_DATLEN	(0x1fu << 0)	/* DATLEN: Data Length */
+
+/* SSC_TCMR */
+#define	SSC_TCMR_PERIOD	(0xffu << 24)	/* PERIOD: Receive Period Divider sel*/
+#define	SSC_TCMR_STTDLY	(0xffu << 16)	/* STTDLY: Receive Start Delay */
+#define	SSC_TCMR_START	(0xfu << 8)	/* START: Receive Start Sel */
+#define		SSC_TCMR_START_CONT		(0u << 8)
+#define		SSC_TCMR_START_RX_START		(1u << 8)
+#define		SSC_TCMR_START_LOW_RF		(2u << 8)
+#define		SSC_TCMR_START_HIGH_RF		(3u << 8)
+#define		SSC_TCMR_START_FALL_EDGE_RF	(4u << 8)
+#define		SSC_TCMR_START_RISE_EDGE_RF	(5u << 8)
+#define		SSC_TCMR_START_LEVEL_CHANGE_RF	(6u << 8)
+#define		SSC_TCMR_START_ANY_EDGE_RF	(7u << 8)
+#define	SSC_TCMR_CKI	(1u << 5)	/* CKI: Receive Clock Inversion */
+#define	SSC_TCMR_CKO	(7u << 2)	/* CKO: Receive Clock Output Mode Sel*/
+#define		SSC_TCMR_CKO_NONE		(0u << 2)
+#define		SSC_TCMR_CKO_CONTINUOUS		(1u << 2)
+#define	SSC_TCMR_CKS	(3u)	       	/* CKS: Receive Clock Selection */
+#define		SSC_TCMR_CKS_DIVIDED		(0)
+#define		SSC_TCMR_CKS_RK_CLOCK		(1)
+#define		SSC_TCMR_CKS_TK			(2)
+
+/* SSC_TFMR */
+#define	SSC_TFMR_FSEDGE	(1u << 24)	/* FSEDGE: Frame Sync Edge Detection */
+#define	SSC_TFMR_FSOS	(7u << 20)	/* FSOS: Receive frame Sync Out sel */
+#define		SSC_TFMR_FSOS_NONE		(0u << 20)
+#define		SSC_TFMR_FSOS_NEG_PULSE		(1u << 20)
+#define		SSC_TFMR_FSOS_POS_PULSE		(2u << 20)
+#define		SSC_TFMR_FSOS_LOW		(3u << 20)
+#define		SSC_TFMR_FSOS_HIGH		(4u << 20)
+#define		SSC_TFMR_FSOS_TOGGLE		(5u << 20)
+#define	SSC_TFMR_FSLEN	(0xfu << 16)	/* FSLEN: Receive Frame Sync Length */
+#define	SSC_TFMR_DATNB	(0xfu << 8)	/* DATNB: Data Number per Frame */
+#define	SSC_TFMR_MSFBF	(1u << 7)	/* MSBF: Most Significant Bit First */
+#define	SSC_TFMR_DATDEF	(1u << 5)	/* DATDEF: Data Default Value */
+#define	SSC_TFMR_DATLEN	(0x1fu << 0)	/* DATLEN: Data Length */
+
 #endif /* ARM_AT91_AT91_SSCREG_H */



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200609280642.k8S6gPoi042184>