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

📄 init.c

📁 wince底层驱动开发代码 ARM作为一种嵌入式系统处理器
💻 C
📖 第 1 页 / 共 2 页
字号:
		DEBUGMSG(1,
			(TEXT("PDCardInitServices CHIP_REVISION = 0x%x, expected = 0x83 !!!\r\n"), tmp));
		return CERR_BAD_ADAPTER;
	}

	// otput2card_disable, AUTO_POWER, VCC_POWER_OFF,Vpp1=0V
	PCICIndex(0, REG_POWER_CONTROL);
	PCICDataWrite((0<<7) | (1<<5) | (0<<4) | (0<<0));

	// INPACK_ignored,speak_enable,edge_irq_intr,edge_management_intr,nVCC_3_enabled(temp)
	PCICIndex(0, REG_GENERAL_CONTROL);

	// Management int, System int -> edge triggering(PULSE)  
//  PCICDataWrite(MISC1_VCC_33|MISC1_PM_IRQ|MISC1_PS_IRQ|MISC1_SPK_ENABLE);
	// Management int -> edge triggering(PULSE), System int -> LEVEL triggering 
	PCICDataWrite(MISC1_VCC_33|MISC1_PM_IRQ|MISC1_SPK_ENABLE);

	// 25Mhz_bypass,low_power_dynamic,IRQ12=drive_LED
	PCICIndex(0, REG_GLOBAL_CONTROL);
//  PCICDataWrite(MISC2_BFS|MISC2_LOW_POWER_MODE|MISC2_LED_ENABLE);
	PCICDataWrite(MISC2_LOW_POWER_MODE|MISC2_LED_ENABLE);
	
	// before configuring timing register, FIFO should be cleared.
	PCICIndex(0, REG_FIFO_CTRL);
	PCICDataWrite(FIFO_EMPTY_WRITE);    //Flush FIFO

	//default access time is 300ns
	PCICIndex(0, REG_SETUP_TIMING0);
	PCICDataWrite(5);                   //80ns(no spec)
	PCICIndex(0, REG_CMD_TIMING0);
	PCICDataWrite(20);                  //320ns(by spec,25Mhz clock)
	PCICIndex(0, REG_RECOVERY_TIMING0);
	PCICDataWrite(5);                   //80ns(no spec)

	//default access time is 300ns
	PCICIndex(0, REG_SETUP_TIMING1);
	PCICDataWrite(2);                   //80ns(no spec)
	PCICIndex(0, REG_CMD_TIMING1);
	PCICDataWrite(8);                   //320ns(by spec,25Mhz clock)
	PCICIndex(0, REG_RECOVERY_TIMING1);
	PCICDataWrite(2);                   //80ns(no spec)

	DEBUGMSG(1, (TEXT("InitSocketNoCard(0) is called\r\n")));
	InitSocketNoCard(0);
//  InitSocketNoCard(1);

	PCICIndex(0, REG_CHIP_REVISION);
	tmp = PCICDataRead();
	DEBUGMSG(1, (TEXT("PDCardInitServices REG_CHIP_REVISION = 0x%x\r\n"), tmp));

#ifdef DEBUG
	DumpSocketRegisters(0);
#endif


	DEBUGMSG (1,(TEXT("--PDCardInitServices\n\r")));

	return CERR_SUCCESS;

pcis_fail:
	if (v_pIOPRegs) {
		VirtualFree((LPVOID)v_pIOPRegs, 0, MEM_RELEASE);
	}
	if (v_pMEMRegs) {
		VirtualFree((LPVOID)v_pMEMRegs, 0, MEM_RELEASE);
	}
	if (v_pPCMCIAPort) {
		VirtualFree((LPVOID)v_pPCMCIAPort, 0, MEM_RELEASE);
	}

	return CERR_OUT_OF_RESOURCE;    
}


//
// Function to set the PCIC index register
//
VOID
PCICIndex(
	UINT socket_num,
	UINT8  register_num
	)
{
	WRITE_PORT_UCHAR(g_PCICIndex,
		(UINT8)((socket_num == 0 ? 0 : 0x40)|register_num));
}

//
// Function to write to the PCIC data register
//
VOID
PCICDataWrite(
	UINT8 value
	)
{
	WRITE_PORT_UCHAR(g_PCICData, value);
}

//
// Function to read the PCIC data register
//
UINT8
PCICDataRead(VOID)
{
	return READ_PORT_UCHAR(g_PCICData);
}

#ifdef DEBUG
UCHAR SocketRegisters[2][REG_LAST_INDEX+1];

LPWSTR RegisterNames[] = {
TEXT("REG_CHIP_REVISION"), //                    0x00
TEXT("REG_INTERFACE_STATUS"), //                 0x01
TEXT("REG_POWER_CONTROL"), //                    0x02
TEXT("REG_INTERRUPT_AND_GENERAL_CONTROL"), //    0x03
TEXT("REG_CARD_STATUS_CHANGE"), //               0x04
TEXT("REG_STATUS_CHANGE_INT_CONFIG"), //         0x05
TEXT("REG_WINDOW_ENABLE"), //                    0x06
TEXT("REG_IO_WINDOW_CONTROL"), //                0x07
TEXT("REG_IO_MAP0_START_ADDR_LO"), //            0x08
TEXT("REG_IO_MAP0_START_ADDR_HI"), //            0x09
TEXT("REG_IO_MAP0_END_ADDR_LO"), //              0x0A
TEXT("REG_IO_MAP0_END_ADDR_HI"), //              0x0B
TEXT("REG_IO_MAP1_START_ADDR_LO"), //            0x0C
TEXT("REG_IO_MAP1_START_ADDR_HI"), //            0x0D
TEXT("REG_IO_MAP1_END_ADDR_LO"), //              0x0E
TEXT("REG_IO_MAP1_END_ADDR_HI"), //              0x0F
TEXT("REG_MEM_MAP0_START_ADDR_LO"), //           0x10
TEXT("REG_MEM_MAP0_START_ADDR_HI"), //           0x11
TEXT("REG_MEM_MAP0_END_ADDR_LO"), //             0x12
TEXT("REG_MEM_MAP0_END_ADDR_HI"), //             0x13
TEXT("REG_MEM_MAP0_ADDR_OFFSET_LO"), //          0x14
TEXT("REG_MEM_MAP0_ADDR_OFFSET_HI"), //          0x15
TEXT("REG_GENERAL_CONTROL"), //                  0x16
TEXT("REG_FIFO_CTRL"), //                        0x17
TEXT("REG_MEM_MAP1_START_ADDR_LO"), //           0x18
TEXT("REG_MEM_MAP1_START_ADDR_HI"), //           0x19
TEXT("REG_MEM_MAP1_END_ADDR_LO"), //             0x1A
TEXT("REG_MEM_MAP1_END_ADDR_HI"), //             0x1B
TEXT("REG_MEM_MAP1_ADDR_OFFSET_LO"), //          0x1C
TEXT("REG_MEM_MAP1_ADDR_OFFSET_HI"), //          0x1D
TEXT("REG_GLOBAL_CONTROL"), //                   0x1E
TEXT("REG_CHIP_INFO"), //                        0x1F
TEXT("REG_MEM_MAP2_START_ADDR_LO"), //           0x20
TEXT("REG_MEM_MAP2_START_ADDR_HI"), //           0x21
TEXT("REG_MEM_MAP2_END_ADDR_LO"), //             0x22
TEXT("REG_MEM_MAP2_END_ADDR_HI"), //             0x23
TEXT("REG_MEM_MAP2_ADDR_OFFSET_LO"), //          0x24
TEXT("REG_MEM_MAP2_ADDR_OFFSET_HI"), //          0x25
TEXT("REG_ATA_CTRL"), //                         0x26
TEXT("REG_SCRATCHPAD"), //                       0x27
TEXT("REG_MEM_MAP3_START_ADDR_LO"), //           0x28
TEXT("REG_MEM_MAP3_START_ADDR_HI"), //           0x29
TEXT("REG_MEM_MAP3_END_ADDR_LO"), //             0x2A
TEXT("REG_MEM_MAP3_END_ADDR_HI"), //             0x2B
TEXT("REG_MEM_MAP3_ADDR_OFFSET_LO"), //          0x2C
TEXT("REG_MEM_MAP3_ADDR_OFFSET_HI"), //          0x2D
TEXT("REG_EXTENDED_INDEX"), //                   0x2E
TEXT("REG_EXTENDED_DATA"), //                    0x2F
TEXT("REG_MEM_MAP4_START_ADDR_LO"), //           0x30
TEXT("REG_MEM_MAP4_START_ADDR_HI"), //           0x31
TEXT("REG_MEM_MAP4_END_ADDR_LO"), //             0x32
TEXT("REG_MEM_MAP4_END_ADDR_HI"), //             0x33
TEXT("REG_MEM_MAP4_ADDR_OFFSET_LO"), //          0x34
TEXT("REG_MEM_MAP4_ADDR_OFFSET_HI"), //          0x35
TEXT("REG_CARD_IO_MAP0_OFFSET_L"), //            0x36
TEXT("REG_CARD_IO_MAP0_OFFSET_H"), //            0x37
TEXT("REG_CARD_IO_MAP1_OFFSET_L"), //            0x38
TEXT("REG_CARD_IO_MAP1_OFFSET_H"), //            0x39
TEXT("REG_SETUP_TIMING0"), //                    0x3A
TEXT("REG_CMD_TIMING0"), //                      0x3B
TEXT("REG_RECOVERY_TIMING0"), //                 0x3C
TEXT("REG_CMD_TIMING1"), //                      0x3D
TEXT("REG_CMD_TIMING1"), //                      0x3E
TEXT("REG_RECOVERY_TIMING1"), //                 0x3F
};


VOID
DisplaySocketRegister(
	UINT socket,
	UCHAR reg,
	UCHAR value
	)
{
	if (reg > (REG_LAST_INDEX+1)) return;

	if (RegisterNames[reg] != NULL) {
		DEBUGMSG(1,
			(TEXT("PCMCIA:PCIC Register[%d:%2x:%s] = 0x%x\r\n"),
			socket, reg, RegisterNames[reg & 0x3f], value));
	}
}


VOID
DumpSocketRegisters(
	UINT socket
	)
{
	UCHAR i;

    if (!DEBUGZONE(ZONE_PDD)) return;

	for (i = 0; i < REG_LAST_INDEX+1; i++) {
		PCICIndex(socket, i);
		SocketRegisters[socket][i] = PCICDataRead();
		DisplaySocketRegister(socket, i, SocketRegisters[socket][i]);
	}
}

VOID
DeltaSocketRegisters(
	UINT socket
	)
{
	static UCHAR idx;
	UCHAR CurrentRegisters[REG_LAST_INDEX];

    if (!DEBUGZONE(ZONE_PDD)) return;

	DEBUGMSG (1,(TEXT("++DeltaSocketRegisters #%x\n\r"), socket));

	for (idx = 0; idx < REG_LAST_INDEX+1; idx++) {
		PCICIndex(socket, idx);
		CurrentRegisters[idx] = PCICDataRead();
	}

	for (idx = 0; idx < REG_LAST_INDEX+1; idx++) {
		if (CurrentRegisters[idx] != SocketRegisters[socket][idx]) {
			DisplaySocketRegister(socket, idx, CurrentRegisters[idx]);
			SocketRegisters[socket][idx] = CurrentRegisters[idx];
		}
	}
	DEBUGMSG (1,(TEXT("--DeltaSocketRegisters\n\r")));
}
#endif  // DEBUG

⌨️ 快捷键说明

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