Training courses
Kernel and Embedded Linux
Bootlin training courses
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144
/* SPDX-License-Identifier: GPL-2.0 */ /* * Copyright (c) 2003-2006 Simtec Electronics <linux@simtec.co.uk> * http://armlinux.simtec.co.uk/ * * S3C2410 clock register definitions */ #ifndef __ASM_ARM_REGS_CLOCK #define __ASM_ARM_REGS_CLOCK #define S3C2410_CLKREG(x) ((x) + S3C24XX_VA_CLKPWR) #define S3C2410_PLLVAL(_m,_p,_s) ((_m) << 12 | ((_p) << 4) | ((_s))) #define S3C2410_LOCKTIME S3C2410_CLKREG(0x00) #define S3C2410_MPLLCON S3C2410_CLKREG(0x04) #define S3C2410_UPLLCON S3C2410_CLKREG(0x08) #define S3C2410_CLKCON S3C2410_CLKREG(0x0C) #define S3C2410_CLKSLOW S3C2410_CLKREG(0x10) #define S3C2410_CLKDIVN S3C2410_CLKREG(0x14) #define S3C2410_CLKCON_IDLE (1<<2) #define S3C2410_CLKCON_POWER (1<<3) #define S3C2410_CLKCON_NAND (1<<4) #define S3C2410_CLKCON_LCDC (1<<5) #define S3C2410_CLKCON_USBH (1<<6) #define S3C2410_CLKCON_USBD (1<<7) #define S3C2410_CLKCON_PWMT (1<<8) #define S3C2410_CLKCON_SDI (1<<9) #define S3C2410_CLKCON_UART0 (1<<10) #define S3C2410_CLKCON_UART1 (1<<11) #define S3C2410_CLKCON_UART2 (1<<12) #define S3C2410_CLKCON_GPIO (1<<13) #define S3C2410_CLKCON_RTC (1<<14) #define S3C2410_CLKCON_ADC (1<<15) #define S3C2410_CLKCON_IIC (1<<16) #define S3C2410_CLKCON_IIS (1<<17) #define S3C2410_CLKCON_SPI (1<<18) #define S3C2410_CLKDIVN_PDIVN (1<<0) #define S3C2410_CLKDIVN_HDIVN (1<<1) #define S3C2410_CLKSLOW_UCLK_OFF (1<<7) #define S3C2410_CLKSLOW_MPLL_OFF (1<<5) #define S3C2410_CLKSLOW_SLOW (1<<4) #define S3C2410_CLKSLOW_SLOWVAL(x) (x) #define S3C2410_CLKSLOW_GET_SLOWVAL(x) ((x) & 7) #if defined([31mCONFIG_CPU_S3C2440[0m) || defined([31mCONFIG_CPU_S3C2442[0m) /* extra registers */ #define S3C2440_CAMDIVN S3C2410_CLKREG(0x18) #define S3C2440_CLKCON_CAMERA (1<<19) #define S3C2440_CLKCON_AC97 (1<<20) #define S3C2440_CLKDIVN_PDIVN (1<<0) #define S3C2440_CLKDIVN_HDIVN_MASK (3<<1) #define S3C2440_CLKDIVN_HDIVN_1 (0<<1) #define S3C2440_CLKDIVN_HDIVN_2 (1<<1) #define S3C2440_CLKDIVN_HDIVN_4_8 (2<<1) #define S3C2440_CLKDIVN_HDIVN_3_6 (3<<1) #define S3C2440_CLKDIVN_UCLK (1<<3) #define S3C2440_CAMDIVN_CAMCLK_MASK (0xf<<0) #define S3C2440_CAMDIVN_CAMCLK_SEL (1<<4) #define S3C2440_CAMDIVN_HCLK3_HALF (1<<8) #define S3C2440_CAMDIVN_HCLK4_HALF (1<<9) #define S3C2440_CAMDIVN_DVSEN (1<<12) #define S3C2442_CAMDIVN_CAMCLK_DIV3 (1<<5) #endif /* CONFIG_CPU_S3C2440 or CONFIG_CPU_S3C2442 */ #if defined([31mCONFIG_CPU_S3C2412[0m) #define S3C2412_OSCSET S3C2410_CLKREG(0x18) #define S3C2412_CLKSRC S3C2410_CLKREG(0x1C) #define S3C2412_PLLCON_OFF (1<<20) #define S3C2412_CLKDIVN_PDIVN (1<<2) #define S3C2412_CLKDIVN_HDIVN_MASK (3<<0) #define S3C2412_CLKDIVN_ARMDIVN (1<<3) #define S3C2412_CLKDIVN_DVSEN (1<<4) #define S3C2412_CLKDIVN_HALFHCLK (1<<5) #define S3C2412_CLKDIVN_USB48DIV (1<<6) #define S3C2412_CLKDIVN_UARTDIV_MASK (15<<8) #define S3C2412_CLKDIVN_UARTDIV_SHIFT (8) #define S3C2412_CLKDIVN_I2SDIV_MASK (15<<12) #define S3C2412_CLKDIVN_I2SDIV_SHIFT (12) #define S3C2412_CLKDIVN_CAMDIV_MASK (15<<16) #define S3C2412_CLKDIVN_CAMDIV_SHIFT (16) #define S3C2412_CLKCON_WDT (1<<28) #define S3C2412_CLKCON_SPI (1<<27) #define S3C2412_CLKCON_IIS (1<<26) #define S3C2412_CLKCON_IIC (1<<25) #define S3C2412_CLKCON_ADC (1<<24) #define S3C2412_CLKCON_RTC (1<<23) #define S3C2412_CLKCON_GPIO (1<<22) #define S3C2412_CLKCON_UART2 (1<<21) #define S3C2412_CLKCON_UART1 (1<<20) #define S3C2412_CLKCON_UART0 (1<<19) #define S3C2412_CLKCON_SDI (1<<18) #define S3C2412_CLKCON_PWMT (1<<17) #define S3C2412_CLKCON_USBD (1<<16) #define S3C2412_CLKCON_CAMCLK (1<<15) #define S3C2412_CLKCON_UARTCLK (1<<14) /* missing 13 */ #define S3C2412_CLKCON_USB_HOST48 (1<<12) #define S3C2412_CLKCON_USB_DEV48 (1<<11) #define S3C2412_CLKCON_HCLKdiv2 (1<<10) #define S3C2412_CLKCON_HCLKx2 (1<<9) #define S3C2412_CLKCON_SDRAM (1<<8) /* missing 7 */ #define S3C2412_CLKCON_USBH S3C2410_CLKCON_USBH #define S3C2412_CLKCON_LCDC S3C2410_CLKCON_LCDC #define S3C2412_CLKCON_NAND S3C2410_CLKCON_NAND #define S3C2412_CLKCON_DMA3 (1<<3) #define S3C2412_CLKCON_DMA2 (1<<2) #define S3C2412_CLKCON_DMA1 (1<<1) #define S3C2412_CLKCON_DMA0 (1<<0) /* clock sourec controls */ #define S3C2412_CLKSRC_EXTCLKDIV_MASK (7 << 0) #define S3C2412_CLKSRC_EXTCLKDIV_SHIFT (0) #define S3C2412_CLKSRC_MDIVCLK_EXTCLKDIV (1<<3) #define S3C2412_CLKSRC_MSYSCLK_MPLL (1<<4) #define S3C2412_CLKSRC_USYSCLK_UPLL (1<<5) #define S3C2412_CLKSRC_UARTCLK_MPLL (1<<8) #define S3C2412_CLKSRC_I2SCLK_MPLL (1<<9) #define S3C2412_CLKSRC_USBCLK_HCLK (1<<10) #define S3C2412_CLKSRC_CAMCLK_HCLK (1<<11) #define S3C2412_CLKSRC_UREFCLK_EXTCLK (1<<12) #define S3C2412_CLKSRC_EREFCLK_EXTCLK (1<<14) #endif /* CONFIG_CPU_S3C2412 */ #define S3C2416_CLKDIV2 S3C2410_CLKREG(0x28) #endif /* __ASM_ARM_REGS_CLOCK */