123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367 |
- //*****************************************************************************
- //
- //! \file w5500.c
- //! \brief W5500 HAL Interface.
- //! \version 1.0.2
- //! \date 2013/10/21
- //! \par Revision history
- //! <2014/05/01> V1.0.2
- //! 1. Implicit type casting -> Explicit type casting. Refer to M20140501
- //! Fixed the problem on porting into under 32bit MCU
- //! Issued by Mathias ClauBen, wizwiki forum ID Think01 and bobh
- //! Thank for your interesting and serious advices.
- //! <2013/12/20> V1.0.1
- //! 1. Remove warning
- //! 2. WIZCHIP_READ_BUF WIZCHIP_WRITE_BUF in case _WIZCHIP_IO_MODE_SPI_FDM_
- //! for loop optimized(removed). refer to M20131220
- //! <2013/10/21> 1st Release
- //! \author MidnightCow
- //! \copyright
- //!
- //! Copyright (c) 2013, WIZnet Co., LTD.
- //! All rights reserved.
- //!
- //! Redistribution and use in source and binary forms, with or without
- //! modification, are permitted provided that the following conditions
- //! are met:
- //!
- //! * Redistributions of source code must retain the above copyright
- //! notice, this list of conditions and the following disclaimer.
- //! * 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.
- //! * Neither the name of the <ORGANIZATION> nor the names of its
- //! contributors may be used to endorse or promote products derived
- //! from this software without specific prior written permission.
- //!
- //! THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS 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 COPYRIGHT OWNER 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.
- //
- //*****************************************************************************
- //#include <stdio.h>
- #include "w5500.h"
- #define _W5500_SPI_VDM_OP_ 0x00
- #define _W5500_SPI_FDM_OP_LEN1_ 0x01
- #define _W5500_SPI_FDM_OP_LEN2_ 0x02
- #define _W5500_SPI_FDM_OP_LEN4_ 0x03
- ////////////////////////////////////////////////////
- uint8_t WIZCHIP_READ(uint32_t AddrSel)
- {
- uint8_t ret;
- WIZCHIP_CRITICAL_ENTER();
- WIZCHIP.CS._select();
- #if( (_WIZCHIP_IO_MODE_ & _WIZCHIP_IO_MODE_SPI_))
- #if ( _WIZCHIP_IO_MODE_ == _WIZCHIP_IO_MODE_SPI_VDM_ )
- AddrSel |= (_W5500_SPI_READ_ | _W5500_SPI_VDM_OP_);
- #elif( _WIZCHIP_IO_MODE_ == _WIZCHIP_IO_MODE_SPI_FDM_ )
- AddrSel |= (_W5500_SPI_READ_ | _W5500_SPI_FDM_OP_LEN1_);
- #else
- #error "Unsupported _WIZCHIP_IO_SPI_ in W5500 !!!"
- #endif
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x00FF0000) >> 16);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x0000FF00) >> 8);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x000000FF) >> 0);
- ret = WIZCHIP.IF.SPI._read_byte();
- #elif ( (_WIZCHIP_IO_MODE_ & _WIZCHIP_IO_MODE_BUS_) )
- #if (_WIZCHIP_IO_MODE_ == _WIZCHIP_IO_MODE_BUS_DIR_)
- #elif(_WIZCHIP_IO_MODE_ == _WIZCHIP_IO_MODE_BUS_INDIR_)
- #else
- #error "Unsupported _WIZCHIP_IO_MODE_BUS_ in W5500 !!!"
- #endif
- #else
- #error "Unknown _WIZCHIP_IO_MODE_ in W5000. !!!"
- #endif
- WIZCHIP.CS._deselect();
- WIZCHIP_CRITICAL_EXIT();
- return ret;
- }
- void WIZCHIP_WRITE(uint32_t AddrSel, uint8_t wb )
- {
- WIZCHIP_CRITICAL_ENTER();
- WIZCHIP.CS._select();
- #if( (_WIZCHIP_IO_MODE_ & _WIZCHIP_IO_MODE_SPI_))
- #if ( _WIZCHIP_IO_MODE_ == _WIZCHIP_IO_MODE_SPI_VDM_ )
- AddrSel |= (_W5500_SPI_WRITE_ | _W5500_SPI_VDM_OP_);
- #elif( _WIZCHIP_IO_MODE_ == _WIZCHIP_IO_MODE_SPI_FDM_ )
- AddrSel |= (_W5500_SPI_WRITE_ | _W5500_SPI_FDM_OP_LEN1_);
- #else
- #error "Unsupported _WIZCHIP_IO_SPI_ in W5500 !!!"
- #endif
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x00FF0000) >> 16);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x0000FF00) >> 8);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x000000FF) >> 0);
- WIZCHIP.IF.SPI._write_byte(wb);
- #elif ( (_WIZCHIP_IO_MODE_ & _WIZCHIP_IO_MODE_BUS_) )
- #if (_WIZCHIP_IO_MODE_ == _WIZCHIP_IO_MODE_BUS_DIR_)
- #elif(_WIZCHIP_IO_MODE_ == _WIZCHIP_IO_MODE_BUS_INDIR_)
- #else
- #error "Unsupported _WIZCHIP_IO_MODE_BUS_ in W5500 !!!"
- #endif
- #else
- #error "Unknown _WIZCHIP_IO_MODE_ in W5500. !!!"
- #endif
- WIZCHIP.CS._deselect();
- WIZCHIP_CRITICAL_EXIT();
- }
-
- void WIZCHIP_READ_BUF (uint32_t AddrSel, uint8_t* pBuf, uint16_t len)
- {
- uint16_t i = 0;
- uint16_t j = 0;
- WIZCHIP_CRITICAL_ENTER();
- WIZCHIP.CS._select();
- #if( (_WIZCHIP_IO_MODE_ & _WIZCHIP_IO_MODE_SPI_))
- #if ( _WIZCHIP_IO_MODE_ == _WIZCHIP_IO_MODE_SPI_VDM_ )
- AddrSel |= (_W5500_SPI_READ_ | _W5500_SPI_VDM_OP_);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x00FF0000) >> 16);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x0000FF00) >> 8);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x000000FF) >> 0);
- for(i = 0; i < len; i++,j)
- pBuf[i] = WIZCHIP.IF.SPI._read_byte();
- #elif( _WIZCHIP_IO_MODE_ == _WIZCHIP_IO_MODE_SPI_FDM_ )
- AddrSel |= (_W5500_SPI_READ_ | _W5500_SPI_FDM_OP_LEN4_);
- for(i = 0; i < len/4; i++, j)
- {
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x00FF0000) >> 16);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x0000FF00) >> 8);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x000000FF) >> 0);
- pBuf[i*4] = WIZCHIP.IF.SPI._read_byte();
- pBuf[i*4+1] = WIZCHIP.IF.SPI._read_byte();
- pBuf[i*4+2] = WIZCHIP.IF.SPI._read_byte();
- pBuf[i*4+3] = WIZCHIP.IF.SPI._read_byte();
- AddrSel = WIZCHIP_OFFSET_INC(AddrSel,4);
- }
- len %= 4; // for the rest data
- // M20131220 : remove for loop
- i *= 4;
- if(len >= 2)
- {
- AddrSel -= 1; // change _W5500_SPI_FDM_OP_LEN4_ to _W5500_SPI_FDM_OP_LEN2_
- //for(j = 0; j < len/2 ; j++)
- {
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x00FF0000) >> 16);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x0000FF00) >> 8);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x000000FF) >> 0);
- pBuf[i] = WIZCHIP.IF.SPI._read_byte();
- pBuf[i+1] = WIZCHIP.IF.SPI._read_byte();
- i += 2;
- AddrSel = WIZCHIP_OFFSET_INC(AddrSel,2);
- }
- }
- len %= 2;
- if(len)
- {
- AddrSel -= 1; // change _W5500_SPI_FDM_OP_LEN2_ to _W5500_SPI_FDM_OP_LEN1_
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x00FF0000) >> 16);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x0000FF00) >> 8);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x000000FF) >> 0);
- pBuf[i] = WIZCHIP.IF.SPI._read_byte();
- }
- #else
- #error "Unsupported _WIZCHIP_IO_MODE_SPI_ in W5500 !!!"
- #endif
- #elif ( (_WIZCHIP_IO_MODE_ & _WIZCHIP_IO_MODE_BUS_) )
- #if (_WIZCHIP_IO_MODE_ == _WIZCHIP_IO_MODE_BUS_DIR_)
- #elif(_WIZCHIP_IO_MODE_ == _WIZCHIP_IO_MODE_BUS_INDIR_)
- #else
- #error "Unsupported _WIZCHIP_IO_MODE_BUS_ in W5500 !!!"
- #endif
- #else
- #error "Unknown _WIZCHIP_IO_MODE_ in W5500. !!!!"
- #endif
- WIZCHIP.CS._deselect();
- WIZCHIP_CRITICAL_EXIT();
- }
- void WIZCHIP_WRITE_BUF(uint32_t AddrSel, uint8_t* pBuf, uint16_t len)
- {
- uint16_t i = 0;
- uint16_t j = 0;
- WIZCHIP_CRITICAL_ENTER();
- WIZCHIP.CS._select();
- #if( (_WIZCHIP_IO_MODE_ & _WIZCHIP_IO_MODE_SPI_))
- #if ( _WIZCHIP_IO_MODE_ == _WIZCHIP_IO_MODE_SPI_VDM_ )
- AddrSel |= (_W5500_SPI_WRITE_ | _W5500_SPI_VDM_OP_);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x00FF0000) >> 16);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x0000FF00) >> 8);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x000000FF) >> 0);
- for(i = 0; i < len; i++,j)
- WIZCHIP.IF.SPI._write_byte(pBuf[i]);
- #elif( _WIZCHIP_IO_MODE_ == _WIZCHIP_IO_MODE_SPI_FDM_ )
- AddrSel |= (_W5500_SPI_WRITE_ | _W5500_SPI_FDM_OP_LEN4_);
- for(i = 0; i < len/4; i++, j)
- {
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x00FF0000) >> 16);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x0000FF00) >> 8);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x000000FF) >> 0);
- WIZCHIP.IF.SPI._write_byte(pBuf[i*4] );
- WIZCHIP.IF.SPI._write_byte(pBuf[i*4+1]);
- WIZCHIP.IF.SPI._write_byte(pBuf[i*4+2]);
- WIZCHIP.IF.SPI._write_byte(pBuf[i*4+3]);
- AddrSel = WIZCHIP_OFFSET_INC(AddrSel,4);
- }
- len %= 4; // for the rest data
- // M20131220 : Remove for loop
- i *= 4;
- if(len >= 2)
- {
- AddrSel -= 1; // change _W5500_SPI_FDM_OP_LEN4_ to _W5500_SPI_FDM_OP_LEN2_
- //for(j = 0; j < len/2 ; j++)
- {
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x00FF0000) >> 16);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x0000FF00) >> 8);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x000000FF) >> 0);
- WIZCHIP.IF.SPI._write_byte(pBuf[i] );
- WIZCHIP.IF.SPI._write_byte(pBuf[i+1]);
- i += 2;
- AddrSel = WIZCHIP_OFFSET_INC(AddrSel, 2);
- }
- len %= 2;
- if(len)
- {
- AddrSel -= 1; // change _W5500_SPI_FDM_OP_LEN2_ to _W5500_SPI_FDM_OP_LEN1_
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x00FF0000) >> 16);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x0000FF00) >> 8);
- WIZCHIP.IF.SPI._write_byte((AddrSel & 0x000000FF) >> 0);
- WIZCHIP.IF.SPI._write_byte(pBuf[i]);
- }
- }
- #else
- #error "Unsupported _WIZCHIP_IO_SPI_ in W5500 !!!"
- #endif
- #elif ( (_WIZCHIP_IO_MODE_ & _WIZCHIP_IO_MODE_BUS_) )
- #if (_WIZCHIP_IO_MODE_ == _WIZCHIP_IO_MODE_BUS_DIR_)
- #elif(_WIZCHIP_IO_MODE_ == _WIZCHIP_IO_MODE_BUS_INDIR_)
- #else
- #error "Unsupported _WIZCHIP_IO_MODE_BUS_ in W5500 !!!"
- #endif
- #else
- #error "Unknown _WIZCHIP_IO_MODE_ in W5500. !!!!"
- #endif
- WIZCHIP.CS._deselect();
- WIZCHIP_CRITICAL_EXIT();
- }
- uint16_t getSn_TX_FSR(uint8_t sn)
- {
- uint16_t val=0,val1=0;
- do
- {
- val1 = WIZCHIP_READ(Sn_TX_FSR(sn));
- val1 = (val1 << 8) + WIZCHIP_READ(WIZCHIP_OFFSET_INC(Sn_TX_FSR(sn),1));
- if (val1 != 0)
- {
- val = WIZCHIP_READ(Sn_TX_FSR(sn));
- val = (val << 8) + WIZCHIP_READ(WIZCHIP_OFFSET_INC(Sn_TX_FSR(sn),1));
- }
- }while (val != val1);
- return val;
- }
- uint16_t getSn_RX_RSR(uint8_t sn)
- {
- uint16_t val=0,val1=0;
- do
- {
- val1 = WIZCHIP_READ(Sn_RX_RSR(sn));
- val1 = (val1 << 8) + WIZCHIP_READ(WIZCHIP_OFFSET_INC(Sn_RX_RSR(sn),1));
- if (val1 != 0)
- {
- val = WIZCHIP_READ(Sn_RX_RSR(sn));
- val = (val << 8) + WIZCHIP_READ(WIZCHIP_OFFSET_INC(Sn_RX_RSR(sn),1));
- }
- }while (val != val1);
- return val;
- }
- void wiz_send_data(uint8_t sn, uint8_t *wizdata, uint16_t len)
- {
- uint16_t ptr = 0;
- uint32_t addrsel = 0;
- if(len == 0) return;
- ptr = getSn_TX_WR(sn);
- //M20140501 : implict type casting -> explict type casting
- //addrsel = (ptr << 8) + (WIZCHIP_TXBUF_BLOCK(sn) << 3);
- addrsel = ((uint32_t)ptr << 8) + (WIZCHIP_TXBUF_BLOCK(sn) << 3);
- //
- WIZCHIP_WRITE_BUF(addrsel,wizdata, len);
-
- ptr += len;
- setSn_TX_WR(sn,ptr);
- }
- void wiz_recv_data(uint8_t sn, uint8_t *wizdata, uint16_t len)
- {
- uint16_t ptr = 0;
- uint32_t addrsel = 0;
-
- if(len == 0) return;
- ptr = getSn_RX_RD(sn);
- //M20140501 : implict type casting -> explict type casting
- //addrsel = ((ptr << 8) + (WIZCHIP_RXBUF_BLOCK(sn) << 3);
- addrsel = ((uint32_t)ptr << 8) + (WIZCHIP_RXBUF_BLOCK(sn) << 3);
- //
- WIZCHIP_READ_BUF(addrsel, wizdata, len);
- ptr += len;
-
- setSn_RX_RD(sn,ptr);
- }
- void wiz_recv_ignore(uint8_t sn, uint16_t len)
- {
- uint16_t ptr = 0;
- ptr = getSn_RX_RD(sn);
- ptr += len;
- setSn_RX_RD(sn,ptr);
- }
|