Add server tcp api.
[bertos.git] / bertos / cpu / arm / io / at91sam7.h
index dbc6f4499a89e71ef6f2232afdb434edc3986ebe..6c645dcab9074958f9860044f8770453e9cc9558 100644 (file)
@@ -30,7 +30,6 @@
  *
  * -->
  *
- * \version $Id$
  *
  * \author Francesco Sacchi <batt@develer.com>
  * \author Daniele Basile <asterix@develer.com>
        #define SSC_HAS_PDC                1
        #define USART_HAS_PDC              1
 
+       /* PDC registers */
+       #define PERIPH_RPR_OFF  0x100  ///< Receive Pointer Register.
+       #define PERIPH_RCR_OFF  0x104  ///< Receive Counter Register.
+       #define PERIPH_TPR_OFF  0x108  ///< Transmit Pointer Register.
+       #define PERIPH_TCR_OFF  0x10C  ///< Transmit Counter Register.
+       #define PERIPH_RNPR_OFF 0x110  ///< Receive Next Pointer Register.
+       #define PERIPH_RNCR_OFF 0x114  ///< Receive Next Counter Register.
+       #define PERIPH_TNPR_OFF 0x118  ///< Transmit Next Pointer Register.
+       #define PERIPH_TNCR_OFF 0x11C  ///< Transmit Next Counter Register.
+       #define PERIPH_PTCR_OFF 0x120  ///< PDC Transfer Control Register.
+       #define PERIPH_PTSR_OFF 0x124  ///< PDC Transfer Status Register.
+
+       #define PDC_RXTEN  0
+       #define PDC_RXTDIS 1
+       #define PDC_TXTEN  8
+       #define PDC_TXTDIS 9
+
 #else
-       #error No base addrese register definition for selected ARM CPU
+       #error No base address register definition for selected ARM CPU
+
+#endif
+
+#if CPU_ARM_AT91SAM7S64
+       #define FLASH_MEM_SIZE          0x10000UL ///< Internal flash memory size
+       #define FLASH_PAGE_SIZE_BYTES         128 ///< Size of cpu flash memory page in bytes
+       #define FLASH_BANKS_NUM                 1 ///< Number of flash banks
+       #define FLASH_SECTORS_NUM              16 ///< Number of flash sector
+       #define FLASH_PAGE_PER_SECTOR          32 ///< Number of page for sector
+
+#elif CPU_ARM_AT91SAM7S128 || CPU_ARM_AT91SAM7X128
+       #define FLASH_MEM_SIZE          0x20000UL ///< Internal flash memory size
+       #define FLASH_PAGE_SIZE_BYTES         256 ///< Size of cpu flash memory page in bytes
+       #define FLASH_BANKS_NUM                 1 ///< Number of flash banks
+       #define FLASH_SECTORS_NUM               8 ///< Number of flash sector
+       #define FLASH_PAGE_PER_SECTOR          64 ///< Number of page for sector
+
+#elif CPU_ARM_AT91SAM7S256 || CPU_ARM_AT91SAM7X256
+       #define FLASH_MEM_SIZE          0x40000UL ///< Internal flash memory size
+       #define FLASH_PAGE_SIZE_BYTES         256 ///< Size of cpu flash memory page in bytes
+       #define FLASH_BANKS_NUM                 1 ///< Number of flash banks
+       #define FLASH_SECTORS_NUM              16 ///< Number of flash sector
+       #define FLASH_PAGE_PER_SECTOR          64 ///< Number of page for sector
+
+#elif CPU_ARM_AT91SAM7S512 || CPU_ARM_AT91SAM7X512
+       #define FLASH_MEM_SIZE          0x80000UL ///< Internal flash memory size
+       #define FLASH_PAGE_SIZE_BYTES         256 ///< Size of cpu flash memory page in bytes
+       #define FLASH_BANKS_NUM                 2 ///< Number of flash banks
+       #define FLASH_SECTORS_NUM              32 ///< Number of flash sector
+       #define FLASH_PAGE_PER_SECTOR          64 ///< Number of page for sector
 
+#else
+       #error Memory size definition for selected ARM CPU
 #endif
 
 #include "at91_aic.h"
 #include "at91_pwm.h"
 #include "at91_spi.h"
 #include "at91_twi.h"
+#include "at91_ssc.h"
+#include "at91_emac.h"
 //TODO: add other peripherals
 
 /**
 #endif
 /*\}*/
 
+/**
+ * SSC pins name
+ *\{
+ */
+#if CPU_ARM_SAM7S_LARGE
+
+       #define SSC_TF     15 // PA15
+       #define SSC_TK     16 // PA16
+       #define SSC_TD     17 // PA17
+       #define SSC_RD     18 // PA18
+       #define SSC_RK     19 // PA19
+       #define SSC_RF     20 // PA20
+
+#elif CPU_ARM_SAM7X
+
+       #define SSC_TF     21 // PA21
+       #define SSC_TK     22 // PA22
+       #define SSC_TD     23 // PA23
+       #define SSC_RD     24 // PA24
+       #define SSC_RK     25 // PA25
+       #define SSC_RF     26 // PA26
+
+#else
+       #error No SSC pins name definition for selected ARM CPU
+
+#endif
+/*\}*/
+
 /**
  * Timer counter pins definition.
  *\{
        #define PWM_PIO_PDR     PIOB_PDR
        #define PWM_PIO_PER     PIOB_PER
        #define PWM_PIO_CODR    PIOB_CODR
+       #define PWM_PIO_SODR    PIOB_SODR
        #define PWM_PIO_OER     PIOB_OER
        #define PWM_PIO_ABSR    PIOB_ASR
 
        #define PWM_PIO_PDR     PIOA_PDR
        #define PWM_PIO_PER     PIOA_PER
        #define PWM_PIO_CODR    PIOA_CODR
+       #define PWM_PIO_SODR    PIOA_SODR
        #define PWM_PIO_OER     PIOA_OER
        #define PWM_PIO_ABSR    PIOA_BSR
 
 #endif
 /*\}*/
 
+
+/**
+ * Pin definition MII/RMII PHY interdace
+ */
+#if CPU_ARM_SAM7X
+       #define PHY_TXCLK_BIT      BV(0)
+       #define PHY_TXEN_BIT       BV(1)
+       #define PHY_TXD0_BIT       BV(2)
+       #define PHY_TXD1_BIT       BV(3)
+       #define PHY_CRS_BIT        BV(4)
+       #define PHY_RXD0_BIT       BV(5)
+       #define PHY_RXD1_BIT       BV(6)
+       #define PHY_RXER_BIT       BV(7)
+       #define PHY_MDC_BIT        BV(8)
+       #define PHY_MDIO_BIT       BV(9)
+       #define PHY_TXD2_BIT       BV(10)
+       #define PHY_TXD3_BIT       BV(11)
+       #define PHY_TXER_BIT       BV(12)
+       #define PHY_RXD2_BIT       BV(13)
+       #define PHY_RXD3_BIT       BV(14)
+       #define PHY_RXDV_BIT       BV(15)
+       #define PHY_COL_BIT        BV(16)
+       #define PHY_RXCLK_BIT      BV(17)
+
+#elif CPU_ARM_SAM7S_LARGE
+       /* No ethernet interface is present on this cpu */
+#else
+       #error No MII/RMII PHY pins interface was define for select CPU.
+#endif
+
+#define PHY_MII_PINS   \
+       ( PHY_TXEN_BIT \
+       | PHY_TXD0_BIT \
+       | PHY_TXD1_BIT \
+       | PHY_CRS_BIT \
+       | PHY_RXD0_BIT \
+       | PHY_RXD1_BIT \
+       | PHY_RXER_BIT \
+       | PHY_MDC_BIT \
+       | PHY_MDIO_BIT \
+       | PHY_TXD2_BIT \
+       | PHY_TXD3_BIT \
+       | PHY_TXER_BIT \
+       | PHY_RXD2_BIT \
+       | PHY_RXD3_BIT \
+       | PHY_RXDV_BIT \
+       | PHY_COL_BIT \
+       | PHY_RXCLK_BIT)
+// \}
+
 #endif /* AT91SAM7_H */