Apply SBI/CBI/TEST in HAL
This commit is contained in:
		| @@ -117,7 +117,7 @@ void HAL_init() { | ||||
|     PinCfg.Pinmode = 2;    // no pull-up/pull-down | ||||
|     PINSEL_ConfigPin(&PinCfg); | ||||
|     // now set CLKOUT_EN bit | ||||
|     LPC_SC->CLKOUTCFG |= (1<<8); | ||||
|     SBI(LPC_SC->CLKOUTCFG, 8); | ||||
|   #endif | ||||
|  | ||||
|   USB_Init();                               // USB Initialization | ||||
|   | ||||
| @@ -71,8 +71,8 @@ static void TXBegin() { | ||||
|       volatile uint32_t ICER[32]; | ||||
|     }; | ||||
|  | ||||
|     NVICMin * nvicBase = (NVICMin*)0xE000E100; | ||||
|     nvicBase->ICER[nvicIndex / 32] |= _BV32(nvicIndex % 32); | ||||
|     NVICMin *nvicBase = (NVICMin*)0xE000E100; | ||||
|     SBI32(nvicBase->ICER[nvicIndex >> 5], nvicIndex & 0x1F); | ||||
|  | ||||
|     // We NEED memory barriers to ensure Interrupts are actually disabled! | ||||
|     // ( https://dzone.com/articles/nvic-disabling-interrupts-on-arm-cortex-m-and-the ) | ||||
|   | ||||
| @@ -45,7 +45,6 @@ | ||||
| #define SDRAM_MODEREG_WRITEBURST_MODE_PROGRAMMED ((uint16_t)0x0000) | ||||
| #define SDRAM_MODEREG_WRITEBURST_MODE_SINGLE     ((uint16_t)0x0200) | ||||
|  | ||||
|  | ||||
| void SDRAM_Initialization_Sequence(SDRAM_HandleTypeDef *hsdram, FMC_SDRAM_CommandTypeDef *Command) { | ||||
|  | ||||
|   __IO uint32_t tmpmrd =0; | ||||
| @@ -192,7 +191,7 @@ void LTDC_Config() { | ||||
|  | ||||
|   hltdc_F.Instance = LTDC; | ||||
|  | ||||
| /* Layer0 Configuration ------------------------------------------------------*/ | ||||
|   /* Layer0 Configuration ------------------------------------------------------*/ | ||||
|  | ||||
|   /* Windowing configuration */ | ||||
|   pLayerCfg.WindowX0 = 0; | ||||
| @@ -289,22 +288,21 @@ void TFT_LTDC::DrawRect(uint16_t sx, uint16_t sy, uint16_t ex, uint16_t ey, uint | ||||
|   uint16_t offline = TFT_WIDTH - (ex - sx); | ||||
|   uint32_t addr = (uint32_t)&framebuffer[(TFT_WIDTH * sy) + sx]; | ||||
|  | ||||
|   DMA2D->CR &= ~(1 << 0); | ||||
|   CBI(DMA2D->CR, 0); | ||||
|   DMA2D->CR = 3 << 16; | ||||
|   DMA2D->OPFCCR = 0X02; | ||||
|   DMA2D->OOR = offline; | ||||
|   DMA2D->OMAR = addr; | ||||
|   DMA2D->NLR = (ey - sy) | ((ex - sx) << 16); | ||||
|   DMA2D->OCOLR = color; | ||||
|   DMA2D->CR |= 1<<0; | ||||
|   SBI(DMA2D->CR, 0); | ||||
|  | ||||
|   uint32_t timeout = 0; | ||||
|   while((DMA2D->ISR & (1<<1)) == 0) | ||||
|   { | ||||
|   while (!TEST(DMA2D->ISR, 1)) { | ||||
|     timeout++; | ||||
|     if(timeout>0X1FFFFF)break; | ||||
|     if (timeout > 0x1FFFFF) break; | ||||
|   } | ||||
|   DMA2D->IFCR |= 1<<1; | ||||
|   SBI(DMA2D->IFCR, 1); | ||||
| } | ||||
|  | ||||
| void TFT_LTDC::DrawImage(uint16_t sx, uint16_t sy, uint16_t ex, uint16_t ey, uint16_t *colors) { | ||||
| @@ -314,7 +312,7 @@ void TFT_LTDC::DrawImage(uint16_t sx, uint16_t sy, uint16_t ex, uint16_t ey, uin | ||||
|   uint16_t offline = TFT_WIDTH - (ex - sx); | ||||
|   uint32_t addr = (uint32_t)&framebuffer[(TFT_WIDTH * sy) + sx]; | ||||
|  | ||||
|   DMA2D->CR &= ~(1 << 0); | ||||
|   CBI(DMA2D->CR, 0) | ||||
|   DMA2D->CR = 0 << 16; | ||||
|   DMA2D->FGPFCCR = 0X02; | ||||
|   DMA2D->FGOR = 0; | ||||
| @@ -322,15 +320,14 @@ void TFT_LTDC::DrawImage(uint16_t sx, uint16_t sy, uint16_t ex, uint16_t ey, uin | ||||
|   DMA2D->FGMAR = (uint32_t)colors; | ||||
|   DMA2D->OMAR = addr; | ||||
|   DMA2D->NLR = (ey - sy) | ((ex - sx) << 16); | ||||
|   DMA2D->CR |= 1<<0; | ||||
|   SBI(DMA2D->CR, 0); | ||||
|  | ||||
|   uint32_t timeout = 0; | ||||
|   while((DMA2D->ISR & (1<<1)) == 0) | ||||
|   { | ||||
|   while (!TEST(DMA2D->ISR, 1)) { | ||||
|     timeout++; | ||||
|     if(timeout>0X1FFFFF)break; | ||||
|     if (timeout > 0x1FFFFF) break; | ||||
|   } | ||||
|   DMA2D->IFCR |= 1<<1; | ||||
|   SBI(DMA2D->IFCR, 1); | ||||
| } | ||||
|  | ||||
| void TFT_LTDC::WriteData(uint16_t data) { | ||||
|   | ||||
| @@ -55,7 +55,7 @@ static void TXBegin() { | ||||
|     nvic_irq_disable(dev->irq_num); | ||||
|  | ||||
|     // Use this if removing libmaple | ||||
|     //NVIC_BASE->ICER[1] |= _BV(irq - 32); | ||||
|     //SBI(NVIC_BASE->ICER[1], irq - 32); | ||||
|  | ||||
|     // We NEED memory barriers to ensure Interrupts are actually disabled! | ||||
|     // ( https://dzone.com/articles/nvic-disabling-interrupts-on-arm-cortex-m-and-the ) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user