!C99Shell v. 2.5 [PHP 8 Update] [24.05.2025]!

Software: Apache/2.4.41 (Ubuntu). PHP/8.0.30 

uname -a: Linux apirnd 5.4.0-204-generic #224-Ubuntu SMP Thu Dec 5 13:38:28 UTC 2024 x86_64 

uid=33(www-data) gid=33(www-data) groups=33(www-data) 

Safe-mode: OFF (not secure)

/usr/src/linux-headers-5.4.0-204/include/linux/clk/   drwxr-xr-x
Free 13.17 GB of 57.97 GB (22.72%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     at91_pmc.h (11.29 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/* SPDX-License-Identifier: GPL-2.0-or-later */
/*
 * include/linux/clk/at91_pmc.h
 *
 * Copyright (C) 2005 Ivan Kokshaysky
 * Copyright (C) SAN People
 *
 * Power Management Controller (PMC) - System peripherals registers.
 * Based on AT91RM9200 datasheet revision E.
 */

#ifndef AT91_PMC_H
#define AT91_PMC_H

#define    AT91_PMC_SCER        0x00            /* System Clock Enable Register */
#define    AT91_PMC_SCDR        0x04            /* System Clock Disable Register */

#define    AT91_PMC_SCSR        0x08            /* System Clock Status Register */
#define        AT91_PMC_PCK        (1 <<  0)        /* Processor Clock */
#define        AT91RM9200_PMC_UDP    (1 <<  1)        /* USB Devcice Port Clock [AT91RM9200 only] */
#define        AT91RM9200_PMC_MCKUDP    (1 <<  2)        /* USB Device Port Master Clock Automatic Disable on Suspend [AT91RM9200 only] */
#define        AT91RM9200_PMC_UHP    (1 <<  4)        /* USB Host Port Clock [AT91RM9200 only] */
#define        AT91SAM926x_PMC_UHP    (1 <<  6)        /* USB Host Port Clock [AT91SAM926x only] */
#define        AT91SAM926x_PMC_UDP    (1 <<  7)        /* USB Devcice Port Clock [AT91SAM926x only] */
#define        AT91_PMC_PCK0        (1 <<  8)        /* Programmable Clock 0 */
#define        AT91_PMC_PCK1        (1 <<  9)        /* Programmable Clock 1 */
#define        AT91_PMC_PCK2        (1 << 10)        /* Programmable Clock 2 */
#define        AT91_PMC_PCK3        (1 << 11)        /* Programmable Clock 3 */
#define        AT91_PMC_PCK4        (1 << 12)        /* Programmable Clock 4 [AT572D940HF only] */
#define        AT91_PMC_HCK0        (1 << 16)        /* AHB Clock (USB host) [AT91SAM9261 only] */
#define        AT91_PMC_HCK1        (1 << 17)        /* AHB Clock (LCD) [AT91SAM9261 only] */

#define    AT91_PMC_PCER        0x10            /* Peripheral Clock Enable Register */
#define    AT91_PMC_PCDR        0x14            /* Peripheral Clock Disable Register */
#define    AT91_PMC_PCSR        0x18            /* Peripheral Clock Status Register */

#define    AT91_CKGR_UCKR        0x1C            /* UTMI Clock Register [some SAM9] */
#define        AT91_PMC_UPLLEN        (1   << 16)        /* UTMI PLL Enable */
#define        AT91_PMC_UPLLCOUNT    (0xf << 20)        /* UTMI PLL Start-up Time */
#define        AT91_PMC_BIASEN        (1   << 24)        /* UTMI BIAS Enable */
#define        AT91_PMC_BIASCOUNT    (0xf << 28)        /* UTMI BIAS Start-up Time */

#define    AT91_CKGR_MOR        0x20            /* Main Oscillator Register [not on SAM9RL] */
#define        AT91_PMC_MOSCEN        (1    <<  0)        /* Main Oscillator Enable */
#define        AT91_PMC_OSCBYPASS    (1    <<  1)        /* Oscillator Bypass */
#define        AT91_PMC_WAITMODE    (1    <<  2)        /* Wait Mode Command */
#define        AT91_PMC_MOSCRCEN    (1    <<  3)        /* Main On-Chip RC Oscillator Enable [some SAM9] */
#define        AT91_PMC_OSCOUNT    (0xff <<  8)        /* Main Oscillator Start-up Time */
#define        AT91_PMC_KEY_MASK    (0xff << 16)
#define        AT91_PMC_KEY        (0x37 << 16)        /* MOR Writing Key */
#define        AT91_PMC_MOSCSEL    (1    << 24)        /* Main Oscillator Selection [some SAM9] */
#define        AT91_PMC_CFDEN        (1    << 25)        /* Clock Failure Detector Enable [some SAM9] */

#define    AT91_CKGR_MCFR        0x24            /* Main Clock Frequency Register */
#define        AT91_PMC_MAINF        (0xffff <<  0)        /* Main Clock Frequency */
#define        AT91_PMC_MAINRDY    (1    << 16)        /* Main Clock Ready */

#define    AT91_CKGR_PLLAR        0x28            /* PLL A Register */
#define    AT91_CKGR_PLLBR        0x2c            /* PLL B Register */
#define        AT91_PMC_DIV        (0xff  <<  0)        /* Divider */
#define        AT91_PMC_PLLCOUNT    (0x3f  <<  8)        /* PLL Counter */
#define        AT91_PMC_OUT        (3     << 14)        /* PLL Clock Frequency Range */
#define        AT91_PMC_MUL        (0x7ff << 16)        /* PLL Multiplier */
#define        AT91_PMC_MUL_GET(n)    ((n) >> 16 & 0x7ff)
#define        AT91_PMC3_MUL        (0x7f  << 18)        /* PLL Multiplier [SAMA5 only] */
#define        AT91_PMC3_MUL_GET(n)    ((n) >> 18 & 0x7f)
#define        AT91_PMC_USBDIV        (3     << 28)        /* USB Divisor (PLLB only) */
#define            AT91_PMC_USBDIV_1        (0 << 28)
#define            AT91_PMC_USBDIV_2        (1 << 28)
#define            AT91_PMC_USBDIV_4        (2 << 28)
#define        AT91_PMC_USB96M        (1     << 28)        /* Divider by 2 Enable (PLLB only) */

#define AT91_PMC_CPU_CKR    0x28            /* CPU Clock Register */

#define    AT91_PMC_MCKR        0x30            /* Master Clock Register */
#define        AT91_PMC_CSS        (3 <<  0)        /* Master Clock Selection */
#define            AT91_PMC_CSS_SLOW        (0 << 0)
#define            AT91_PMC_CSS_MAIN        (1 << 0)
#define            AT91_PMC_CSS_PLLA        (2 << 0)
#define            AT91_PMC_CSS_PLLB        (3 << 0)
#define            AT91_PMC_CSS_UPLL        (3 << 0)    /* [some SAM9 only] */
#define        PMC_PRES_OFFSET        2
#define        AT91_PMC_PRES        (7 <<  PMC_PRES_OFFSET)        /* Master Clock Prescaler */
#define            AT91_PMC_PRES_1            (0 << PMC_PRES_OFFSET)
#define            AT91_PMC_PRES_2            (1 << PMC_PRES_OFFSET)
#define            AT91_PMC_PRES_4            (2 << PMC_PRES_OFFSET)
#define            AT91_PMC_PRES_8            (3 << PMC_PRES_OFFSET)
#define            AT91_PMC_PRES_16        (4 << PMC_PRES_OFFSET)
#define            AT91_PMC_PRES_32        (5 << PMC_PRES_OFFSET)
#define            AT91_PMC_PRES_64        (6 << PMC_PRES_OFFSET)
#define        PMC_ALT_PRES_OFFSET    4
#define        AT91_PMC_ALT_PRES    (7 <<  PMC_ALT_PRES_OFFSET)        /* Master Clock Prescaler [alternate location] */
#define            AT91_PMC_ALT_PRES_1        (0 << PMC_ALT_PRES_OFFSET)
#define            AT91_PMC_ALT_PRES_2        (1 << PMC_ALT_PRES_OFFSET)
#define            AT91_PMC_ALT_PRES_4        (2 << PMC_ALT_PRES_OFFSET)
#define            AT91_PMC_ALT_PRES_8        (3 << PMC_ALT_PRES_OFFSET)
#define            AT91_PMC_ALT_PRES_16        (4 << PMC_ALT_PRES_OFFSET)
#define            AT91_PMC_ALT_PRES_32        (5 << PMC_ALT_PRES_OFFSET)
#define            AT91_PMC_ALT_PRES_64        (6 << PMC_ALT_PRES_OFFSET)
#define        AT91_PMC_MDIV        (3 <<  8)        /* Master Clock Division */
#define            AT91RM9200_PMC_MDIV_1        (0 << 8)    /* [AT91RM9200 only] */
#define            AT91RM9200_PMC_MDIV_2        (1 << 8)
#define            AT91RM9200_PMC_MDIV_3        (2 << 8)
#define            AT91RM9200_PMC_MDIV_4        (3 << 8)
#define            AT91SAM9_PMC_MDIV_1        (0 << 8)    /* [SAM9 only] */
#define            AT91SAM9_PMC_MDIV_2        (1 << 8)
#define            AT91SAM9_PMC_MDIV_4        (2 << 8)
#define            AT91SAM9_PMC_MDIV_6        (3 << 8)    /* [some SAM9 only] */
#define            AT91SAM9_PMC_MDIV_3        (3 << 8)    /* [some SAM9 only] */
#define        AT91_PMC_PDIV        (1 << 12)        /* Processor Clock Division [some SAM9 only] */
#define            AT91_PMC_PDIV_1            (0 << 12)
#define            AT91_PMC_PDIV_2            (1 << 12)
#define        AT91_PMC_PLLADIV2    (1 << 12)        /* PLLA divisor by 2 [some SAM9 only] */
#define            AT91_PMC_PLLADIV2_OFF        (0 << 12)
#define            AT91_PMC_PLLADIV2_ON        (1 << 12)
#define        AT91_PMC_H32MXDIV    BIT(24)

#define    AT91_PMC_USB        0x38            /* USB Clock Register [some SAM9 only] */
#define        AT91_PMC_USBS        (0x1 <<  0)        /* USB OHCI Input clock selection */
#define            AT91_PMC_USBS_PLLA        (0 << 0)
#define            AT91_PMC_USBS_UPLL        (1 << 0)
#define            AT91_PMC_USBS_PLLB        (1 << 0)    /* [AT91SAMN12 only] */
#define        AT91_PMC_OHCIUSBDIV    (0xF <<  8)        /* Divider for USB OHCI Clock */
#define            AT91_PMC_OHCIUSBDIV_1    (0x0 <<  8)
#define            AT91_PMC_OHCIUSBDIV_2    (0x1 <<  8)

#define    AT91_PMC_SMD        0x3c            /* Soft Modem Clock Register [some SAM9 only] */
#define        AT91_PMC_SMDS        (0x1  <<  0)        /* SMD input clock selection */
#define        AT91_PMC_SMD_DIV    (0x1f <<  8)        /* SMD input clock divider */
#define        AT91_PMC_SMDDIV(n)    (((n) <<  8) & AT91_PMC_SMD_DIV)

#define    AT91_PMC_PCKR(n)    (0x40 + ((n) * 4))    /* Programmable Clock 0-N Registers */
#define        AT91_PMC_ALT_PCKR_CSS    (0x7 <<  0)        /* Programmable Clock Source Selection [alternate length] */
#define            AT91_PMC_CSS_MASTER        (4 << 0)    /* [some SAM9 only] */
#define        AT91_PMC_CSSMCK        (0x1 <<  8)        /* CSS or Master Clock Selection */
#define            AT91_PMC_CSSMCK_CSS        (0 << 8)
#define            AT91_PMC_CSSMCK_MCK        (1 << 8)

#define    AT91_PMC_IER        0x60            /* Interrupt Enable Register */
#define    AT91_PMC_IDR        0x64            /* Interrupt Disable Register */
#define    AT91_PMC_SR        0x68            /* Status Register */
#define        AT91_PMC_MOSCS        (1 <<  0)        /* MOSCS Flag */
#define        AT91_PMC_LOCKA        (1 <<  1)        /* PLLA Lock */
#define        AT91_PMC_LOCKB        (1 <<  2)        /* PLLB Lock */
#define        AT91_PMC_MCKRDY        (1 <<  3)        /* Master Clock */
#define        AT91_PMC_LOCKU        (1 <<  6)        /* UPLL Lock [some SAM9] */
#define        AT91_PMC_OSCSEL        (1 <<  7)        /* Slow Oscillator Selection [some SAM9] */
#define        AT91_PMC_PCK0RDY    (1 <<  8)        /* Programmable Clock 0 */
#define        AT91_PMC_PCK1RDY    (1 <<  9)        /* Programmable Clock 1 */
#define        AT91_PMC_PCK2RDY    (1 << 10)        /* Programmable Clock 2 */
#define        AT91_PMC_PCK3RDY    (1 << 11)        /* Programmable Clock 3 */
#define        AT91_PMC_MOSCSELS    (1 << 16)        /* Main Oscillator Selection [some SAM9] */
#define        AT91_PMC_MOSCRCS    (1 << 17)        /* Main On-Chip RC [some SAM9] */
#define        AT91_PMC_CFDEV        (1 << 18)        /* Clock Failure Detector Event [some SAM9] */
#define        AT91_PMC_GCKRDY        (1 << 24)        /* Generated Clocks */
#define    AT91_PMC_IMR        0x6c            /* Interrupt Mask Register */

#define AT91_PMC_FSMR        0x70        /* Fast Startup Mode Register */
#define AT91_PMC_FSTT(n)    BIT(n)
#define AT91_PMC_RTTAL        BIT(16)
#define AT91_PMC_RTCAL        BIT(17)        /* RTC Alarm Enable */
#define AT91_PMC_USBAL        BIT(18)        /* USB Resume Enable */
#define AT91_PMC_SDMMC_CD    BIT(19)        /* SDMMC Card Detect Enable */
#define AT91_PMC_LPM        BIT(20)        /* Low-power Mode */
#define AT91_PMC_RXLP_MCE    BIT(24)        /* Backup UART Receive Enable */
#define AT91_PMC_ACC_CE        BIT(25)        /* ACC Enable */

#define AT91_PMC_FSPR        0x74        /* Fast Startup Polarity Reg */

#define AT91_PMC_FS_INPUT_MASK  0x7ff

#define AT91_PMC_PLLICPR    0x80            /* PLL Charge Pump Current Register */

#define AT91_PMC_PROT        0xe4            /* Write Protect Mode Register [some SAM9] */
#define        AT91_PMC_WPEN        (0x1  <<  0)        /* Write Protect Enable */
#define        AT91_PMC_WPKEY        (0xffffff << 8)        /* Write Protect Key */
#define        AT91_PMC_PROTKEY    (0x504d43 << 8)        /* Activation Code */

#define AT91_PMC_WPSR        0xe8            /* Write Protect Status Register [some SAM9] */
#define        AT91_PMC_WPVS        (0x1  <<  0)        /* Write Protect Violation Status */
#define        AT91_PMC_WPVSRC        (0xffff  <<  8)        /* Write Protect Violation Source */

#define AT91_PMC_PCER1        0x100            /* Peripheral Clock Enable Register 1 [SAMA5 only]*/
#define AT91_PMC_PCDR1        0x104            /* Peripheral Clock Enable Register 1 */
#define AT91_PMC_PCSR1        0x108            /* Peripheral Clock Enable Register 1 */

#define AT91_PMC_PCR        0x10c            /* Peripheral Control Register [some SAM9 and SAMA5] */
#define        AT91_PMC_PCR_PID_MASK        0x3f
#define        AT91_PMC_PCR_CMD        (0x1  <<  12)                /* Command (read=0, write=1) */
#define        AT91_PMC_PCR_GCKDIV_MASK    GENMASK(27, 20)
#define        AT91_PMC_PCR_EN            (0x1  <<  28)                /* Enable */
#define        AT91_PMC_PCR_GCKEN        (0x1  <<  29)                /* GCK Enable */

#define AT91_PMC_AUDIO_PLL0    0x14c
#define        AT91_PMC_AUDIO_PLL_PLLEN    (1  <<  0)
#define        AT91_PMC_AUDIO_PLL_PADEN    (1  <<  1)
#define        AT91_PMC_AUDIO_PLL_PMCEN    (1  <<  2)
#define        AT91_PMC_AUDIO_PLL_RESETN    (1  <<  3)
#define        AT91_PMC_AUDIO_PLL_ND_OFFSET    8
#define        AT91_PMC_AUDIO_PLL_ND_MASK    (0x7f << AT91_PMC_AUDIO_PLL_ND_OFFSET)
#define        AT91_PMC_AUDIO_PLL_ND(n)    ((n)  << AT91_PMC_AUDIO_PLL_ND_OFFSET)
#define        AT91_PMC_AUDIO_PLL_QDPMC_OFFSET    16
#define        AT91_PMC_AUDIO_PLL_QDPMC_MASK    (0x7f << AT91_PMC_AUDIO_PLL_QDPMC_OFFSET)
#define        AT91_PMC_AUDIO_PLL_QDPMC(n)    ((n)  << AT91_PMC_AUDIO_PLL_QDPMC_OFFSET)

#define AT91_PMC_AUDIO_PLL1    0x150
#define        AT91_PMC_AUDIO_PLL_FRACR_MASK        0x3fffff
#define        AT91_PMC_AUDIO_PLL_QDPAD_OFFSET        24
#define        AT91_PMC_AUDIO_PLL_QDPAD_MASK        (0x7f << AT91_PMC_AUDIO_PLL_QDPAD_OFFSET)
#define        AT91_PMC_AUDIO_PLL_QDPAD(n)        ((n)  << AT91_PMC_AUDIO_PLL_QDPAD_OFFSET)
#define        AT91_PMC_AUDIO_PLL_QDPAD_DIV_OFFSET    AT91_PMC_AUDIO_PLL_QDPAD_OFFSET
#define        AT91_PMC_AUDIO_PLL_QDPAD_DIV_MASK    (0x3  << AT91_PMC_AUDIO_PLL_QDPAD_DIV_OFFSET)
#define        AT91_PMC_AUDIO_PLL_QDPAD_DIV(n)        ((n)  << AT91_PMC_AUDIO_PLL_QDPAD_DIV_OFFSET)
#define        AT91_PMC_AUDIO_PLL_QDPAD_EXTDIV_OFFSET    26
#define        AT91_PMC_AUDIO_PLL_QDPAD_EXTDIV_MAX    0x1f
#define        AT91_PMC_AUDIO_PLL_QDPAD_EXTDIV_MASK    (AT91_PMC_AUDIO_PLL_QDPAD_EXTDIV_MAX << AT91_PMC_AUDIO_PLL_QDPAD_EXTDIV_OFFSET)
#define        AT91_PMC_AUDIO_PLL_QDPAD_EXTDIV(n)    ((n)  << AT91_PMC_AUDIO_PLL_QDPAD_EXTDIV_OFFSET)

#endif

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0049 ]--