- FSMC_NANDInitTypeDef FSMC_NANDInitStructure;
- FSMC_NAND_PCCARDTimingInitTypeDef p;
- /* Enable GPIOs clock */
- RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOD | RCC_AHB1Periph_GPIOE , ENABLE);
- RCC_APB2PeriphClockCmd(RCC_APB2Periph_SYSCFG, ENABLE);
-
- // RCC_AHBPeriphClockCmd(RCC_AHBPeriph_FSMC, ENABLE);//2013年7月7日12:10:51屏蔽 in STM32F105RB Let compiler happy
- RCC_AHB3PeriphClockCmd(RCC_AHB3Periph_FSMC, ENABLE);
- /*-- GPIO Configuration ------------------------------------------------------*/
-
- GPIO_PinAFConfig(GPIOD, GPIO_PinSource0, GPIO_AF_FSMC);
- GPIO_PinAFConfig(GPIOD, GPIO_PinSource1, GPIO_AF_FSMC);
- GPIO_PinAFConfig(GPIOD, GPIO_PinSource14, GPIO_AF_FSMC);
- GPIO_PinAFConfig(GPIOD, GPIO_PinSource15, GPIO_AF_FSMC);
-
- GPIO_PinAFConfig(GPIOE, GPIO_PinSource7, GPIO_AF_FSMC);
- GPIO_PinAFConfig(GPIOE, GPIO_PinSource8, GPIO_AF_FSMC);
- GPIO_PinAFConfig(GPIOE, GPIO_PinSource9, GPIO_AF_FSMC);
- GPIO_PinAFConfig(GPIOE, GPIO_PinSource10, GPIO_AF_FSMC);
-
- GPIO_PinAFConfig(GPIOD, GPIO_PinSource4, GPIO_AF_FSMC);
- GPIO_PinAFConfig(GPIOD, GPIO_PinSource5, GPIO_AF_FSMC);
- GPIO_PinAFConfig(GPIOD, GPIO_PinSource6, GPIO_AF_FSMC);
- GPIO_PinAFConfig(GPIOD, GPIO_PinSource7, GPIO_AF_FSMC);
- GPIO_PinAFConfig(GPIOD, GPIO_PinSource11, GPIO_AF_FSMC);
- GPIO_PinAFConfig(GPIOD, GPIO_PinSource12, GPIO_AF_FSMC);
-
- /* CLE, ALE, D0->D3, NOE, NWE and NCE2 NAND pin configuration */
- GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
- GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;
- GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
- GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;
- GPIO_InitStructure.GPIO_Pin = GPIO_Pin_14 | GPIO_Pin_15 | GPIO_Pin_0 | GPIO_Pin_1 ;
- GPIO_Init(GPIOD, &GPIO_InitStructure);
- /* D4->D7 NAND pin configuration */
- GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7 | GPIO_Pin_8 | GPIO_Pin_9 | GPIO_Pin_10;
- GPIO_Init(GPIOE, &GPIO_InitStructure);
-
- // GPIO_PinAFConfig(GPIOD, GPIO_PinSource4, GPIO_AF_FSMC);
- // GPIO_PinAFConfig(GPIOD, GPIO_PinSource5, GPIO_AF_FSMC);
- GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4 | GPIO_Pin_5;
- GPIO_Init(GPIOD, &GPIO_InitStructure);
- /* ALE and CLE configuration */
- // GPIO_PinAFConfig(GPIOD,GPIO_PinSource11, GPIO_AF_FSMC);
- // GPIO_PinAFConfig(GPIOD,GPIO_PinSource12, GPIO_AF_FSMC);
- GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11 | GPIO_Pin_12;
- GPIO_Init(GPIOD, &GPIO_InitStructure);
-
- /* NE1 configuration */
- // GPIO_PinAFConfig(GPIOD, GPIO_PinSource7, GPIO_AF_FSMC);
- GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7;
- GPIO_Init(GPIOD, &GPIO_InitStructure);
- /* NWAIT Configuration */
- // GPIO_PinAFConfig(GPIOD,GPIO_PinSource6, GPIO_AF_FSMC);
- /* NWAIT NAND pin configuration */
- GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6;
- GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;
- GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;
- GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;
- GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
- GPIO_Init(GPIOD, &GPIO_InitStructure);
-
- /* INT2 NAND pin configuration */
- // GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6; //在100脚的407上没用到该管脚
- // GPIO_Init(GPIOG, &GPIO_InitStructure); //
- /*-- FSMC Configuration ------------------------------------------------------*/
- p.FSMC_SetupTime = 0x1;//2013年7月19日18:29:14,jack.li
- p.FSMC_WaitSetupTime = 0x3;
- p.FSMC_HoldSetupTime = 0x2;
- p.FSMC_HiZSetupTime = 0x1;
- FSMC_NANDInitStructure.FSMC_Bank = FSMC_Bank2_NAND;
- FSMC_NANDInitStructure.FSMC_Waitfeature = FSMC_Waitfeature_Disable;
- FSMC_NANDInitStructure.FSMC_MemoryDataWidth = FSMC_MemoryDataWidth_8b;
- FSMC_NANDInitStructure.FSMC_ECC = FSMC_ECC_Enable;
- FSMC_NANDInitStructure.FSMC_ECCPageSize = FSMC_ECCPageSize_512Bytes;
- //FSMC_NANDInitStructure.FSMC_AddressLowMapping = FSMC_AddressLowMapping_Direct;//2013年7月6日21:16:52屏蔽,在STM32F105RB上没有该结构体内容//在407上同样需要屏蔽
- FSMC_NANDInitStructure.FSMC_TCLRSetupTime = 0x00;
- FSMC_NANDInitStructure.FSMC_TARSetupTime = 0x00;
- FSMC_NANDInitStructure.FSMC_CommonSpaceTimingStruct = &p;
- FSMC_NANDInitStructure.FSMC_AttributeSpaceTimingStruct = &p;
- FSMC_NANDInit(&FSMC_NANDInitStructure);
- /* FSMC NAND Bank Cmd Test */
- FSMC_NANDCmd(FSMC_Bank2_NAND, ENABLE);
- /* Enables the FSMC NAND ECC feature */
- FSMC_NANDECCCmd(FSMC_Bank2_NAND, ENABLE);