mirror of
https://github.com/marqs85/ossc.git
synced 2024-09-17 00:54:34 +00:00
261 lines
9.9 KiB
C
261 lines
9.9 KiB
C
|
/******************************************************************************
|
||
|
* *
|
||
|
* License Agreement *
|
||
|
* *
|
||
|
* Copyright (c) 2014 Altera Corporation, San Jose, California, USA. *
|
||
|
* All rights reserved. *
|
||
|
* *
|
||
|
* Permission is hereby granted, free of charge, to any person obtaining a *
|
||
|
* copy of this software and associated documentation files (the "Software"), *
|
||
|
* to deal in the Software without restriction, including without limitation *
|
||
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense, *
|
||
|
* and/or sell copies of the Software, and to permit persons to whom the *
|
||
|
* Software is furnished to do so, subject to the following conditions: *
|
||
|
* *
|
||
|
* The above copyright notice and this permission notice shall be included in *
|
||
|
* all copies or substantial portions of the Software. *
|
||
|
* *
|
||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR *
|
||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, *
|
||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE *
|
||
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER *
|
||
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING *
|
||
|
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER *
|
||
|
* DEALINGS IN THE SOFTWARE. *
|
||
|
* *
|
||
|
* This agreement shall be governed in all respects by the laws of the State *
|
||
|
* of California and by the laws of the United States of America. *
|
||
|
* *
|
||
|
******************************************************************************/
|
||
|
|
||
|
#ifndef __ALTERA_EPCQ_CONTROLLER_REGS_H__
|
||
|
#define __ALTERA_EPCQ_CONTROLLER_REGS_H__
|
||
|
|
||
|
#include <io.h>
|
||
|
|
||
|
/*
|
||
|
* EPCQ_RD_STATUS register offset
|
||
|
*
|
||
|
* The EPCQ_RD_STATUS register contains information from the read status
|
||
|
* register operation. A full description of the register can be found in the
|
||
|
* data sheet,
|
||
|
*
|
||
|
*/
|
||
|
#define ALTERA_EPCQ_CONTROLLER_STATUS_REG (0x0)
|
||
|
|
||
|
/*
|
||
|
* EPCQ_RD_STATUS register access macros
|
||
|
*/
|
||
|
#define IOADDR_ALTERA_EPCQ_CONTROLLER_STATUS(base) \
|
||
|
__IO_CALC_ADDRESS_DYNAMIC(base, ALTERA_EPCQ_CONTROLLER_STATUS_REG)
|
||
|
|
||
|
#define IORD_ALTERA_EPCQ_CONTROLLER_STATUS(base) \
|
||
|
IORD_32DIRECT(base, ALTERA_EPCQ_CONTROLLER_STATUS_REG)
|
||
|
|
||
|
#define IOWR_ALTERA_EPCQ_CONTROLLER_STATUS(base, data) \
|
||
|
IOWR_32DIRECT(base, ALTERA_EPCQ_CONTROLLER_STATUS_REG, data)
|
||
|
|
||
|
/*
|
||
|
* EPCQ_RD_STATUS register description macros
|
||
|
*/
|
||
|
|
||
|
/** Write in progress bit */
|
||
|
#define ALTERA_EPCQ_CONTROLLER_STATUS_WIP_MASK (0x00000001)
|
||
|
#define ALTERA_EPCQ_CONTROLLER_STATUS_WIP_AVAILABLE (0x00000000)
|
||
|
#define ALTERA_EPCQ_CONTROLLER_STATUS_WIP_BUSY (0x00000001)
|
||
|
/** When to time out a poll of the write in progress bit */
|
||
|
/* 0.7 sec time out */
|
||
|
#define ALTERA_EPCQ_CONTROLLER_1US_TIMEOUT_VALUE 700000
|
||
|
|
||
|
/*
|
||
|
* EPCQ_RD_SID register offset
|
||
|
*
|
||
|
* The EPCQ_RD_SID register contains the information from the read silicon ID
|
||
|
* operation and can be used to determine what type of EPCS device we have.
|
||
|
* Only support in EPCS16 and EPCS64.
|
||
|
*
|
||
|
* This register is valid only if the device is an EPCS.
|
||
|
*
|
||
|
*/
|
||
|
#define ALTERA_EPCQ_CONTROLLER_SID_REG (0x4)
|
||
|
|
||
|
/*
|
||
|
* EPCQ_RD_SID register access macros
|
||
|
*/
|
||
|
#define IOADDR_ALTERA_EPCQ_CONTROLLER_SID(base) \
|
||
|
__IO_CALC_ADDRESS_DYNAMIC(base, ALTERA_EPCQ_CONTROLLER_SID_REG)
|
||
|
|
||
|
#define IORD_ALTERA_EPCQ_CONTROLLER_SID(base) \
|
||
|
IORD_32DIRECT(base, ALTERA_EPCQ_CONTROLLER_SID_REG)
|
||
|
|
||
|
#define IOWR_ALTERA_EPCQ_CONTROLLER_SID(base, data) \
|
||
|
IOWR_32DIRECT(base, ALTERA_EPCQ_CONTROLLER_SID_REG, data)
|
||
|
|
||
|
/*
|
||
|
* EPCQ_RD_SID register description macros
|
||
|
*
|
||
|
* Specific device values obtained from Table 14 of:
|
||
|
* "Serial Configuration (EPCS) Devices Datasheet"
|
||
|
*/
|
||
|
#define ALTERA_EPCQ_CONTROLLER_SID_MASK (0x000000FF)
|
||
|
#define ALTERA_EPCQ_CONTROLLER_SID_EPCS16 (0x00000014)
|
||
|
#define ALTERA_EPCQ_CONTROLLER_SID_EPCS64 (0x00000016)
|
||
|
#define ALTERA_EPCQ_CONTROLLER_SID_EPCS128 (0x00000018)
|
||
|
|
||
|
/*
|
||
|
* EPCQ_RD_RDID register offset
|
||
|
*
|
||
|
* The EPCQ_RD_RDID register contains the information from the read memory
|
||
|
* capacity operation and can be used to determine what type of EPCQ device
|
||
|
* we have.
|
||
|
*
|
||
|
* This register is only valid if the device is an EPCQ.
|
||
|
*
|
||
|
*/
|
||
|
#define ALTERA_EPCQ_CONTROLLER_RDID_REG (0x8)
|
||
|
|
||
|
/*
|
||
|
* EPCQ_RD_RDID register access macros
|
||
|
*/
|
||
|
#define IOADDR_ALTERA_EPCQ_CONTROLLER_RDID(base) \
|
||
|
__IO_CALC_ADDRESS_DYNAMIC(base, ALTERA_EPCQ_CONTROLLER_RDID_REG)
|
||
|
|
||
|
#define IORD_ALTERA_EPCQ_CONTROLLER_RDID(base) \
|
||
|
IORD_32DIRECT(base, ALTERA_EPCQ_CONTROLLER_RDID_REG)
|
||
|
|
||
|
#define IOWR_ALTERA_EPCQ_CONTROLLER_RDID(base, data) \
|
||
|
IOWR_32DIRECT(base, ALTERA_EPCQ_CONTROLLER_RDID_REG, data)
|
||
|
|
||
|
/*
|
||
|
* EPCQ_RD_RDID register description macros
|
||
|
*
|
||
|
* Specific device values obtained from Table 28 of:
|
||
|
* "Quad-Serial Configuration (EPCQ (www.altera.com/literature/hb/cfg/cfg_cf52012.pdf))
|
||
|
* Devices Datasheet"
|
||
|
*/
|
||
|
#define ALTERA_EPCQ_CONTROLLER_RDID_MASK (0x000000FF)
|
||
|
#define ALTERA_EPCQ_CONTROLLER_RDID_EPCQ16 (0x00000015)
|
||
|
#define ALTERA_EPCQ_CONTROLLER_RDID_EPCQ32 (0x00000016)
|
||
|
#define ALTERA_EPCQ_CONTROLLER_RDID_EPCQ64 (0x00000017)
|
||
|
#define ALTERA_EPCQ_CONTROLLER_RDID_EPCQ128 (0x00000018)
|
||
|
#define ALTERA_EPCQ_CONTROLLER_RDID_EPCQ256 (0x00000019)
|
||
|
#define ALTERA_EPCQ_CONTROLLER_RDID_EPCQ512 (0x00000020)
|
||
|
#define ALTERA_EPCQ_CONTROLLER_RDID_EPCQ1024 (0x00000021)
|
||
|
|
||
|
/*
|
||
|
* EPCQ_MEM_OP register offset
|
||
|
*
|
||
|
* The EPCQ_MEM_OP register is used to do memory protect and erase operations
|
||
|
*
|
||
|
*/
|
||
|
#define ALTERA_EPCQ_CONTROLLER_MEM_OP_REG (0xC)
|
||
|
|
||
|
/*
|
||
|
* EPCQ_MEM_OP register access macros
|
||
|
*/
|
||
|
#define IOADDR_ALTERA_EPCQ_CONTROLLER_MEM_OP(base) \
|
||
|
__IO_CALC_ADDRESS_DYNAMIC(base, ALTERA_EPCQ_CONTROLLER_MEM_OP_REG)
|
||
|
|
||
|
#define IORD_ALTERA_EPCQ_CONTROLLER_MEM_OP(base) \
|
||
|
IORD_32DIRECT(base, ALTERA_EPCQ_CONTROLLER_MEM_OP_REG)
|
||
|
|
||
|
#define IOWR_ALTERA_EPCQ_CONTROLLER_MEM_OP(base, data) \
|
||
|
IOWR_32DIRECT(base, ALTERA_EPCQ_CONTROLLER_MEM_OP_REG, data)
|
||
|
|
||
|
/*
|
||
|
* EPCQ_MEM_OP register description macros
|
||
|
*/
|
||
|
#define ALTERA_EPCQ_CONTROLLER_MEM_OP_CMD_MASK (0x00000003)
|
||
|
#define ALTERA_EPCQ_CONTROLLER_MEM_OP_BULK_ERASE_CMD (0x00000001)
|
||
|
#define ALTERA_EPCQ_CONTROLLER_MEM_OP_SECTOR_ERASE_CMD (0x00000002)
|
||
|
#define ALTERA_EPCQ_CONTROLLER_MEM_OP_SECTOR_PROTECT_CMD (0x00000003)
|
||
|
|
||
|
/** see datasheet for sector values */
|
||
|
#define ALTERA_EPCQ_CONTROLLER_MEM_OP_SECTOR_VALUE_MASK (0x00FFFF00)
|
||
|
|
||
|
/*
|
||
|
* EPCQ_ISR register offset
|
||
|
*
|
||
|
* The EPCQ_ISR register is used to determine whether an invalid write or erase
|
||
|
* operation triggered an interrupt
|
||
|
*
|
||
|
*/
|
||
|
#define ALTERA_EPCQ_CONTROLLER_ISR_REG (0x10)
|
||
|
|
||
|
/*
|
||
|
* EPCQ_ISR register access macros
|
||
|
*/
|
||
|
#define IOADDR_ALTERA_EPCQ_CONTROLLER_ISR(base) \
|
||
|
__IO_CALC_ADDRESS_DYNAMIC(base, ALTERA_EPCQ_CONTROLLER_ISR_REG)
|
||
|
|
||
|
#define IORD_ALTERA_EPCQ_CONTROLLER_ISR(base) \
|
||
|
IORD_32DIRECT(base, ALTERA_EPCQ_CONTROLLER_ISR_REG)
|
||
|
|
||
|
#define IOWR_ALTERA_EPCQ_CONTROLLER_ISR(base, data) \
|
||
|
IOWR_32DIRECT(base, ALTERA_EPCQ_CONTROLLER_ISR_REG, data)
|
||
|
|
||
|
/*
|
||
|
* EPCQ_ISR register description macros
|
||
|
*/
|
||
|
#define ALTERA_EPCQ_CONTROLLER_ISR_ILLEGAL_ERASE_MASK (0x00000001)
|
||
|
#define ALTERA_EPCQ_CONTROLLER_ISR_ILLEGAL_ERASE_ACTIVE (0x00000001)
|
||
|
|
||
|
#define ALTERA_EPCQ_CONTROLLER_ISR_ILLEGAL_WRITE_MASK (0x00000002)
|
||
|
#define ALTERA_EPCQ_CONTROLLER_ISR_ILLEGAL_WRITE_ACTIVE (0x00000002)
|
||
|
|
||
|
|
||
|
/*
|
||
|
* EPCQ_IMR register offset
|
||
|
*
|
||
|
* The EPCQ_IMR register is used to mask the invalid erase or the invalid write
|
||
|
* interrupts.
|
||
|
*
|
||
|
*/
|
||
|
#define ALTERA_EPCQ_CONTROLLER_IMR_REG (0x14)
|
||
|
|
||
|
/*
|
||
|
* EPCQ_IMR register access macros
|
||
|
*/
|
||
|
#define IOADDR_ALTERA_EPCQ_CONTROLLER_IMR(base) \
|
||
|
__IO_CALC_ADDRESS_DYNAMIC(base, ALTERA_EPCQ_CONTROLLER_IMR_REG)
|
||
|
|
||
|
#define IORD_ALTERA_EPCQ_CONTROLLER_IMR(base) \
|
||
|
IORD_32DIRECT(base, ALTERA_EPCQ_CONTROLLER_IMR_REG)
|
||
|
|
||
|
#define IOWR_ALTERA_EPCQ_CONTROLLER_IMR(base, data) \
|
||
|
IOWR_32DIRECT(base, ALTERA_EPCQ_CONTROLLER_IMR_REG, data)
|
||
|
|
||
|
/*
|
||
|
* EPCQ_IMR register description macros
|
||
|
*/
|
||
|
#define ALTERA_EPCQ_CONTROLLER_IMR_ILLEGAL_ERASE_MASK (0x00000001)
|
||
|
#define ALTERA_EPCQ_CONTROLLER_IMR_ILLEGAL_ERASE_ENABLED (0x00000001)
|
||
|
|
||
|
#define ALTERA_EPCQ_CONTROLLER_IMR_ILLEGAL_WRITE_MASK (0x00000002)
|
||
|
#define ALTERA_EPCQ_CONTROLLER_IMR_ILLEGAL_WRITE_ENABLED (0x00000002)
|
||
|
|
||
|
/*
|
||
|
* EPCQ_CHIP_SELECT register offset
|
||
|
*
|
||
|
* The EPCQ_CHIP_SELECT register is used to issue chip select
|
||
|
*/
|
||
|
#define ALTERA_EPCQ_CHIP_SELECT_REG (0x18)
|
||
|
|
||
|
/*
|
||
|
* EPCQ_CHIP_SELECT register access macros
|
||
|
*/
|
||
|
#define IOADDR_ALTERA_EPCQ_CHIP_SELECT(base) \
|
||
|
__IO_CALC_ADDRESS_DYNAMIC(base, ALTERA_EPCQ_CHIP_SELECT_REG)
|
||
|
|
||
|
#define IOWR_ALTERA_EPCQ_CHIP_SELECT(base, data) \
|
||
|
IOWR_32DIRECT(base, ALTERA_EPCQ_CHIP_SELECT_REG, data)
|
||
|
|
||
|
/*
|
||
|
* EPCQ_CHIP_SELECT register description macros
|
||
|
*/
|
||
|
#define ALTERA_EPCQ_CHIP1_SELECT (0x00000001)
|
||
|
#define ALTERA_EPCQ_CHIP2_SELECT (0x00000002)
|
||
|
#define ALTERA_EPCQ_CHIP3_SELECT (0x00000003)
|
||
|
|
||
|
#endif /* __ALTERA_EPCQ_CONTROLLER_REGS_H__ */
|