⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 aic94xx_seq.c

📁 linux 内核源代码
💻 C
📖 第 1 页 / 共 4 页
字号:
		0,		0xFFFF,		  /* mode 4/5 */		0xFFFF,		  /* mode 4/5 */	};	/*	 * Mode 0,1,2 and 4/5 have common field on page 0 for the first	 * 14 bytes.	 */	for (i = 0; i < 3; i++) {		moffs = i * LSEQ_MODE_SCRATCH_SIZE;		asd_write_reg_word(asd_ha, LmSEQ_RET_ADDR(lseq)+moffs,				   ret_addr[i]);		asd_write_reg_word(asd_ha, LmSEQ_REG0_MODE(lseq)+moffs, 0);		asd_write_reg_word(asd_ha, LmSEQ_MODE_FLAGS(lseq)+moffs, 0);		asd_write_reg_word(asd_ha, LmSEQ_RET_ADDR2(lseq)+moffs,0xFFFF);		asd_write_reg_word(asd_ha, LmSEQ_RET_ADDR1(lseq)+moffs,0xFFFF);		asd_write_reg_byte(asd_ha, LmSEQ_OPCODE_TO_CSEQ(lseq)+moffs,0);		asd_write_reg_word(asd_ha, LmSEQ_DATA_TO_CSEQ(lseq)+moffs,0);	}	/*	 *  Mode 5 page 0 overlaps the same scratch page with Mode 0 page 3.	 */	asd_write_reg_word(asd_ha,			 LmSEQ_RET_ADDR(lseq)+LSEQ_MODE5_PAGE0_OFFSET,			   ret_addr[5]);	asd_write_reg_word(asd_ha,			 LmSEQ_REG0_MODE(lseq)+LSEQ_MODE5_PAGE0_OFFSET,0);	asd_write_reg_word(asd_ha,			 LmSEQ_MODE_FLAGS(lseq)+LSEQ_MODE5_PAGE0_OFFSET, 0);	asd_write_reg_word(asd_ha,			 LmSEQ_RET_ADDR2(lseq)+LSEQ_MODE5_PAGE0_OFFSET,0xFFFF);	asd_write_reg_word(asd_ha,			 LmSEQ_RET_ADDR1(lseq)+LSEQ_MODE5_PAGE0_OFFSET,0xFFFF);	asd_write_reg_byte(asd_ha,		         LmSEQ_OPCODE_TO_CSEQ(lseq)+LSEQ_MODE5_PAGE0_OFFSET,0);	asd_write_reg_word(asd_ha,		         LmSEQ_DATA_TO_CSEQ(lseq)+LSEQ_MODE5_PAGE0_OFFSET, 0);	/* LSEQ Mode dependent 0, page 0 setup. */	asd_write_reg_word(asd_ha, LmSEQ_FIRST_INV_DDB_SITE(lseq),			   (u16)asd_ha->hw_prof.max_ddbs);	asd_write_reg_word(asd_ha, LmSEQ_EMPTY_TRANS_CTX(lseq), 0);	asd_write_reg_word(asd_ha, LmSEQ_RESP_LEN(lseq), 0);	asd_write_reg_word(asd_ha, LmSEQ_FIRST_INV_SCB_SITE(lseq),			   (u16)last_scb_site_no+1);	asd_write_reg_word(asd_ha, LmSEQ_INTEN_SAVE(lseq),			    (u16) ((LmM0INTEN_MASK & 0xFFFF0000) >> 16));	asd_write_reg_word(asd_ha, LmSEQ_INTEN_SAVE(lseq) + 2,			    (u16) LmM0INTEN_MASK & 0xFFFF);	asd_write_reg_byte(asd_ha, LmSEQ_LINK_RST_FRM_LEN(lseq), 0);	asd_write_reg_byte(asd_ha, LmSEQ_LINK_RST_PROTOCOL(lseq), 0);	asd_write_reg_byte(asd_ha, LmSEQ_RESP_STATUS(lseq), 0);	asd_write_reg_byte(asd_ha, LmSEQ_LAST_LOADED_SGE(lseq), 0);	asd_write_reg_word(asd_ha, LmSEQ_SAVE_SCBPTR(lseq), 0);	/* LSEQ mode dependent, mode 1, page 0 setup. */	asd_write_reg_word(asd_ha, LmSEQ_Q_XMIT_HEAD(lseq), 0xFFFF);	asd_write_reg_word(asd_ha, LmSEQ_M1_EMPTY_TRANS_CTX(lseq), 0);	asd_write_reg_word(asd_ha, LmSEQ_INI_CONN_TAG(lseq), 0);	asd_write_reg_byte(asd_ha, LmSEQ_FAILED_OPEN_STATUS(lseq), 0);	asd_write_reg_byte(asd_ha, LmSEQ_XMIT_REQUEST_TYPE(lseq), 0);	asd_write_reg_byte(asd_ha, LmSEQ_M1_RESP_STATUS(lseq), 0);	asd_write_reg_byte(asd_ha, LmSEQ_M1_LAST_LOADED_SGE(lseq), 0);	asd_write_reg_word(asd_ha, LmSEQ_M1_SAVE_SCBPTR(lseq), 0);	/* LSEQ Mode dependent mode 2, page 0 setup */	asd_write_reg_word(asd_ha, LmSEQ_PORT_COUNTER(lseq), 0);	asd_write_reg_word(asd_ha, LmSEQ_PM_TABLE_PTR(lseq), 0);	asd_write_reg_word(asd_ha, LmSEQ_SATA_INTERLOCK_TMR_SAVE(lseq), 0);	asd_write_reg_word(asd_ha, LmSEQ_IP_BITL(lseq), 0);	asd_write_reg_word(asd_ha, LmSEQ_COPY_SMP_CONN_TAG(lseq), 0);	asd_write_reg_byte(asd_ha, LmSEQ_P0M2_OFFS1AH(lseq), 0);	/* LSEQ Mode dependent, mode 4/5, page 0 setup. */	asd_write_reg_byte(asd_ha, LmSEQ_SAVED_OOB_STATUS(lseq), 0);	asd_write_reg_byte(asd_ha, LmSEQ_SAVED_OOB_MODE(lseq), 0);	asd_write_reg_word(asd_ha, LmSEQ_Q_LINK_HEAD(lseq), 0xFFFF);	asd_write_reg_byte(asd_ha, LmSEQ_LINK_RST_ERR(lseq), 0);	asd_write_reg_byte(asd_ha, LmSEQ_SAVED_OOB_SIGNALS(lseq), 0);	asd_write_reg_byte(asd_ha, LmSEQ_SAS_RESET_MODE(lseq), 0);	asd_write_reg_byte(asd_ha, LmSEQ_LINK_RESET_RETRY_COUNT(lseq), 0);	asd_write_reg_byte(asd_ha, LmSEQ_NUM_LINK_RESET_RETRIES(lseq), 0);	asd_write_reg_word(asd_ha, LmSEQ_OOB_INT_ENABLES(lseq), 0);	/*	 * Set the desired interval between transmissions of the NOTIFY	 * (ENABLE SPINUP) primitive.  Must be initilized to val - 1.	 */	asd_write_reg_word(asd_ha, LmSEQ_NOTIFY_TIMER_TIMEOUT(lseq),			   ASD_NOTIFY_TIMEOUT - 1);	/* No delay for the first NOTIFY to be sent to the attached target. */	asd_write_reg_word(asd_ha, LmSEQ_NOTIFY_TIMER_DOWN_COUNT(lseq),			   ASD_NOTIFY_DOWN_COUNT);	asd_write_reg_word(asd_ha, LmSEQ_NOTIFY_TIMER_INITIAL_COUNT(lseq),			   ASD_NOTIFY_DOWN_COUNT);	/* LSEQ Mode dependent, mode 0 and 1, page 1 setup. */	for (i = 0; i < 2; i++)	{		int j;		/* Start from Page 1 of Mode 0 and 1. */		moffs = LSEQ_PAGE_SIZE + i*LSEQ_MODE_SCRATCH_SIZE;		/* All the fields of page 1 can be intialized to 0. */		for (j = 0; j < LSEQ_PAGE_SIZE; j += 4)			asd_write_reg_dword(asd_ha, LmSCRATCH(lseq)+moffs+j,0);	}	/* LSEQ Mode dependent, mode 2, page 1 setup. */	asd_write_reg_dword(asd_ha, LmSEQ_INVALID_DWORD_COUNT(lseq), 0);	asd_write_reg_dword(asd_ha, LmSEQ_DISPARITY_ERROR_COUNT(lseq), 0);	asd_write_reg_dword(asd_ha, LmSEQ_LOSS_OF_SYNC_COUNT(lseq), 0);	/* LSEQ Mode dependent, mode 4/5, page 1. */	for (i = 0; i < LSEQ_PAGE_SIZE; i+=4)		asd_write_reg_dword(asd_ha, LmSEQ_FRAME_TYPE_MASK(lseq)+i, 0);	asd_write_reg_byte(asd_ha, LmSEQ_FRAME_TYPE_MASK(lseq), 0xFF);	asd_write_reg_byte(asd_ha, LmSEQ_HASHED_DEST_ADDR_MASK(lseq), 0xFF);	asd_write_reg_byte(asd_ha, LmSEQ_HASHED_DEST_ADDR_MASK(lseq)+1,0xFF);	asd_write_reg_byte(asd_ha, LmSEQ_HASHED_DEST_ADDR_MASK(lseq)+2,0xFF);	asd_write_reg_byte(asd_ha, LmSEQ_HASHED_SRC_ADDR_MASK(lseq), 0xFF);	asd_write_reg_byte(asd_ha, LmSEQ_HASHED_SRC_ADDR_MASK(lseq)+1, 0xFF);	asd_write_reg_byte(asd_ha, LmSEQ_HASHED_SRC_ADDR_MASK(lseq)+2, 0xFF);	asd_write_reg_dword(asd_ha, LmSEQ_DATA_OFFSET(lseq), 0xFFFFFFFF);	/* LSEQ Mode dependent, mode 0, page 2 setup. */	asd_write_reg_dword(asd_ha, LmSEQ_SMP_RCV_TIMER_TERM_TS(lseq), 0);	asd_write_reg_byte(asd_ha, LmSEQ_DEVICE_BITS(lseq), 0);	asd_write_reg_word(asd_ha, LmSEQ_SDB_DDB(lseq), 0);	asd_write_reg_byte(asd_ha, LmSEQ_SDB_NUM_TAGS(lseq), 0);	asd_write_reg_byte(asd_ha, LmSEQ_SDB_CURR_TAG(lseq), 0);	/* LSEQ Mode Dependent 1, page 2 setup. */	asd_write_reg_dword(asd_ha, LmSEQ_TX_ID_ADDR_FRAME(lseq), 0);	asd_write_reg_dword(asd_ha, LmSEQ_TX_ID_ADDR_FRAME(lseq)+4, 0);	asd_write_reg_dword(asd_ha, LmSEQ_OPEN_TIMER_TERM_TS(lseq), 0);	asd_write_reg_dword(asd_ha, LmSEQ_SRST_AS_TIMER_TERM_TS(lseq), 0);	asd_write_reg_dword(asd_ha, LmSEQ_LAST_LOADED_SG_EL(lseq), 0);	/* LSEQ Mode Dependent 2, page 2 setup. */	/* The LmSEQ_STP_SHUTDOWN_TIMER_TERM_TS is IGNORED by the sequencer,	 * i.e. always 0. */	asd_write_reg_dword(asd_ha, LmSEQ_STP_SHUTDOWN_TIMER_TERM_TS(lseq),0);	asd_write_reg_dword(asd_ha, LmSEQ_CLOSE_TIMER_TERM_TS(lseq), 0);	asd_write_reg_dword(asd_ha, LmSEQ_BREAK_TIMER_TERM_TS(lseq), 0);	asd_write_reg_dword(asd_ha, LmSEQ_DWS_RESET_TIMER_TERM_TS(lseq), 0);	asd_write_reg_dword(asd_ha,LmSEQ_SATA_INTERLOCK_TIMER_TERM_TS(lseq),0);	asd_write_reg_dword(asd_ha, LmSEQ_MCTL_TIMER_TERM_TS(lseq), 0);	/* LSEQ Mode Dependent 4/5, page 2 setup. */	asd_write_reg_dword(asd_ha, LmSEQ_COMINIT_TIMER_TERM_TS(lseq), 0);	asd_write_reg_dword(asd_ha, LmSEQ_RCV_ID_TIMER_TERM_TS(lseq), 0);	asd_write_reg_dword(asd_ha, LmSEQ_RCV_FIS_TIMER_TERM_TS(lseq), 0);	asd_write_reg_dword(asd_ha, LmSEQ_DEV_PRES_TIMER_TERM_TS(lseq),	0);}/** * asd_init_lseq_scratch -- setup and init link sequencers * @asd_ha: pointer to host adapter struct */static void asd_init_lseq_scratch(struct asd_ha_struct *asd_ha){	u8 lseq;	u8 lseq_mask;	lseq_mask = asd_ha->hw_prof.enabled_phys;	for_each_sequencer(lseq_mask, lseq_mask, lseq) {		asd_init_lseq_mip(asd_ha, lseq);		asd_init_lseq_mdp(asd_ha, lseq);	}}/** * asd_init_scb_sites -- initialize sequencer SCB sites (memory). * @asd_ha: pointer to host adapter structure * * This should be done before initializing common CSEQ and LSEQ * scratch since those areas depend on some computed values here, * last_scb_site_no, etc. */static void asd_init_scb_sites(struct asd_ha_struct *asd_ha){	u16	site_no;	u16     max_scbs = 0;	for (site_no = asd_ha->hw_prof.max_scbs-1;	     site_no != (u16) -1;	     site_no--) {		u16	i;		/* Initialize all fields in the SCB site to 0. */		for (i = 0; i < ASD_SCB_SIZE; i += 4)			asd_scbsite_write_dword(asd_ha, site_no, i, 0);		/* Initialize SCB Site Opcode field to invalid. */		asd_scbsite_write_byte(asd_ha, site_no,				       offsetof(struct scb_header, opcode),				       0xFF);		/* Initialize SCB Site Flags field to mean a response		 * frame has been received.  This means inadvertent		 * frames received to be dropped. */		asd_scbsite_write_byte(asd_ha, site_no, 0x49, 0x01);		/* Workaround needed by SEQ to fix a SATA issue is to exclude		 * certain SCB sites from the free list. */		if (!SCB_SITE_VALID(site_no))			continue;		if (last_scb_site_no == 0)			last_scb_site_no = site_no;		/* For every SCB site, we need to initialize the		 * following fields: Q_NEXT, SCB_OPCODE, SCB_FLAGS,		 * and SG Element Flag. */		/* Q_NEXT field of the last SCB is invalidated. */		asd_scbsite_write_word(asd_ha, site_no, 0, first_scb_site_no);		first_scb_site_no = site_no;		max_scbs++;	}	asd_ha->hw_prof.max_scbs = max_scbs;	ASD_DPRINTK("max_scbs:%d\n", asd_ha->hw_prof.max_scbs);	ASD_DPRINTK("first_scb_site_no:0x%x\n", first_scb_site_no);	ASD_DPRINTK("last_scb_site_no:0x%x\n", last_scb_site_no);}/** * asd_init_cseq_cio - initialize CSEQ CIO registers * @asd_ha: pointer to host adapter structure */static void asd_init_cseq_cio(struct asd_ha_struct *asd_ha){	int i;	asd_write_reg_byte(asd_ha, CSEQCOMINTEN, 0);	asd_write_reg_byte(asd_ha, CSEQDLCTL, ASD_DL_SIZE_BITS);	asd_write_reg_byte(asd_ha, CSEQDLOFFS, 0);	asd_write_reg_byte(asd_ha, CSEQDLOFFS+1, 0);	asd_ha->seq.scbpro = 0;	asd_write_reg_dword(asd_ha, SCBPRO, 0);	asd_write_reg_dword(asd_ha, CSEQCON, 0);	/* Intialize CSEQ Mode 11 Interrupt Vectors.	 * The addresses are 16 bit wide and in dword units.	 * The values of their macros are in byte units.	 * Thus we have to divide by 4. */	asd_write_reg_word(asd_ha, CM11INTVEC0, cseq_vecs[0]);	asd_write_reg_word(asd_ha, CM11INTVEC1, cseq_vecs[1]);	asd_write_reg_word(asd_ha, CM11INTVEC2, cseq_vecs[2]);	/* Enable ARP2HALTC (ARP2 Halted from Halt Code Write). */	asd_write_reg_byte(asd_ha, CARP2INTEN, EN_ARP2HALTC);	/* Initialize CSEQ Scratch Page to 0x04. */	asd_write_reg_byte(asd_ha, CSCRATCHPAGE, 0x04);	/* Initialize CSEQ Mode[0-8] Dependent registers. */	/* Initialize Scratch Page to 0. */	for (i = 0; i < 9; i++)		asd_write_reg_byte(asd_ha, CMnSCRATCHPAGE(i), 0);	/* Reset the ARP2 Program Count. */	asd_write_reg_word(asd_ha, CPRGMCNT, cseq_idle_loop);	for (i = 0; i < 8; i++) {		/* Intialize Mode n Link m Interrupt Enable. */		asd_write_reg_dword(asd_ha, CMnINTEN(i), EN_CMnRSPMBXF);		/* Initialize Mode n Request Mailbox. */		asd_write_reg_dword(asd_ha, CMnREQMBX(i), 0);	}}/** * asd_init_lseq_cio -- initialize LmSEQ CIO registers * @asd_ha: pointer to host adapter structure */static void asd_init_lseq_cio(struct asd_ha_struct *asd_ha, int lseq){	u8  *sas_addr;	int  i;	/* Enable ARP2HALTC (ARP2 Halted from Halt Code Write). */	asd_write_reg_dword(asd_ha, LmARP2INTEN(lseq), EN_ARP2HALTC);	asd_write_reg_byte(asd_ha, LmSCRATCHPAGE(lseq), 0);	/* Initialize Mode 0,1, and 2 SCRATCHPAGE to 0. */	for (i = 0; i < 3; i++)		asd_write_reg_byte(asd_ha, LmMnSCRATCHPAGE(lseq, i), 0);	/* Initialize Mode 5 SCRATCHPAGE to 0. */	asd_write_reg_byte(asd_ha, LmMnSCRATCHPAGE(lseq, 5), 0);	asd_write_reg_dword(asd_ha, LmRSPMBX(lseq), 0);	/* Initialize Mode 0,1,2 and 5 Interrupt Enable and	 * Interrupt registers. */	asd_write_reg_dword(asd_ha, LmMnINTEN(lseq, 0), LmM0INTEN_MASK);	asd_write_reg_dword(asd_ha, LmMnINT(lseq, 0), 0xFFFFFFFF);	/* Mode 1 */	asd_write_reg_dword(asd_ha, LmMnINTEN(lseq, 1), LmM1INTEN_MASK);	asd_write_reg_dword(asd_ha, LmMnINT(lseq, 1), 0xFFFFFFFF);	/* Mode 2 */	asd_write_reg_dword(asd_ha, LmMnINTEN(lseq, 2), LmM2INTEN_MASK);	asd_write_reg_dword(asd_ha, LmMnINT(lseq, 2), 0xFFFFFFFF);	/* Mode 5 */	asd_write_reg_dword(asd_ha, LmMnINTEN(lseq, 5), LmM5INTEN_MASK);	asd_write_reg_dword(asd_ha, LmMnINT(lseq, 5), 0xFFFFFFFF);	/* Enable HW Timer status. */	asd_write_reg_byte(asd_ha, LmHWTSTATEN(lseq), LmHWTSTATEN_MASK);	/* Enable Primitive Status 0 and 1. */	asd_write_reg_dword(asd_ha, LmPRIMSTAT0EN(lseq), LmPRIMSTAT0EN_MASK);	asd_write_reg_dword(asd_ha, LmPRIMSTAT1EN(lseq), LmPRIMSTAT1EN_MASK);	/* Enable Frame Error. */	asd_write_reg_dword(asd_ha, LmFRMERREN(lseq), LmFRMERREN_MASK);	asd_write_reg_byte(asd_ha, LmMnHOLDLVL(lseq, 0), 0x50);	/* Initialize Mode 0 Transfer Level to 512. */	asd_write_reg_byte(asd_ha,  LmMnXFRLVL(lseq, 0), LmMnXFRLVL_512);	/* Initialize Mode 1 Transfer Level to 256. */	asd_write_reg_byte(asd_ha, LmMnXFRLVL(lseq, 1), LmMnXFRLVL_256);	/* Initialize Program Count. */	asd_write_reg_word(asd_ha, LmPRGMCNT(lseq), lseq_idle_loop);	/* Enable Blind SG Move. */	asd_write_reg_dword(asd_ha, LmMODECTL(lseq), LmBLIND48);	asd_write_reg_word(asd_ha, LmM3SATATIMER(lseq),			   ASD_SATA_INTERLOCK_TIMEOUT);	(void) asd_read_reg_dword(asd_ha, LmREQMBX(lseq));	/* Clear Primitive Status 0 and 1. */	asd_write_reg_dword(asd_ha, LmPRMSTAT0(lseq), 0xFFFFFFFF);	asd_write_reg_dword(asd_ha, LmPRMSTAT1(lseq), 0xFFFFFFFF);	/* Clear HW Timer status. */	asd_write_reg_byte(asd_ha, LmHWTSTAT(lseq), 0xFF);	/* Clear DMA Errors for Mode 0 and 1. */	asd_write_reg_byte(asd_ha, LmMnDMAERRS(lseq, 0), 0xFF);	asd_write_reg_byte(asd_ha, LmMnDMAERRS(lseq, 1), 0xFF);	/* Clear SG DMA Errors for Mode 0 and 1. */	asd_write_reg_byte(asd_ha, LmMnSGDMAERRS(lseq, 0), 0xFF);	asd_write_reg_byte(asd_ha, LmMnSGDMAERRS(lseq, 1), 0xFF);	/* Clear Mode 0 Buffer Parity Error. */	asd_write_reg_byte(asd_ha, LmMnBUFSTAT(lseq, 0), LmMnBUFPERR);	/* Clear Mode 0 Frame Error register. */	asd_write_reg_dword(asd_ha, LmMnFRMERR(lseq, 0), 0xFFFFFFFF);	/* Reset LSEQ external interrupt arbiter. */	asd_write_reg_byte(asd_ha, LmARP2INTCTL(lseq), RSTINTCTL);	/* Set the Phy SAS for the LmSEQ WWN. */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -