# **Table of Contents**

| Linux Kernel Porting:                                             | 2   |
|-------------------------------------------------------------------|-----|
| Porting:                                                          | 2   |
| What Linux kernel porting involves:                               | 2   |
| Building a Linux kernel for the target platform:                  | 2   |
| The Linux kernel build system:                                    |     |
| Linux Support Packages (LSP)/Board Support Packages (BSP)         | 5   |
| Components of LSP                                                 | 5   |
| Machine ID                                                        | 6   |
| MACHINE_START                                                     | 6   |
| How to begin with porting                                         | 7   |
| Reference Board: ST: SPEAR13XX                                    | 8   |
| Introduction                                                      | 8   |
| Configuration                                                     | 8   |
| Layout                                                            | 8   |
| Following rules to be respected for defining the virtual address: | 9   |
| Examples - UART_PHYS - UART_VIRT                                  | 9   |
| Linux Serial Console                                              | 11  |
| Shikhara SoC & Board                                              | 12  |
| Shikhara SoC Features                                             | 12  |
| IP List in Shikhara SoC                                           | 13  |
| Device Tree                                                       | 18  |
| IP List in Shikhara SoC – Address Map                             | 18  |
| IRQ LIST                                                          |     |
| Mach-shikhara                                                     | 23  |
| Step 1: mach-shikhara                                             | 23  |
| Step 2: UART PHY , UART VIRT                                      | 23  |
| Step 3: Kconfig , Makefile                                        | 24  |
| Step 4: platsmp.c                                                 | 25  |
| Step 5: hotplug.c                                                 | 28  |
| Step 6: shikhara.c                                                | 30  |
| Step 7: generic.h                                                 | 31  |
| Step 7: Device Tree                                               | 32  |
| Step 7: shikhara_defconfig                                        | 37  |
| Step 7: building                                                  | 129 |

# **Linux Kernel Porting:**

# **Porting:**

Porting means making something work on an environment it is not designed for. Embedded Linux porting means making Linux work on an embedded platform, for which it was not designed. Porting is a broader term and when I say embedded Linux porting, it not only involves Linux kernel porting, but also porting a first stage boot loader, a second stage boot loader and, last but not the least, the applications. Porting differs from development. Usually, porting doesn't involve as much of coding as in development. This means that there is already some code available and it only needs to be fine-tuned to the desired target. There may be a need to change a few lines here and there, before it is up and running. But, the key thing to know is, what needs to be changed and where.

## What Linux kernel porting involves:

Linux kernel porting involves two things at a higher level: **architecture porting and board porting**. Architecture, in Linux terminology, refers to CPU. So, architecture porting means adapting the Linux **kernel to the target CPU, which may be ARM, Power PC, MIPS**, and so on. **In addition to this, SOC porting can also be considered as part of architecture porting.** As far as the Linux kernel is concerned, most of the times, you don't need to port it for architecture as this would already be supported in Linux. **However, you still need to port Linux for the board and this is where the major focus lies**. Architecture porting entails porting of initial start-up code, interrupt service routines, dispatcher routine, timer routine, memory management, and so on. Whereas board porting involves writing custom drivers and initialization code for devices specific to the board.

## **Building a Linux kernel for the target platform:**

Kernel building is a two-step process: **first, the kernel needs to be configured for the target platform.** There are many ways to configure the kernel, based on the preferred configuration interface. Given below are some of the common methods.

To run the text-based configuration, execute the following command:

make config

This will show the configuration options on the console as seen in Figure . It is a little cumbersome to configure the kernel with this, as it prompts every configuration option, in order, and doesn't allow the reversion of changes.

To run the menu-driven configuration, execute the following command:

### make menuconfig

This will show the menu options for configuring the kernel, as seen in Figure . This requires the *ncurses* library to be installed on the system. This is the most popular interface used to configure the kernel.

For details on other options, execute the following command in the kernel top directory:

## make help

Once the kernel is configured, the next step is to build the kernel with the *make* command. A few commonly used commands are given below:

make vmlinux Builds the bare kernel make modules Builds the modules

If the above commands are executed as stated, the kernel will be configured and compiled for the host system, which is generally the x86 platform. But, for porting, the intention is to configure and build the kernel for the target platform, which in turn, requires configuration of *makefile*. Two things that need to be changed in the *makefile* are given below:

```
ARCH=<architecture>
CROSS_COMPILE = <toolchain prefix>
```

The first line defines the architecture the kernel needs to be built for, and the second line defines the cross compilation tool chain prefix. So, if the architecture is ARM and the tool chain is say, from CodeSourcery, then it would be:

```
ARCH=arm CROSS_COMPILE=arm-none-linux-gnueabi-
```

The kernel image generated after the compilation is usually vmlinux, which is in ELF format. This image can't be used directly with embedded system boot loaders such as u-boot.

## The Linux kernel build system:

One of the beautiful things about the Linux kernel is that it is highly configurable and the same code base can be used for a variety of applications, ranging from high end servers to tiny embedded devices. And the infrastructure, which plays an important role in achieving this in an efficient manner, is the kernel build system, also known as *kbuild*. The kernel build system has two main components: **makefile and Kconfig.** 

*Makefile:* Every sub-directory has its own makefile, which is used to compile the files in that directory and generate the object code out of that. The top level makefile percolates recursively into its sub-directories and invokes the corresponding makefile to build the modules and finally, the Linux kernel image. The makefile builds only the files for which the configuration option is enabled through the configuration tool.

**Kconfig:** As with the makefile, every sub-directory has a Kconfig file. Kconfig is in configuration language and Kconfig files located inside each sub-directory are the programs. Kconfig contains the entries, which are read by configuration targets such as *make menuconfig* to show a menu-like structure.

So we have covered makefile and Kconfig and at present they seem to be pretty much disconnected. For kbuild to work properly, there has to be some link between the Kconfig and makefile. And that link is nothing but the configuration symbols, which generally have a prefix *CONFIG\_*. These symbols are generated by a configuration target such as *menuconfig*, based on entries defined in the Kconfig file. And based on what the user has selected in the menu, these symbols can have the values 'y', 'n', or 'm'.

## **Linux Support Packages (LSP)/Board Support Packages (BSP)**

One of the most important and probably the most challenging thing in porting is the development of **Board Support Packages (BSP)**. BSP development is a one-time effort during the product development life cycle and, obviously, the most critical. As we have discussed, porting involves architecture porting and board porting. Board porting involves board-specific initialization code that includes initialization of the various interfaces such as memory, peripherals such as serial, and i2c, which in turn, involves the driver porting.

There are two categories of drivers. One is the standard device driver such as the i2c driver and block driver located at the standard directory location. Another is the custom interface or device driver, which includes the board-specific custom code and needs to be specifically brought in with the kernel. And this collection of board-specific initialization and custom code is referred to as a Board Support Package or, in Linux terminology, a LSP. In simple words, whatever software code you require (which is specific to the target platform) to boot up the target with the operating system can be called LSP.

## **Components of LSP**

As the name itself suggests, BSP is dependent on the things that are specific to the target board. So, it consists of the code which is specific to that particular board, and it applies only to that board. The usual list includes Interrupt Request Numbers (IRQ), which are dependent on how the various devices are connected on the board. Also, some boards have an audio codec and you need to have a driver for that codec. Likewise, there would be switch interfaces, a matrix keypad, external *eeprom*, and so on.



#### LSP placement

LSP is placed under a specific *<arch>* folder of the kernel's arch folder. For example, architecture-specific code for ARM resides in the *arch/arm* directory. This is about the code, but you also need the headers which are placed under *arch/arm/include/asm*. However, board-specific code is placed at

arch/arm/mach-<board\_name> and corresponding headers are placed at arch/arm/mach-<soc architecture>/include. For example, LSP for Beagle Board is placed at arch/arm/mach-omap2/board-omap3beagle.c and corresponding headers are placed at arch/arm/mach-omap2/include/mach/. This is shown in figure.

| 1 | ARM resides in the <i>arch/arm</i> directory                                           |
|---|----------------------------------------------------------------------------------------|
| 2 | headers which are placed under <i>arch/arm/include/asm</i>                             |
| 3 | board-specific code is placed at arch/arm/mach- <box></box>                            |
| 4 | corresponding headers are placed at arch/arm/mach- <soc architecture="">/include</soc> |
| 5 | LSP for Beagle Board is placed at arch/arm/mach-omap2/board-omap3beagle.c              |
| 6 | corresponding headers are placed at arch/arm/mach-omap2/include/mach/.                 |

#### **Machine ID**

Every board in the kernel is identified by a machine ID. This helps the kernel maintainers to manage the boards based on ARM architecture in the source tree. This ID is passed to the kernel from the second stage boot loader such as u-boot. For the kernel to boot properly, there has to be a match between the kernel and the second stage boot loader. This information is available in **arch/arm/tools/mach-types** and is used to generate the file **linux/include/generated/mach-types.h**. The macros defined by mach-types.h are used by the rest of the kernel code. For example, the machine ID for Beagle Board is 1546, and this is the number which the second stage boot loader passes to the kernel.

## **MACHINE START**

One of the steps involved in kernel porting is to define the initialization functions for the various interfaces on the board, such as serial, Ethernet, Gpio, etc. Once these functions are defined, they need to be linked with the kernel so that it can invoke them during boot-up. For this, the kernel provides the macro **MACHINE\_START**. Typically, a MACHINE\_START macro looks like what shown below:

```
MACHINE_START(MY_BOARD, "My Board for Demo")
.atag_offset = 0x100,
.init_early = my_board_early,
.init_irq = my_board_irq,
.init_machine = my_board_init,
MACHINE_END
```

Let's understand this macro. MY\_BOARD is machine ID defined in arch/arm/tools/mach-types. The

second parameter to the macro is a string describing the board. The next few lines specify the various initialization functions, which the kernel has to invoke during boot-up. These include the following:

.atag\_offset: Defines the offset in RAM, where the boot parameters will be placed. These parameters are passed from the second stage boot loader, such as u-boot.

*my\_board\_early:* Calls the SOC initialization functions. This function will be defined by the SOC vendor, if the kernel is ported for it.

*my\_board\_irq*: Initialization related to interrupts is done over here.

*my\_board\_init*: All the board-specific initialization is done here. This function should be defined during the board porting. This includes things such as setting up the pin multiplexing, initialization of the serial console, initialization of RAM, initialization of Ethernet, USB and so on.

MACHINE END ends the macro. This macro is defined in arch/arm/include/asm/mach/arch.h.

# How to begin with porting

The most common and recommended way to begin with porting is to start with **some reference board**, **which closely resembles yours.** So, if you are porting for a board based on OMAP3 architecture, take Beagle Board as a reference. Also, for porting, you should understand the system very well. Depending on the features available on your board, configure the kernel accordingly. To start with, just enable the minimal set of features required to boot the kernel. This may include but not be limited to initialization of RAM, Gpio subsystems, serial interfaces, and file systems drivers for mounting the root file system. Once the kernel boots up with the minimal configuration, start adding the new features, as required.

#### So, let us summarize the steps involved in porting:

- 1. The first step is to register the machine with the kernel maintainer and get the unique ID for your board. While this is not necessary to begin with porting, it needs to be done eventually, if patches are to be submitted to the mainline. Place the machine ID in *arch/arm/tools/mach-types*.
- 2. Create the board-specific file board-<br/>
  'at arch/arm/mach-<soc> and define the MACHINE\_START for the new board. For example, the board-specific file for the Panda Board resides at arch/arm/mach-omap2/board-omap4panda.c.
- 3. Update the Kconfig file at *arch/arm/mach\_*<*soc*> to add an entry for the new board as shown below:

```
config MACH_MY_BOARD
bool My Board for Demo
depends on ARCH_OMAP3
default y
```

4. Update the corresponding makefile, so that the board-specific file gets compiled. This is shown below:

```
obj-$(CONFIG_MACH_MY_BOARD) += board-my_board.o
```

5. Create a default configuration file for the new board. To begin with, take any .config file as a starting point and customise it for the new board. Place the working .config file at <code>arch/arm/configs/my\_board\_defconfig</code>

## Reference Board: ST: SPEAR13XX

SPEAr ARM Linux Overview

## Introduction

SPEAr (Structured Processor Enhanced Architecture). weblink: http://www.st.com/spear

The ST Microelectronics SPEAr range of ARM9/CortexA9 System-on-Chip CPUs are supported by the 'spear' platform of ARM Linux. Currently **SPEAr1310**, **SPEAr1340**, SPEAr300, SPEAr310, SPEAr320 and SPEAr600 SOCs are supported.

#### **Hierarchy in SPEAr is as follows:**

- SPEAr13XX (13XX SOC series, based on ARM CORTEXA9)
  - SPEAr1310 (SOC)
    - SPEAr1310 Evaluation Board
  - SPEAr1340 (SOC)
    - SPEAr1340 Evaluation Board

# Configuration

A generic configuration is provided for each machine, and can be used as the default by **make spear13xx\_defconfig** 

## Layout

The common files for multiple machine families (SPEAr3xx, SPEAr6xx and SPEAr13xx) are located

in the platform code contained in **arch/arm/mach-spear**/ with headers in **arch/arm/mach-spear/include**/.

```
# Common support
obj-y := restart.o time.o

smp-$(CONFIG_SMP) += headsmp.o platsmp.o
smp-$(CONFIG_HOTPLUG_CPU) += hotplug.o

obj-$(CONFIG_ARCH_SPEAR13XX) += spear13xx.o $(smp-y)
obj-$(CONFIG_MACH_SPEAR1310) += spear1310.o
obj-$(CONFIG_MACH_SPEAR1340) += spear1340.o
```

## Following rules to be respected for defining the virtual address:

- 1. The 20 low weight bits (21 in case LPAE is enabled) must be kept in order to align region size of 1MB (2MB in LPAE is enabled).
- 2. It must be mapped at the upper address of the vmalloc area, in order to not be overwritten by kernel which is stating from lower addresses: i.e here we select 0xFE0xxxxx

```
CONFIG_DEBUG_UART_PHYS: 0x40010000 /* UART4 */CONFIG_DEBUG_UART_VIRT: 0xFE010000
```

Please find below table for USART/UART of STMP32MP1:

| Name   | <b>Physical base address</b> | Virtual base address |
|--------|------------------------------|----------------------|
| USART1 | 5c000000                     | FE000000             |
| USART2 | 4000e000                     | <b>FE0</b> 0e000     |
| USART3 | 4000f000                     | <b>FE0</b> 0f000     |
| UART4  | 40010000                     | <b>FE0</b> 10000     |
| UART5  | 40011000                     | <b>FE0</b> 11000     |
| USART6 | 44003000                     | <b>FE0</b> 03000     |
| UART7  | 40018000                     | <b>FE0</b> 18000     |
| UART8  | 40019000                     | <b>FE0</b> 19000     |

## **Examples - UART\_PHYS - UART\_VIRT**

- arch/arm/Kconfig.debug
- config DEBUG\_UART\_PHYS

default 0xe0000000 if DEBUG\_SPEAR13XX default 0x20201000 if DEBUG\_BCM2835 default 0x3f201000 if DEBUG\_BCM2836 default 0x40100000 if DEBUG\_PXA\_UART1

#### config DEBUG\_UART\_VIRT

default 0xfd000000 if DEBUG\_SPEAR3XX || DEBUG\_SPEAR13XX default 0xf0201000 if DEBUG\_BCM2835 || DEBUG\_BCM2836 default 0xf6200000 if DEBUG\_PXA\_UART1

#### source code:

arch/arm/include/debug/

| pl01x.S     |
|-------------|
| bcm63xx.S   |
| at91.S      |
| imx.S       |
| omap2plus.S |
| samsung.S   |
| sti.S       |
| vexpress.S  |
|             |

## Typical code:

ARM\_BE8(

```
#ifdef CONFIG_DEBUG_UART_PHYS
        .macro addruart, rp, rv, tmp
        ldr \rp, =CONFIG_DEBUG_UART_PHYS
        ldr
            \rv, =CONFIG DEBUG UART VIRT
        .endm
#endif
        .macro senduart,rd,rx
        strb \rd, [\rx, #UART01x_DR]
        .endm
        .macro waituart,rd,rx
1001:
        ldr \rd, [\rx, #UART01x_FR]
ARM BE8(
              rev \rd, \rd)
            \rd, #UART01x_FR_TXFF
        tst
        bne
             1001b
        .endm
        .macro busyuart,rd,rx
1001:
             \rd, [\rx, #UART01x_FR]
```

rev \rd, \rd)

```
tst \rd, #UART01x_FR_BUSY bne 1001b .endm
```

## **Linux Serial Console**

setenv bootargs earlyprintk console=ttyAMA0 mem=512M root=/dev/ram0 rw initrd=0x12c00000,16M

To use a serial port as console you need to compile the support into your kernel

drivers/tty/serial/amba-pl011.c

```
amba-pl011.c
                                               static struct console amba_console = {
                                                                = "ttyAMA",
                                                    .name
                                                    .write
                                                               = pl011_console_write,
                                                    .device
                                                               = uart_console_device,
                                                               = pl011 console setup,
                                                    .setup
                                                                = pl011 console match,
                                                    .match
                                                    .flags
                                                              = CON_PRINTBUFFER |
                                               CON ANYTIME,
                                                    .index
                                                               = -1,
                                                    .data
                                                              = &amba reg,
                                               };
amba-pl010.c
                                               static struct console amba_console = {
                                                    .name
                                                                = "ttyAM",
                                                               = pl010 console write,
                                                    .write
                                                               = uart_console_device,
                                                    .device
                                                    .setup
                                                               = pl010_console_setup,
                                                              = CON_PRINTBUFFER,
                                                    .flags
                                                    .index
                                                               = -1,
                                                    .data
                                                              = &amba_reg,
                                               };
```

## Shikhara SoC & Board

## **Shikhara SoC Features**

Following is the summary of Shikhara features:

#### **CPU Platform**

 ARM Cortex A9 dual core (800MHz – Processor subsystem), 32KB L1 D-Cache, 32KB L1 I-Cache, 512KB L2 Cache.

#### **Video Processing Unit**

• ARC700 (400MHz-Video Sub system)

#### **Internal On chip memories**

- 64 KB ROM & 64KB RAM, 512KB L2 Cache RAM
- 64 KB RAM for Video ARC 700

#### External memory interfaces

NAND/NOR/SRAM memory, LPDDR2/DDR3 SDRAM, SDMMC and SDIO

#### **Communication & connectivity**

- USB 3.0 DRD Controller
- USB3.0 Host Controller
- HDMI 1.4a Tx Controller
- Four UARTs
- Four General purpose input outputs
- One I2S (Master)
- Three I2C
- Two SPI Controllers.
- One MIPI CSI-2 Receiver.
- One MIPI DSI Transmitter

• One CAN Controller.

#### **System functions**

- Multiple power domains
- Clock gating
- Power gating
- Two DMA Controllers
- Two Dual Timers
- Watch Dog Timer
- JTAG interface for ARM debug access
- Multi Format video codec provides encoding & decoding of MPEG-4/H.263/H.264 up to 30fps

# IP List in Shikhara SoC

The following IPs is integrated in the Shikhara SoC.

| No  | IP/      | Vendor | Version | Number    |                                                      |  |
|-----|----------|--------|---------|-----------|------------------------------------------------------|--|
| 110 | Prime    |        | Number  | of        | Remarks                                              |  |
| •   | Cell     |        |         | instances |                                                      |  |
| 1   | CortexA9 | ARM    | r0p0    | 1         | Main house keeping CPU of the SoC.                   |  |
|     | MPCOR    |        |         |           | Following are the version numbers of main components |  |
|     | E TSMC   |        |         |           | inside the Hard Macro:                               |  |
|     | 40nm     |        |         |           |                                                      |  |
|     | Hard     |        |         |           | <ul> <li>Cortex-A9 MPCore : r3p0</li> </ul>          |  |
|     | Macro    |        |         |           | • CortexA9 NEON : r3p0                               |  |
|     |          |        |         |           | • L2CC: r3p2                                         |  |
|     |          |        |         |           | • PTM-A9: r1p0                                       |  |
|     |          |        |         |           | • ATB/APB asynch briges: r0p0                        |  |
|     |          |        |         |           |                                                      |  |

| 2 | Corelink NIC 301                  | ARM      | r2p3  | 5 | The AMBA Network Interconnect is a highly configurable component that enables to createa complete high performance, optimized AMBA-compliant network infrastructure. The possible configurations for the AMBA Network Interconnect can range up to a complex infrastructure that consists of up to 128 masters and 64 slaves of a combination of different AMBA protocols. It support advanced QoS features. |
|---|-----------------------------------|----------|-------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3 | DMAC<br>(PL330)                   | ARM      | r1p0  | 2 | The DMAC provides an AXI interface to perform the DMA transfers and two APB interfaces that control its operation. The DMAC implements TrustZone® secure technology with one APB interface operating in the Secure state and the other operating in the Non-secure state.                                                                                                                                    |
| 4 | Video<br>subsyste<br>m<br>(AV417) | Synopsys | 1.4   | 1 | The AV417 is a 32-bit microprocessor systemthat provides a powerful package of System-on-Chip (SOC) features to make the modular ARC 700 corecapable of addressing demanding data processing applications and general purpose processing.                                                                                                                                                                    |
| 5 | MALI 400<br>MP                    | ARM      | r1p1  | 1 | The Mali-400 MP GPU is a hardware accelerator for 2D and 3D graphics systems. The GPU consists of:  • one to four Pixel Processors (PPs)  • a Geometry Processor (GP)  • a Level 2 Cache Controller (L2)  • a Memory Management Unit (MMU) for each GP and PP  • a Power Management Unit (PMU).                                                                                                              |
| 6 | USB3.0<br>DRD                     | Synopsys | 2.50a | 1 | USB 3.0 DRD Functions either as a device or a Host at a given time providing, SuperSpeed, High-Speed and Full-Speed Low speed operations.                                                                                                                                                                                                                                                                    |
| 7 | USB3.0<br>HC                      | Synopsys | 2.50a | 1 | USB3.0 Host Controller supports Super Speed, High-Speed, Full-Speed, and Low-Speed Compatible with the xHCI specification from Intel Corporation. It Supports upto 16 USB 2.0 ports and 16 USB 3.0 ports.                                                                                                                                                                                                    |

| 8  | LPDDR2/          | Synopsys      | 1.20a | 1 | The Memory Controller provides means to access the                                                        |  |
|----|------------------|---------------|-------|---|-----------------------------------------------------------------------------------------------------------|--|
|    | DDR3             |               |       |   | external SDRAM memory. The controller is responsible                                                      |  |
|    | Controller       |               |       |   | for all protocols and arbitration and the DDR PHY                                                         |  |
|    |                  |               |       |   | responsible for the double data rate and strobe domain as                                                 |  |
|    |                  |               |       |   | well as signal integrity.                                                                                 |  |
| 9  | Trust Zone       | ARM           | r0p1  | 3 | TZASC (Trust zone Address Space Controller) is high-                                                      |  |
|    | Address          |               |       |   | performance, area-optimized address space controller                                                      |  |
|    | space            |               |       |   | with on-chip AMBA bus interfaces. TZASC can be                                                            |  |
|    | controller       |               |       |   | configured to provide the optimum security address                                                        |  |
|    | Controller       |               |       |   |                                                                                                           |  |
|    |                  |               |       |   | region control functions required for the intended                                                        |  |
| 10 | HDMI Tx          | Synopsys      | 1.31a | 1 | application.  Required for transmitting audio and video information on                                    |  |
| 10 |                  | Зупорзуз      | 1.51α | 1 |                                                                                                           |  |
| 11 | 1.4<br>MIPI CSI2 | Synonsys      | 1.03a | 1 | single cable to the external world The DWC_mipi_csi2_host is designed to receive data                     |  |
|    |                  | Эупороуо      | 1.054 | _ | from a CSI-2 compliant camera sensor. A D-PHY                                                             |  |
|    |                  |               |       |   | -                                                                                                         |  |
| 12 | MIPI DSI         | Synopsys      | 1.21a | 1 | configured as a Slave acts as the physical layer. The DesignWare Cores MIPI DSI Host Controller is a      |  |
|    |                  | - J - F - J - |       |   | digital core that implements all protocol functions defined                                               |  |
|    |                  |               |       |   | in the MIPI DSI specification. The DWC_mipi_dsi_host                                                      |  |
|    |                  |               |       |   | -                                                                                                         |  |
|    |                  |               |       |   | provides an interface between the system and the MIPI D-                                                  |  |
|    |                  |               |       |   | PHY, allowing the communication with a DSI-compliant                                                      |  |
| 10 | LODG             | 4 D3 4        | 0.0   | 4 | display.                                                                                                  |  |
| 13 | LCDC             | ARM           | r0p2  | 1 | The principal features of the CLCD controller are:                                                        |  |
|    | (PL111)          |               |       |   | • it supports single- and dual-panel mono Super Twisted                                                   |  |
|    |                  |               |       |   | Nematic (STN) displays with 4 or 8-bit interfaces • it supports single- and dual-panel color STN displays |  |
|    |                  |               |       |   | • it supports Thin Film Transistor (TFT) color displays                                                   |  |
|    |                  |               |       |   | • resolution programmable up to 1024x768                                                                  |  |
|    |                  |               |       |   | • 15 gray-level mono, 3375 color STN, and 32K color                                                       |  |
|    |                  |               |       |   | <ul><li>palettized TFT support</li><li>16bpp true-color nonpalettized, for color STN and TFT</li></ul>    |  |
|    |                  |               |       |   | • 24bpp true-color nonpalettized, for color TFT                                                           |  |
| 14 | BT               | Mind tree     | 1.0   | 1 | Refer BT subsystem Section for all internal IP's                                                          |  |
|    | Subsyste         |               |       |   |                                                                                                           |  |
|    | m                |               |       |   |                                                                                                           |  |

| 15 | SDMMC          | Synopsys | 2.50a   | 2 | It can be configured either as a Multimedia Card-only                                        |  |
|----|----------------|----------|---------|---|----------------------------------------------------------------------------------------------|--|
|    |                |          |         |   | controller or as a Secure Digital_Multimedia Card                                            |  |
|    |                |          |         |   | controller, which simultaneously supports Secure Digital                                     |  |
|    |                |          |         |   | memory (SD Mem), Secure Digital I/O (SDIO),                                                  |  |
|    |                |          |         |   | Multimedia Cards (MMC), and Consumer Electronics                                             |  |
| 16 | SMC            | ARM      | r2p1    | 1 | Advanced Transport Architecture (CE-ATA).  It is a high-performance, area-optimized SRAM and |  |
|    | (PL353)        |          |         |   | NAND memory controller with on-chip bus interfaces                                           |  |
|    |                |          |         |   | that conform to the AMBA Advanced eXtensible                                                 |  |
|    |                |          |         |   | Interface (AXI) protocol.                                                                    |  |
| 17 | EBI            | ARM      | r0p0    | 1 | ARM Prime Cell EBI (PL 220) is an External Bus                                               |  |
|    |                |          |         |   | Interface Standard to provide arbitration between the Two                                    |  |
|    |                |          |         |   | SMC Memory Interfaces requiring access to data and                                           |  |
|    |                |          |         |   | address bus.                                                                                 |  |
| 18 | AXI2ME         | ARM      | r0p0    | 4 | Used to convert the AXI signals to Onchip RAM/ROM                                            |  |
|    | M              |          |         |   | signals. It is used to connect Onchip RAM, Onchip ROM                                        |  |
|    | (BP140)        |          |         |   | with Main nic. Other one is used in Video Subsys to                                          |  |
|    |                |          |         |   | connect with Internal NIC301 of VSS. Other is used to                                        |  |
|    |                |          |         |   | connect with Internal NIC301 of BTSS.                                                        |  |
| 19 | SPI            | ARM      | r1p3    | 3 | Used to transmit or receive synchronous serial data and it                                   |  |
|    | Controlle<br>r |          |         |   | does parallel to serial or serial to parallel conversions.                                   |  |
| 20 | GPIO           | ARM      | First   | 4 | The GPIO Supports the following features:                                                    |  |
|    | (PL061)        |          | release |   | • Eight individually programmable I/O Pins, default to                                       |  |
|    |                |          |         |   | input at reset.                                                                              |  |
|    |                |          |         |   | • Programmable Interrupt Generation capability from a                                        |  |
|    |                |          |         |   | transition or a level condition on any number of pins.                                       |  |
|    |                |          |         |   | Bit masking in both read and write operations through                                        |  |
|    |                |          |         |   | address lines.                                                                               |  |
| 21 | I2C            | Synopsys | 1.10a   | 3 | I2C's are required for ARM sub system and                                                    |  |
|    |                |          |         |   | Configuration of Camera and interfacing for any off-chip                                     |  |
| 22 | IDC            | C        | 1.04    | 1 | EEPROM's.                                                                                    |  |
| 22 | I2S            | Synopsys | 1.04a   | 1 | Configurable number of stereo channels (upto 4) for both                                     |  |
|    |                |          |         |   | tx and rx. Supports audio data resolutions of 12,16,20,24                                    |  |
|    |                |          |         |   | and 32 bits.                                                                                 |  |

| 22  | CAN       | 0         | TDD     | 4 | In and the Distributed made in Control of Its 2.1.              |
|-----|-----------|-----------|---------|---|-----------------------------------------------------------------|
| 23  | CAN       | Opencores | TBD     | 1 | Is used for Distributed real time Control with High level       |
| 5.4 | C C 1     | 4 D 1 6   | 2.0     |   | of Security                                                     |
| 24  |           | ARM       | r2p0    | 1 | The CoreSight architecture provides a system wide               |
|     | DK A9     |           |         |   | solution to real-time debug and trace. It recognizes:           |
|     |           |           |         |   | • The requirement for multi-core debug and trace.               |
|     |           |           |         |   | • The requirement to debug and trace the whole system           |
|     |           |           |         |   | beyond the core, for example buses.                             |
|     |           |           |         |   | • The requirement to share resources, such as pins and          |
|     |           |           |         |   | trace storage, between debug and trace components, to           |
|     |           |           |         |   | keep silicon costs down.                                        |
| 25  | GNSS      | Accord    | TBD     | 1 | ACC GNSS DBB IP is silicon proven high performance,             |
|     |           |           |         |   | fast TTFF, massive correlator architecture                      |
|     |           |           |         |   | GPS/QZSS/SBAS and GLONASS Baseband designed for                 |
|     |           |           |         |   | low power and high performance applications                     |
| 26  | NVM       | Synopsys  | 1.02a   | 1 | The                                                             |
|     |           |           |         |   | AEONMTP_AF_128R32CEH0P0Q32I32W0X1Y_K2 is                        |
|     |           |           |         |   | a multiple-time-programmable (MTP), 4096-bit                    |
|     |           |           |         |   | nonvolatile memory (NVM) block compatible with the              |
|     | _         |           |         |   | TSMC 40 nm LP CMOS process.                                     |
| 27  | RTC       | ARM       | First   | 1 | The RTC can be used to provide a basic alarm function or        |
|     | (PL031)   |           | release |   | long time base counter. This is achieved by generating an       |
|     |           |           |         |   | interrupt signal after counting for a programmed number         |
|     |           |           |         |   | of cycles of a real-time clock input.                           |
| 28  | WDT       | ARM       | r1p0    | 1 | The WDT is a 32-bit down counter with a programmable            |
|     |           |           |         |   | timeout interval that generates an Interrupt output on          |
|     |           |           |         |   | timeout.                                                        |
| 29  | DT(SP804  | ARM       | r1p0    | 2 | The Dual-Timer module consists of two programmable              |
|     | )         |           |         |   | 32/16-bit down counters that can generate interrupts on         |
|     |           |           |         |   | reaching zero.                                                  |
| 30  | UART      | ARM       | r1p5    | 8 | The UART is an AMBA slave module that connects to the           |
|     | Controlle |           |         |   | Advanced Peripheral Bus(APB). The UART includes an              |
|     |           |           |         |   | Infrared Data Association (IrDA) Serial InfraRed (SIR) protocol |
|     | r (PL011) |           |         |   | ENcoder/DECoder (ENDEC).                                        |
| 31  | AHB2AXI   | ARM       | r0p0    | 1 | Bridge is used for Coresight. Coresight is connected to         |
|     | Bridge    |           |         |   | NIC301 through this bridge.                                     |
|     |           |           |         |   |                                                                 |

| 32 | Key board  | ARM | Third   | 1 | Key board mouse interface to the SoC |
|----|------------|-----|---------|---|--------------------------------------|
|    | Mouse      |     | Release |   |                                      |
|    | controller |     |         |   |                                      |
|    | (PL050)    |     |         |   |                                      |

# **Device Tree**

## **MP CORE:**

|         | SCU           | 256B  | 0xD46F_2000 | 0xD46F_20FF | "arm,cortex-a9-scu"     |
|---------|---------------|-------|-------------|-------------|-------------------------|
|         | GIC-Interface | 256B  | 0xD46F_2100 | 0xD46F_21FF | "arm,cortex-a9-gic"     |
| Cortex  | GT            | 256B  | 0xD46F_2200 | 0xD46F_22FF | "arm,cortex-a9-global-  |
| A9 Dual |               |       |             |             | timer"                  |
| core    | RESERVED      | 768B  | 0xD46F_2300 | 0xD46F_25FF |                         |
| Process | PT and WDT    | 256B  | 0xD46F_2600 | 0xD46F_26FF | "arm,cortex-a9-twd-wdt" |
| or      | RESERVED      | 2304B | 0xD46F_2700 | 0xD46F_2FFF |                         |
|         | GIC-          | 4KB   | 0xD46F_3000 | 0xD46F_3FFF | "arm,cortex-a9-gic"     |
|         | Distributor   |       |             |             | _                       |
|         | L2CC          | 4KB   | 0xD46F_4000 | 0xD46F_4FFF | "arm,pl310-cache"       |

# **IP List in Shikhara SoC – Address Map**

| IP     | SIZE | START-<br>ADDRESS | END-<br>ADDRESS | Compatible                      | Configuration Tag                                               |
|--------|------|-------------------|-----------------|---------------------------------|-----------------------------------------------------------------|
| GPIO-0 | 4KB  | 0xD457_6000       | 0xD457_6FFF     | arm,pl061",<br>"arm,primecell"  | CONFIG_GPIO_PL061=y                                             |
| GPIO-1 | 4KB  | 0xD457_7000       | 0xD457_7FFF     | arm,pl061",<br>"arm,primecell"  | CONFIG_GPIO_PL061=y                                             |
| GPIO-2 | 4KB  | 0xD457_8000       | 0xD457_8FFF     | arm,pl061",<br>"arm,primecell"  | CONFIG_GPIO_PL061=y                                             |
| GPIO-3 | 4KB  | 0xD457_9000       | 0xD457_9FFF     | arm,pl061",<br>"arm,primecell"  | CONFIG_GPIO_PL061=y                                             |
| UART-0 | 4KB  | 0xD457_B000       | 0xD457_BFFF     | "arm,pl011",<br>"arm,primecell" | CONFIG_SERIAL_AMB A_PL011=y CONFIG_SERIAL_AMB A_PL011_CONSOLE=y |
| UART-1 | 4KB  | 0xD457_C000       | 0xD457_CFFF     | "arm,pl011",<br>"arm,primecell" | CONFIG_SERIAL_AMB<br>A_PL011=y                                  |

|        |     |             |             |                                 | CONFIG_SERIAL_AMB<br>A_PL011_CONSOLE=y                                   |
|--------|-----|-------------|-------------|---------------------------------|--------------------------------------------------------------------------|
| UART-2 | 4KB | 0xD457_D000 | 0xD457_DFFF | "arm,pl011",<br>"arm,primecell" | CONFIG_SERIAL_AMB A_PL011=y CONFIG_SERIAL_AMB A_PL011_CONSOLE=y          |
| UART-3 | 4KB | 0xD457_E000 | 0xD457_EFFF | "arm,pl011",<br>"arm,primecell" | CONFIG_SERIAL_AMB A_PL011=y CONFIG_SERIAL_AMB A_PL011_CONSOLE=y          |
| UART-4 | 4KB | 0xD457_F000 | 0xD457_FFFF | "arm,pl011",<br>"arm,primecell" | CONFIG_SERIAL_AMB A_PL011=y CONFIG_SERIAL_AMB A_PL011_CONSOLE=y          |
| I2C-0  | 4KB | 0xD458_2000 | 0xD458_2FFF | "snps,designware-<br>i2c"       | CONFIG_I2C_DESIGNW<br>ARE_CORE=y<br>CONFIG_I2C_DESIGNW<br>ARE_PLATFORM=y |
| I2C-1  | 4KB | 0xD458_3000 | 0xD458_3FFF | "snps,designware-<br>i2c"       | CONFIG_I2C_DESIGNW<br>ARE_CORE=y<br>CONFIG_I2C_DESIGNW<br>ARE_PLATFORM=y |
| I2C-2  | 4KB | 0xD458_4000 | 0xD458_4FFF | "snps,designware-<br>i2c"       | CONFIG_I2C_DESIGNW<br>ARE_CORE=y<br>CONFIG_I2C_DESIGNW<br>ARE_PLATFORM=y |
| SPI-0  | 4KB | 0xD457_2000 | 0xD457_2FFF | "arm,pl022",<br>"arm,primecell" | CONFIG_SPI_PL022=y                                                       |
| SPI-1  | 4KB | 0xD457_3000 | 0xD457_3FFF | "arm,pl022",<br>"arm,primecell" | CONFIG_SPI_PL022=y                                                       |
| DT-0   | 4KB | 0xD456_E000 | 0xD456_EFFF | "arm,sp804",<br>"arm,primecell" | CONFIG_ARM_TIMER_<br>SP804=y                                             |
| DT-1   | 4KB | 0xD456_F000 | 0xD456_FFFF | "arm,sp804",<br>"arm,primecell" | CONFIG_ARM_TIMER_<br>SP804=y                                             |
| RTC    | 4KB | 0xD45A_3000 | 0xD45A_3FFF | "arm,pl030",<br>"arm,primecell" | CONFIG_RTC_DRV_PL0<br>30=y<br>CONFIG_RTC_DRV_PL0<br>31=y                 |
| WDT    | 4KB | 0xD457_1000 | 0xD457_1FFF | "arm,sp805",<br>"arm,primecell" | CONFIG_ARM_SP805_W<br>ATCHDOG=y                                          |
| CLCD   | 4KB | 0xD455_4000 | 0xD455_4FFF | "arm,pl111",<br>"arm,primecell" |                                                                          |
| SD/MMC | 4KB | 0xD455_5000 | 0xD455_5FFF | "snps,dw-mshc"                  | CONFIG_MMC_DW=y                                                          |

|      |     |             |             |                | CONFIG_MMC_DW_PLT<br>FM=y                    |
|------|-----|-------------|-------------|----------------|----------------------------------------------|
| SDIO | 4KB | 0xD455_6000 | 0xD455_6FFF | "snps,dw-mshc" | CONFIG_MMC_DW=y<br>CONFIG_MMC_DW_PLT<br>FM=y |

# IRQ LIST

| SL.No | IP                                         | Interrupts     | Signal<br>Level       | GIC[#]     | Comment                  |
|-------|--------------------------------------------|----------------|-----------------------|------------|--------------------------|
| 1     | Cortex-A9 MPCore Speed Optimized macrocell | 1 (L2CC)       | Active<br>High        | GIC[0]     |                          |
| 2     |                                            | 1 (SCUEVABORT) | Edge<br>Trigge<br>red | GIC[1]     |                          |
| 3     | GNSS                                       | 1              | Active<br>High        | GIC[2]     |                          |
| 4     | TZASC0                                     | 1              | Active<br>High        | GIC[3]     |                          |
| 5     | TZASC1                                     | 1              | Active<br>High        | GIC[4]     |                          |
| 6     | TZASC2                                     | 1              | Active<br>High        | GIC[5]     |                          |
| 7     | LPDDR2/DDR<br>3                            | 3              | Active<br>High        | GIC[8:6]   |                          |
| 8     | DMA64_M2M                                  | 2              | Active<br>High        | GIC[10:9]  |                          |
| 9     | CSI BRIDGE                                 | 1              |                       | GIC[11]    |                          |
| 10    | MIPI CSI2                                  | 2              | Active<br>High        | GIC[13:12] |                          |
| 11    | DSI BRIDGE                                 | 1              |                       | GIC[14]    |                          |
| 12    | MIPI DSI                                   | 1              | Active<br>High        | GIC[15]    |                          |
| 13    | CLCD                                       | 1              | Active<br>High        | GIC[16]    | CLCD TOUCH_IRQ interrupt |

| 14 | HDMI<br>BRIDGE     | 1  |                | GIC[17]    |                                                                                                                                                                   |
|----|--------------------|----|----------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15 | HDMI TX            | 2  |                | GIC[19:18] | Need to discuss regarding levels of signals (Active High/Low).                                                                                                    |
| 16 | USB3.0 Host        | 1  | Active<br>High | GIC[20]    | 1024 interrupts can be configured (for the worst case) but the decision on # of interrupts is based on the number of interrupts supported by USB Driver.          |
|    |                    |    |                |            | The two Interrupts available are "bc _interrupt" and " interrupt".                                                                                                |
| 17 | USB3.0 DRD         | 2  | Active<br>High | GIC[22:21] | 1024 interrupts can be configured (for the worst case for host) but the decision on # of interrupts is based on the number of interrupts supported by USB Driver. |
| 18 | CLCD<br>Controller | 1  | Active<br>High | GIC[23]    |                                                                                                                                                                   |
| 19 | IPC(AV417)         | 1  | Active<br>High | GIC[24]    |                                                                                                                                                                   |
| 20 | MALI 400MP         | 11 | Active<br>High | GIC[35:25] |                                                                                                                                                                   |
| 21 | DMAC_0             | 2  | Active<br>High | GIC[37:36] |                                                                                                                                                                   |
| 22 | SDMMC              | 1  | Active High.   | GIC[38]    |                                                                                                                                                                   |
| 23 | SDIO               | 1  | Active High.   | GIC[39]    |                                                                                                                                                                   |
| 24 | WDT                | 1  | Active<br>High | GIC[40]    |                                                                                                                                                                   |
| 25 | DT_0               | 1  | Active<br>High | GIC[41]    |                                                                                                                                                                   |
| 26 | DT_1               | 1  | Active<br>High | GIC[42]    |                                                                                                                                                                   |
| 27 | SMC                | 1  | Active<br>High | GIC[43]    |                                                                                                                                                                   |
| 28 | UART_0             | 1  | Active<br>High | GIC[44]    |                                                                                                                                                                   |

| 29 | UART_1                                              | 1           | Active<br>High | GIC[45]    |               |
|----|-----------------------------------------------------|-------------|----------------|------------|---------------|
| 30 | UART_2                                              | 1           | Active<br>High | GIC[46]    |               |
| 31 | UART_3                                              | 1           | Active<br>High | GIC[47]    |               |
| 32 | Cortex-A9<br>MPCore Speed<br>Optimized<br>macrocell | 2 (CTI-IRQ) | Active<br>Low  | GIC[49:48] |               |
| 33 |                                                     | 2 (PUMIRQ)  | Active<br>High | GIC[51:50] |               |
| 34 |                                                     | 2 (COMMRX)  | Active<br>High | GIC[53:52] |               |
| 35 |                                                     | 2 (COMMTX)  | Active<br>High | GIC[55:54] |               |
| 36 | GPIO_0                                              | 1           | Active<br>High | GIC[56]    |               |
| 37 | GPIO_1                                              | 1           | Active<br>High | GIC[57]    |               |
| 38 | GPIO_2                                              | 1           | Active<br>High | GIC[58]    |               |
| 39 | GPIO_3                                              | 1           | Active<br>High | GIC[59]    |               |
| 40 | I2S                                                 | 1           | Active<br>High | GIC[60]    |               |
| 41 | RTC                                                 | 1           | Active<br>High | GIC[61]    |               |
| 42 | SPI _0                                              | 1           | Active<br>High | GIC[62]    |               |
| 43 | SPI _1                                              | 1           | Active<br>High | GIC[63]    |               |
| 44 | KMI                                                 | 1           | Active<br>High | GIC[64]    |               |
| 45 | CAN                                                 | 1           | Active<br>Low  | GIC[65]    |               |
| 46 | I2C_0                                               | 1           | Active<br>High | GIC[66]    |               |
| 47 | I2C_1                                               | 1           | Active High    | GIC[67]    |               |
| 48 | I2C_2                                               | 1           | Active High    | GIC[68]    |               |
| 49 | BTSS                                                | 7           | Active<br>High | GIC[75:69] |               |
| 50 | LPDDR2/DDR<br>3                                     | 1           | Active<br>High | GIC[76]    | SBR_DONE_INTR |

| 51 | GNSS | 1 | Active<br>High | GIC[77] |  |
|----|------|---|----------------|---------|--|
| 52 | PMU  | 1 | Active<br>High | GIC[78] |  |

## Mach-shikhara

## Step 1: mach-shikhara

arch/arm/Kconfig ---> add the following line

source "arch/arm/mach-shikhara/Kconfig"

create directory: arch/arm/mach-shikhara

#### Patch:

diff --git a/arch/arm/Kconfig b/arch/arm/**Kconfig** index c0fcab6..3e27646 100644 --- a/arch/arm/Kconfig +++ b/arch/arm/Kconfig @@ -808,6 +808,8 @@ source "arch/arm/mach-socfpga/Kconfig"

source "arch/arm/mach-spear/Kconfig"

+source "arch/arm/mach-shikhara/Kconfig"

Т

source "arch/arm/mach-sti/Kconfig"

source "arch/arm/mach-stm32/Kconfig"

# Step 2: UART PHY, UART VIRT

#### Patch:

diff --git a/arch/arm/Kconfig.debug b/arch/arm/**Kconfig.debug** index 426d271..afdedfb 100644
--- a/arch/arm/Kconfig.debug
+++ b/arch/arm/Kconfig.debug
@@ -1070,6 +1070,14 @@ choice
Say Y here if you want kernel low-level debugging support on ST SPEAr13xx based platforms.

- + config DEBUG\_SHIKHARA
- + bool "Kernel low-level debugging messages via MOSCHIP Shikhara PL011 UARTO"
- + depends on ARCH\_MOSCHIP

```
select DEBUG_UART_PL01X
+
+
        help
         Say Y here if you want kernel low-level debugging support
+
         on Moschip Shikhara based platforms.
   config STIH41X_DEBUG_ASC2
       bool "Use StiH415/416 ASC2 UART for low-level debug"
       depends on ARCH STI
@@ -1514,6 +1522,7 @@ config DEBUG_UART_PHYS
   default 0xd4017000 if DEBUG MMP UART2
   default 0xd4018000 if DEBUG_MMP_UART3
   default 0xe0000000 if DEBUG SPEAR13XX
    default 0xd457b000 if DEBUG_SHIKHARA
   default 0xe4007000 if DEBUG_HIP04_UART
   default 0xe6c40000 if DEBUG RMOBILE SCIFA0
   default 0xe6c50000 if DEBUG RMOBILE SCIFA1
@@ -1608,6 +1617,7 @@ config DEBUG_UART_VIRT
   default 0xfc705000 if DEBUG ZTE ZX
   default 0xfcfe8600 if DEBUG_BCM63XX_UART
   default 0xfd000000 if DEBUG SPEAR3XX || DEBUG SPEAR13XX
    default 0xf457b000 if DEBUG_SHIKHARA
   default 0xfd012000 if DEBUG MVEBU UARTO ALTERNATE && ARCH MV78XX0
   default 0xfd883000 if DEBUG_ALPINE_UART0
   default 0xfde12000 if DEBUG_MVEBU_UART0_ALTERNATE && ARCH_DOVE
```

### shikhara\_defconfig:

CONFIG\_DEBUG\_LL=y
CONFIG\_DEBUG\_LL\_UART\_PL01X=y
CONFIG\_DEBUG\_LL\_INCLUDE="debug/pl01x.S"
CONFIG\_DEBUG\_UART\_PHYS=0xd457b000
CONFIG\_DEBUG\_UART\_VIRT=0xf457b000
CONFIG\_DEBUG\_UNCOMPRESS=y
CONFIG\_UNCOMPRESS\_INCLUDE="debug/uncompress.h"
CONFIG\_EARLY\_PRINTK=y

# Step 3: Kconfig, Makefile

#### arch/arm/mach-shikhara/Kconfig

menuconfig ARCH\_MOSCHIP
bool "MOSCHIP SHIKHARA family"
depends on ARCH\_MULTI\_V7
select ARM\_AMBA
select ARM\_GIC
select ARM\_GLOBAL\_TIMER
select ARM\_TIMER\_SP804
select GPIOLIB

```
select HAVE_ARM_SCU if SMP
select HAVE_ARM_TWD if SMP
select PINCTRL
select MFD_SYSCON
help
This option enables support Moschip shikhara EVB
```

You must boot using a Flattened Device Tree in order to use these platforms. The traditional (ATAGs) boot method is not usable on these boards with this option.

endif

#### arch/arm/mach-shikhara/Makefile

```
# # Shikhara Platform specific Makefile
# ccflags-$(CONFIG_ARCH_MULTIPLATFORM) := -I$(srctree)/$(src)/include

smp-$(CONFIG_SMP) += headsmp.o platsmp.o

smp-$(CONFIG_HOTPLUG_CPU) += hotplug.o

obj-$(CONFIG_ARCH_SHIKHARA) += shikhara.o $(smp-y)

CFLAGS_hotplug.o += -march=armv7-a
```

## Step 4: platsmp.c

#### arch/arm/mach-shikhara/platsmp.c

```
/*
 * linux/arch/arm/mach-shikhara/platsmp.c
 *
 * Copyright (C) 2002 ARM Ltd.
 * All Rights Reserved
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 */
#include linux/init.h>
#include <linux/errno.h>
#include <linux/smp.h>
#include <linux/io.h>
```

```
#include linux/of_address.h>
#include linux/vexpress.h>
#include <asm/mcpm.h>
#include <asm/smp_scu.h>
#include <asm/mach/map.h>
#include "generic.h"
* Write pen_release in a way that is guaranteed to be visible to all
* observers, irrespective of whether they're taking part in coherency
* or not. This is necessary for the hotplug code to work reliably.
static void write_pen_release(int val)
{
       pen_release = val;
       smp_wmb();
       sync_cache_w(&pen_release);
}
static DEFINE_SPINLOCK(boot_lock);
static void shikhara_secondary_init(unsigned int cpu)
       * let the primary processor know we're out of the
       * pen, then head off into the C entry point
       write_pen_release(-1);
       * Synchronise with the boot thread.
       spin_lock(&boot_lock);
       spin_unlock(&boot_lock);
}
static int shikhara_boot_secondary(unsigned int cpu, struct task_struct *idle)
       unsigned long timeout;
       * set synchronisation state between this boot processor
       * and the secondary one
       spin lock(&boot lock);
       /*
```

```
* The secondary processor is waiting to be released from
        * the holding pen - release it, then wait for it to flag
        * that it has been released by resetting pen_release.
        * Note that "pen_release" is the hardware CPU ID, whereas
        * "cpu" is Linux's internal ID.
       write_pen_release(cpu);
       timeout = jiffies + (1 * HZ);
       while (time_before(jiffies, timeout)) {
              smp_rmb();
              if (pen_release == -1)
                      break:
              udelay(10);
       }
        * now the secondary core is starting up let it run its
        * calibrations, then wait for it to finish
       spin_unlock(&boot_lock);
       return pen_release != -1 ? -ENOSYS : 0;
}
static const struct of_device_id shikhara_smp_dt_scu_match[] __initconst = {
       { .compatible = "arm,cortex-a9-scu", },
       {}
};
static void __init shikhara_smp_dt_prepare_cpus(unsigned int max_cpus)
{
       struct device_node *scu = of_find_matching_node(NULL,
                      shikhara_smp_dt_scu_match);
       if (scu)
              scu_enable(of_iomap(scu, 0));
        * Write the address of secondary startup into the
        * system-wide flags register. The boot monitor waits
        * until it receives a soft interrupt, and then the
        * secondary CPU branches to this address.
        */
       //__raw_writel(__pa_symbol(shikhara_secondary_startup), SYS_LOCATION);
}
```

```
const struct smp_operations shikhara_smp_dt_ops __initconst = {
          .smp_prepare_cpus = shikhara_smp_dt_prepare_cpus,
          .smp_secondary_init = shikhara_secondary_init,
          .smp_boot_secondary = shikhara_boot_secondary,
#ifdef CONFIG_HOTPLUG_CPU
          .cpu_die = shikhara_cpu_die,
#endif
};
```

## Step 5: hotplug.c

```
arch/arm/mach-shikhara/hotplug.c
* linux/arch/arm/mach-shikhara/hotplug.c
* Copyright (C) 2012 ST Microelectronics Ltd.
* Deepak Sikri <deepak.sikri@st.com>
* based upon linux/arch/arm/mach-realview/hotplug.c
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*/
#include linux/kernel.h>
#include linux/errno.h>
#include linux/smp.h>
#include <asm/cp15.h>
#include <asm/smp_plat.h>
static inline void cpu_enter_lowpower(void)
       unsigned int v;
       asm volatile(
                     p15, 0, %1, c7, c5, 0\n"
       11
              dsb\n"
       * Turn off coherency
       */
                     p15, 0, %0, c1, c0, 1\n"
              mrc
       "
              bic
                     %0, %0, #0x20\n"
                     p15, 0, %0, c1, c0, 1\n"
              mcr
       "
                     p15, 0, %0, c1, c0, 0\n"
              mrc
```

%0, %0, %2\n"

bic

```
p15, 0, %0, c1, c0, 0\n"
              mcr
       : "=&r" (v)
       : "r" (0), "Ir" (CR_C)
       : "cc", "memory");
}
static inline void cpu_leave_lowpower(void)
       unsigned int v;
       asm volatile("mrc
                             p15, 0, %0, c1, c0, 0\n"
                      %0, %0, %1\n"
              orr
                     p15, 0, %0, c1, c0, 0\n"
              mcr
                     p15, 0, %0, c1, c0, 1\n"
              mrc
       "
                     %0, %0, #0x20\n"
              orr
                     p15, 0, %0, c1, c0, 1\n"
              mcr
       : "=&r" (v)
       : "Ir" (CR_C)
       : "cc");
}
static inline void shikhara_do_lowpower(unsigned int cpu, int *spurious)
       for (;;) {
              wfi();
              if (pen_release == cpu) {
                      * OK, proper wakeup, we're done
                      break;
               }
               * Getting here, means that we have come out of WFI without
               * having been woken up - this shouldn't happen
               * Just note it happening - when we're woken, we can report
               * its occurrence.
              (*spurious)++;
       }
}
* platform-specific code to shutdown a CPU
* Called with IRQs disabled
```

## Step 6: shikhara.c

#include linux/init.h>

arch/arm/mach-shikhara/shikhara.c

```
* shikhara board support using the device tree
* Copyright (C) 2010 Secret Lab Technologies Ltd.
* Copyright (C) 2009 Jeremy Kerr < jeremy.kerr@canonical.com>
* Copyright (C) 2004 ARM Limited
* Copyright (C) 2000 Deep Blue Solutions Ltd
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
```

```
#include linux/io.h>
#include linux/of.h>
#include linux/of address.h>
#include linux/of_irq.h>
#include linux/of platform.h>
#include linux/slab.h>
#include linux/amba/bus.h>
#include linux/amba/mmci.h>
#include <asm/mach-types.h>
#include <asm/mach/arch.h>
static const char *const shikhara dt match[] initconst = {
      "moschip,shikhara-evb",
      "moschip,shikhara",
      NULL,
};
DT_MACHINE_START(MOSCHIP_SHIKHARA,"MOSCHIP-SHIKHARA-EVB")
      .dt_compat
                   = shikhara_dt_match
MACHINE END
```

## Step 7: generic.h

#### arch/arm/mach-shikhara/generic.h

void shikhara\_cpu\_die(unsigned int cpu);

```
/*
 * spear machine family generic header file
 *
 * Copyright (C) 2009-2012 ST Microelectronics
 * Rajeev Kumar <rajeev-dlh.kumar@st.com>
 * Viresh Kumar <vireshk@kernel.org>
 *
 * This file is licensed under the terms of the GNU General Public
 * License version 2. This program is licensed "as is" without any
 * warranty of any kind, whether express or implied.
 */

#ifndef __MACH_GENERIC_H
#define __MACH_GENERIC_H
#include linux/dmaengine.h>
#include linux/reboot.h>
#include linux/reboot.h>
#include <a href="mailto:asm/mach/time.h">
#include <a href="mailto:
```

## **Step 7: Device Tree**

arch/arm/boot/dts/shikhara.dts

```
/*
*Reference: DTS file for all Shikahara SoCs
/dts-v1/;
/include/ "skeleton.dtsi"
/ {
    model = "shikhara";
    compatible = "moschip,shikhara-evb", "moschip,shikhara";
    interrupt-parent = <&gic>;
    #address-cells = <1>;
    #size-cells = <1>;
       cpus {
              #address-cells = <1>;
              #size-cells = <0>;
              cpu@0 {
                     compatible = "arm,cortex-a9";
                     device_type = "cpu";
                     reg = <0>;
              };
              cpu@1 {
                     compatible = "arm,cortex-a9";
                     device_type = "cpu";
                     reg = <1>;
              };
       };
   mpcore {
         compatible = "simple-bus";
         #address-cells = <1>;
         #size-cells = <1>;
          scu: snoop-control-unit@d46f2000 {
            compatible = "arm,cortex-a9-scu";
              reg = <0xd46f2000 0x100>;
         };
          timer@d4652200 {
              compatible = "arm,cortex-a9-global-timer";
              reg = <0xd4652200 0x100>;
```

```
};
  watchdog@d46f2600 {
       compatible = "arm,cortex-a9-twd-wdt";
       reg = <0xd46f2600 0x100>;
  };
  gic: interrupt-controller@d46f3000 {
      compatible = "arm,cortex-a9-gic";
      interrupt-controller;
      #interrupt-cells = <3>;
      reg = < 0xd46f3000 0x1000 >,
                     < 0xd46f2100 0x0200 >;
  };
 L2: cache-controller@8000 {
       compatible = "arm,pl310-cache";
       reg = <0x8000 0x1000>;
       cache-unified:
       cache-level = <2>;
       arm,double-linefill-incr = <1>;
       arm,double-linefill-wrap = <0>;
       arm,double-linefill = <1>;
             prefetch-data = <1>;
 };
};
memory {
      name = "memory";
      device_type = "memory";
      reg = <0x0000000000x800000000>;
};
chosen {
      bootargs = "console=ttyAMA0,115200";
};
xtal24mhz: xtal24mhz@24M {
      #clock-cells = <0>;
      compatible = "fixed-clock";
      clock-frequency = <24000000>;
};
pclk: pclk@24M {
      #clock-cells = <0>;
      compatible = "fixed-factor-clock";
      clock-div = <1>;
      clock-mult = <1>;
      clocks = <&xtal24mhz>;
};
timclk: timclk@1M {
             #clock-cells = <0>;
```

```
compatible = "fixed-factor-clock";
              clock-div = <24>;
              clock-mult = <1>;
              clocks = <&xtal24mhz>;
};
apb {
              #address-cells = <1>;
              #size-cells = <1>;
              compatible = "simple-bus";
              gpio0: gpio@d4576000 {
                     compatible = "arm,pl061", "arm,primecell";
                     reg = <0xd4576000 0x1000>;
                     interrupts = <0.56.0x4>;
                     gpio-controller;
                     \#gpio-cells = <2>;
                     interrupt-controller;
                     #interrupt-cells = <2>;
                     status = "disabled";
              };
              gpio1: gpio@d4577000 {
                     compatible = "arm,pl061", "arm,primecell";
                     reg = <0xd4577000 0x1000>;
                     interrupts = <0.57.0x4>;
                     gpio-controller;
                     \#gpio-cells = <2>;
                     interrupt-controller;
                     #interrupt-cells = <2>;
                     status = "disabled";
              };
              gpio2: gpio@d4578000 {
                   compatible = "arm,pl061", "arm,primecell";
                   reg = <0xD4578000 0x1000>;
                   interrupts = <0.58.0x4>;
                   gpio-controller;
                   #gpio-cells = <2>;
                   interrupt-controller;
                   #interrupt-cells = <2>;
                   status = "disabled";
            };
              gpio3: gpio@d4579000 {
                   compatible = "arm,pl061", "arm,primecell";
                   reg = <0xd4579000 0x1000>;
                   interrupts = <0.59.0x4>;
                   gpio-controller;
                   #gpio-cells = <2>;
```

```
interrupt-controller;
      #interrupt-cells = <2>;
      status = "disabled";
 };
 uart0: uart@d457b000 {
        compatible = "arm,pl011", "arm,primecell";
        reg = <0xd457b000 0x1000>;
        interrupts = <0.44.0x4>;
        clocks = <&xtal24mhz>, <&pclk>;
        clock-names = "uartclk", "apb_pclk";
 };
 uart1: uart@d457c000 {
        compatible = "arm,pl011", "arm,primecell";
        reg = <0xd457c000 0x1000>;
        interrupts = <0.45.0x4>;
        clocks = <&xtal24mhz>, <&pclk>;
        clock-names = "uartclk", "apb_pclk";
 };
 uart2: uart@d457d000 {
        compatible = "arm,pl011", "arm,primecell";
        reg = <0xd457c000 0x1000>;
        interrupts = <0.46.0x4>;
        clocks = <&xtal24mhz>, <&pclk>;
        clock-names = "uartclk", "apb_pclk";
 };
 uart3: uart@d457e000 {
      compatible = "arm,pl011", "arm,primecell";
      reg = <0xd457e000 0x1000>;
      interrupts = <0.47.0x4>;
      clocks = <&xtal24mhz>, <&pclk>;
      clock-names = "uartclk", "apb_pclk";
};
 uart4: uart@d457f000 {
      compatible = "arm,pl011", "arm,primecell";
      reg = <0xd457f000 0x1000>;
      interrupts = <0.48.0x4>;
      clocks = <&xtal24mhz>, <&pclk>;
      clock-names = "uartclk", "apb_pclk";
 };
 timer0: timer@d456e000 {
        compatible = "arm,sp804", "arm,primecell";
        reg = <0xd456e000 0x1000>;
```

```
interrupts = <0.41.0x4>;
       clocks = <&timclk>, <&timclk>, <&pclk>;
       clock-names = "timer0", "timer1", "apb_pclk";
};
timer1: timer@d456f000 {
       compatible = "arm,sp804", "arm,primecell";
       reg = <0xd456f000 0x1000>;
       interrupts = <0.42.0x4>;
       clocks = <&timclk>, <&timclk>, <&pclk>;
       clock-names = "timer0", "timer1", "apb_pclk";
};
watchdog@d4571000 {
       compatible = "arm,sp805", "arm,primecell";
       reg = <0xd4571000 0x1000>;
       interrupts = <0.40.4>;
       clocks = <&timclk>, <&pclk>;
       clock-names = "wdogclk", "apb_pclk";
};
rtc1: rtc@d45a3000 {
       compatible = "arm,pl030", "arm,primecell";
       reg = <0xd45a3000 0x1000>;
       interrupts = <0.61.0x4>;
       clocks = <&pclk>;
       clock-names = "apb_pclk";
};
i2c0: i2c@d4582000 {
       #address-cells = <1>;
       \#size-cells = <0>;
       compatible = "snps,designware-i2c";
       reg = <0xd452000 0x1000>;
       interrupts = <0.66.0x4>;
       status = "disabled";
};
i2c1: i2c@d453000 {
       #address-cells = <1>;
       \#size-cells = <0>;
       compatible = "snps,designware-i2c";
       reg = <0xd4583000 0x1000>;
       interrupts = <0.67.0x4>;
       status = "disabled";
};
i2c2: i2c@d4584000 {
       #address-cells = <1>;
       \#size-cells = <0>;
       compatible = "snps,designware-i2c";
```

```
reg = <0xd4584000 0x1000>;
                            interrupts = <0.68.0 \times 4>;
                            status = "disabled";
                     };
                     spi0: spi@d4572000 {
                            compatible = "arm,pl022", "arm,primecell";
                            reg = <0xd4572000 0x1000>;
                            #address-cells = <1>;
                            #size-cells = <0>;
                            interrupts = <0.62.0x4>;
                            status = "disabled";
                     };
                     spi1: spi@d4573000 {
                            compatible = "arm,pl022", "arm,primecell";
                            reg = <0xd4573000 0x1000>;
                            #address-cells = <1>;
                            #size-cells = <0>;
                            interrupts = <0.63.0x4>;
                            status = "disabled";
                     };
                     lcdc: lcd-controller@d4554000 {
                            compatible = "arm,pl111", "arm,primecell";
                            reg = <0xd4554000 0x1000>;
                            interrupts = <0.23.0x4>;
                            status = "disabled";
                     };
                     mmcsd0: mmcsd@d4555000 {
                            compatible = "snps,dw-mshc";
                            reg = <0xd4555000 0x1000>;
                            interrupts = <0.38.0x4>;
                            num-slots = <1>;
                            status = "disabled";
                     };
                     mmcsd1: mmcsd@d4556000 {
                          compatible = "snps,dw-mshc";
                          reg = <0xd4556000 0x1000>;
                          interrupts = <0.39.0x4>;
                          num-slots = <1>;
                          status = "disabled";
                     };
       };
};
```

Step 7: shikhara\_defconfig

```
#
# Automatically generated file; DO NOT EDIT.
# Linux/arm 4.12.2 Kernel Configuration
#
CONFIG_ARM=y
CONFIG_ARM_HAS_SG_CHAIN=y
CONFIG_MIGHT_HAVE_PCI=y
CONFIG_SYS_SUPPORTS_APM_EMULATION=y
CONFIG_HAVE_PROC_CPU=y
CONFIG_STACKTRACE_SUPPORT=y
CONFIG_LOCKDEP_SUPPORT=y
CONFIG_TRACE_IRQFLAGS_SUPPORT=y
CONFIG_RWSEM_XCHGADD_ALGORITHM=y
CONFIG_FIX_EARLYCON_MEM=y
CONFIG_GENERIC_HWEIGHT=y
CONFIG_GENERIC_CALIBRATE_DELAY=y
CONFIG_NEED_DMA_MAP_STATE=y
CONFIG_ARCH_SUPPORTS_UPROBES=y
CONFIG_VECTORS_BASE=0xffff0000
CONFIG_ARM_PATCH_PHYS_VIRT=y
CONFIG_GENERIC_BUG=y
CONFIG_PGTABLE_LEVELS=2
CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config"
CONFIG_IRQ_WORK=y
CONFIG_BUILDTIME_EXTABLE_SORT=y
```

```
#
# General setup
#
```

```
CONFIG_INIT_ENV_ARG_LIMIT=32
CONFIG_CROSS_COMPILE=""
```

# CONFIG\_COMPILE\_TEST is not set

CONFIG\_LOCALVERSION=""

CONFIG\_LOCALVERSION\_AUTO=y

CONFIG\_HAVE\_KERNEL\_GZIP=y

CONFIG\_HAVE\_KERNEL\_LZMA=y

CONFIG\_HAVE\_KERNEL\_XZ=y

CONFIG\_HAVE\_KERNEL\_LZO=y

CONFIG\_HAVE\_KERNEL\_LZ4=y

CONFIG\_KERNEL\_GZIP=y

# CONFIG\_KERNEL\_LZMA is not set

# CONFIG\_KERNEL\_XZ is not set

# CONFIG\_KERNEL\_LZO is not set

# CONFIG\_KERNEL\_LZ4 is not set

CONFIG\_DEFAULT\_HOSTNAME="(none)"

CONFIG\_SWAP=y

CONFIG\_SYSVIPC=y

CONFIG\_SYSVIPC\_SYSCTL=y

# CONFIG\_POSIX\_MQUEUE is not set

CONFIG\_CROSS\_MEMORY\_ATTACH=y

CONFIG\_FHANDLE=y

# CONFIG\_USELIB is not set

# CONFIG AUDIT is not set

CONFIG\_HAVE\_ARCH\_AUDITSYSCALL=y

#

# IRQ subsystem

#

```
CONFIG_GENERIC_IRQ_PROBE=y
CONFIG_GENERIC_IRQ_SHOW=y
CONFIG_GENERIC_IRQ_SHOW_LEVEL=y
CONFIG_HARDIRQS_SW_RESEND=y
CONFIG_IRQ_DOMAIN=y
CONFIG_IRQ_DOMAIN_HIERARCHY=y
CONFIG_HANDLE_DOMAIN_IRQ=y
# CONFIG_IRQ_DOMAIN_DEBUG is not set
CONFIG_IRQ_FORCED_THREADING=y
CONFIG_SPARSE_IRQ=y
CONFIG_ARCH_CLOCKSOURCE_DATA=y
CONFIG_GENERIC_CLOCKEVENTS=y
CONFIG_ARCH_HAS_TICK_BROADCAST=y
CONFIG_GENERIC_CLOCKEVENTS_BROADCAST=y
#
# Timers subsystem
#
CONFIG_HZ_PERIODIC=y
# CONFIG_NO_HZ_IDLE is not set
# CONFIG_NO_HZ_FULL is not set
# CONFIG_NO_HZ is not set
# CONFIG_HIGH_RES_TIMERS is not set
#
# CPU/Task time and stats accounting
#
CONFIG_TICK_CPU_ACCOUNTING=y
# CONFIG_VIRT_CPU_ACCOUNTING_GEN is not set
```

```
# CONFIG_IRQ_TIME_ACCOUNTING is not set
CONFIG_BSD_PROCESS_ACCT=y
# CONFIG_BSD_PROCESS_ACCT_V3 is not set
# CONFIG_TASKSTATS is not set
#
# RCU Subsystem
#
CONFIG_TREE_RCU=y
# CONFIG RCU EXPERT is not set
CONFIG_SRCU=y
CONFIG_TREE_SRCU=y
# CONFIG_TASKS_RCU is not set
CONFIG_RCU_STALL_COMMON=y
CONFIG_RCU_NEED_SEGCBLIST=y
CONFIG_TREE_RCU_TRACE=y
# CONFIG_BUILD_BIN2C is not set
# CONFIG_IKCONFIG is not set
CONFIG_LOG_BUF_SHIFT=17
CONFIG_LOG_CPU_MAX_BUF_SHIFT=12
CONFIG_PRINTK_SAFE_LOG_BUF_SHIFT=13
CONFIG_GENERIC_SCHED_CLOCK=y
# CONFIG_CGROUPS is not set
# CONFIG_CHECKPOINT_RESTORE is not set
CONFIG_NAMESPACES=y
CONFIG_UTS_NS=y
CONFIG_IPC_NS=y
# CONFIG_USER_NS is not set
CONFIG_PID_NS=y
```

```
CONFIG_NET_NS=y
```

# CONFIG\_SCHED\_AUTOGROUP is not set

# CONFIG\_SYSFS\_DEPRECATED is not set

# CONFIG\_RELAY is not set

CONFIG\_BLK\_DEV\_INITRD=y

CONFIG\_INITRAMFS\_SOURCE=""

CONFIG\_RD\_GZIP=y

CONFIG\_RD\_BZIP2=y

CONFIG\_RD\_LZMA=y

CONFIG\_RD\_XZ=y

CONFIG\_RD\_LZO=y

CONFIG\_RD\_LZ4=y

CONFIG\_CC\_OPTIMIZE\_FOR\_PERFORMANCE=y

# CONFIG\_CC\_OPTIMIZE\_FOR\_SIZE is not set

CONFIG\_SYSCTL=y

CONFIG\_ANON\_INODES=y

CONFIG\_HAVE\_UID16=y

CONFIG\_BPF=y

# CONFIG\_EXPERT is not set

CONFIG\_UID16=y

CONFIG\_MULTIUSER=y

# CONFIG\_SGETMASK\_SYSCALL is not set

CONFIG\_SYSFS\_SYSCALL=y

# CONFIG\_SYSCTL\_SYSCALL is not set

CONFIG\_POSIX\_TIMERS=y

CONFIG\_KALLSYMS=y

# CONFIG\_KALLSYMS\_ALL is not set

# CONFIG\_KALLSYMS\_ABSOLUTE\_PERCPU is not set

CONFIG\_KALLSYMS\_BASE\_RELATIVE=y

```
CONFIG_PRINTK=y
CONFIG_PRINTK_NMI=y
CONFIG_BUG=y
CONFIG_ELF_CORE=y
CONFIG_BASE_FULL=y
CONFIG_FUTEX=y
CONFIG_EPOLL=y
CONFIG_SIGNALFD=y
CONFIG_TIMERFD=y
CONFIG_EVENTFD=y
# CONFIG_BPF_SYSCALL is not set
CONFIG_SHMEM=y
CONFIG_AIO=y
CONFIG_ADVISE_SYSCALLS=y
# CONFIG_USERFAULTFD is not set
CONFIG_MEMBARRIER=y
# CONFIG_EMBEDDED is not set
CONFIG_HAVE_PERF_EVENTS=y
CONFIG_PERF_USE_VMALLOC=y
# CONFIG_PC104 is not set
#
# Kernel Performance Events And Counters
# CONFIG_PERF_EVENTS is not set
CONFIG_VM_EVENT_COUNTERS=y
CONFIG_SLUB_DEBUG=y
CONFIG_COMPAT_BRK=y
# CONFIG_SLAB is not set
```

```
CONFIG_SLUB=y
```

# CONFIG\_SLAB\_FREELIST\_RANDOM is not set

CONFIG\_SLUB\_CPU\_PARTIAL=y

# CONFIG\_SYSTEM\_DATA\_VERIFICATION is not set

# CONFIG\_PROFILING is not set

CONFIG\_HAVE\_OPROFILE=y

# CONFIG KPROBES is not set

# CONFIG\_JUMP\_LABEL is not set

# CONFIG\_UPROBES is not set

# CONFIG\_HAVE\_64BIT\_ALIGNED\_ACCESS is not set

CONFIG\_HAVE\_EFFICIENT\_UNALIGNED\_ACCESS=y

CONFIG\_ARCH\_USE\_BUILTIN\_BSWAP=y

CONFIG\_HAVE\_KPROBES=y

CONFIG\_HAVE\_KRETPROBES=y

CONFIG\_HAVE\_OPTPROBES=y

CONFIG\_HAVE\_NMI=y

CONFIG\_HAVE\_ARCH\_TRACEHOOK=y

CONFIG\_HAVE\_DMA\_CONTIGUOUS=y

CONFIG\_GENERIC\_SMP\_IDLE\_THREAD=y

CONFIG\_GENERIC\_IDLE\_POLL\_SETUP=y

CONFIG\_ARCH\_HAS\_SET\_MEMORY=y

CONFIG\_HAVE\_REGS\_AND\_STACK\_ACCESS\_API=y

CONFIG\_HAVE\_CLK=y

CONFIG\_HAVE\_DMA\_API\_DEBUG=y

CONFIG\_HAVE\_PERF\_REGS=y

CONFIG\_HAVE\_PERF\_USER\_STACK\_DUMP=y

CONFIG\_HAVE\_ARCH\_JUMP\_LABEL=y

CONFIG\_ARCH\_WANT\_IPC\_PARSE\_VERSION=y

CONFIG\_HAVE\_ARCH\_SECCOMP\_FILTER=y

CONFIG\_HAVE\_GCC\_PLUGINS=y

# CONFIG\_GCC\_PLUGINS is not set

CONFIG\_HAVE\_CC\_STACKPROTECTOR=y

# CONFIG CC STACKPROTECTOR is not set

CONFIG\_CC\_STACKPROTECTOR\_NONE=y

# CONFIG\_CC\_STACKPROTECTOR\_REGULAR is not set

# CONFIG\_CC\_STACKPROTECTOR\_STRONG is not set

CONFIG\_HAVE\_CONTEXT\_TRACKING=y

CONFIG\_HAVE\_VIRT\_CPU\_ACCOUNTING\_GEN=y

CONFIG\_HAVE\_IRQ\_TIME\_ACCOUNTING=y

CONFIG\_HAVE\_MOD\_ARCH\_SPECIFIC=y

CONFIG\_MODULES\_USE\_ELF\_REL=y

CONFIG\_ARCH\_HAS\_ELF\_RANDOMIZE=y

CONFIG\_HAVE\_ARCH\_MMAP\_RND\_BITS=y

CONFIG\_HAVE\_EXIT\_THREAD=y

CONFIG\_ARCH\_MMAP\_RND\_BITS\_MIN=8

CONFIG ARCH MMAP RND BITS MAX=16

CONFIG\_ARCH\_MMAP\_RND\_BITS=8

# CONFIG\_HAVE\_ARCH\_HASH is not set

# CONFIG\_ISA\_BUS\_API is not set

CONFIG\_CLONE\_BACKWARDS=y

CONFIG\_OLD\_SIGSUSPEND3=y

CONFIG\_OLD\_SIGACTION=y

# CONFIG CPU NO EFFICIENT FFS is not set

# CONFIG\_HAVE\_ARCH\_VMAP\_STACK is not set

CONFIG\_ARCH\_OPTIONAL\_KERNEL\_RWX=y

CONFIG\_ARCH\_OPTIONAL\_KERNEL\_RWX\_DEFAULT=y

CONFIG\_ARCH\_HAS\_STRICT\_KERNEL\_RWX=y

CONFIG\_STRICT\_KERNEL\_RWX=y

```
CONFIG_ARCH_HAS_STRICT_MODULE_RWX=y
CONFIG_STRICT_MODULE_RWX=y
```

```
#
# GCOV-based kernel profiling
#
# CONFIG GCOV KERNEL is not set
CONFIG_ARCH_HAS_GCOV_PROFILE_ALL=y
CONFIG_HAVE_GENERIC_DMA_COHERENT=y
CONFIG_SLABINFO=y
CONFIG_RT_MUTEXES=y
CONFIG_BASE_SMALL=0
CONFIG_MODULES=y
# CONFIG_MODULE_FORCE_LOAD is not set
CONFIG_MODULE_UNLOAD=y
# CONFIG_MODULE_FORCE_UNLOAD is not set
CONFIG MODVERSIONS=y
# CONFIG_MODULE_SRCVERSION_ALL is not set
# CONFIG_MODULE_SIG is not set
# CONFIG_MODULE_COMPRESS is not set
# CONFIG_TRIM_UNUSED_KSYMS is not set
CONFIG_BLOCK=y
CONFIG_LBDAF=y
CONFIG_BLK_SCSI_REQUEST=y
CONFIG_BLK_DEV_BSG=y
# CONFIG_BLK_DEV_BSGLIB is not set
# CONFIG_BLK_DEV_INTEGRITY is not set
# CONFIG_BLK_DEV_ZONED is not set
# CONFIG_BLK_CMDLINE_PARSER is not set
```

```
# CONFIG_BLK_WBT is not set
CONFIG_BLK_DEBUG_FS=y
# CONFIG_BLK_SED_OPAL is not set
#
# Partition Types
CONFIG_PARTITION_ADVANCED=y
# CONFIG_ACORN_PARTITION is not set
# CONFIG AIX PARTITION is not set
# CONFIG_OSF_PARTITION is not set
# CONFIG_AMIGA_PARTITION is not set
# CONFIG_ATARI_PARTITION is not set
# CONFIG MAC PARTITION is not set
CONFIG_MSDOS_PARTITION=y
# CONFIG_BSD_DISKLABEL is not set
# CONFIG MINIX SUBPARTITION is not set
# CONFIG_SOLARIS_X86_PARTITION is not set
# CONFIG_UNIXWARE_DISKLABEL is not set
# CONFIG_LDM_PARTITION is not set
# CONFIG_SGI_PARTITION is not set
# CONFIG_ULTRIX_PARTITION is not set
# CONFIG_SUN_PARTITION is not set
# CONFIG KARMA PARTITION is not set
CONFIG_EFI_PARTITION=y
# CONFIG_SYSV68_PARTITION is not set
# CONFIG_CMDLINE_PARTITION is not set
```

```
# IO Schedulers
#
CONFIG_IOSCHED_NOOP=y
CONFIG_IOSCHED_DEADLINE=y
CONFIG_IOSCHED_CFQ=y
# CONFIG_DEFAULT_DEADLINE is not set
CONFIG_DEFAULT_CFQ=y
# CONFIG_DEFAULT_NOOP is not set
CONFIG_DEFAULT_IOSCHED="cfq"
CONFIG_MQ_IOSCHED_DEADLINE=y
CONFIG_MQ_IOSCHED_KYBER=y
# CONFIG_IOSCHED_BFQ is not set
CONFIG_UNINLINE_SPIN_UNLOCK=y
CONFIG_ARCH_SUPPORTS_ATOMIC_RMW=y
CONFIG_MUTEX_SPIN_ON_OWNER=y
CONFIG_RWSEM_SPIN_ON_OWNER=y
CONFIG_LOCK_SPIN_ON_OWNER=y
CONFIG_FREEZER=y
#
# System Type
#
CONFIG_MMU=y
CONFIG ARCH MULTIPLATFORM=y
# CONFIG_ARCH_EBSA110 is not set
# CONFIG_ARCH_EP93XX is not set
# CONFIG_ARCH_FOOTBRIDGE is not set
# CONFIG_ARCH_NETX is not set
# CONFIG_ARCH_IOP13XX is not set
```

```
# CONFIG_ARCH_IOP32X is not set
# CONFIG_ARCH_IOP33X is not set
# CONFIG_ARCH_IXP4XX is not set
# CONFIG_ARCH_DOVE is not set
# CONFIG_ARCH_KS8695 is not set
# CONFIG_ARCH_W90X900 is not set
# CONFIG_ARCH_LPC32XX is not set
# CONFIG_ARCH_PXA is not set
# CONFIG_ARCH_RPC is not set
# CONFIG_ARCH_SA1100 is not set
# CONFIG_ARCH_S3C24XX is not set
# CONFIG_ARCH_DAVINCI is not set
# CONFIG_ARCH_OMAP1 is not set
#
# Multiple platform selection
#
#
# CPU Core family selection
#
# CONFIG_ARCH_MULTI_V6 is not set
CONFIG_ARCH_MULTI_V7=y
CONFIG_ARCH_MULTI_V6_V7=y
# CONFIG_ARCH_MULTI_CPU_AUTO is not set
# CONFIG_ARCH_VIRT is not set
# CONFIG_ARCH_MVEBU is not set
# CONFIG_ARCH_ALPINE is not set
# CONFIG_ARCH_ARTPEC is not set
```

```
# CONFIG_ARCH_AT91 is not set
# CONFIG_ARCH_BCM is not set
# CONFIG_ARCH_BERLIN is not set
# CONFIG_ARCH_DIGICOLOR is not set
# CONFIG_ARCH_HIGHBANK is not set
# CONFIG_ARCH_HISI is not set
# CONFIG ARCH KEYSTONE is not set
# CONFIG_ARCH_MESON is not set
# CONFIG_ARCH_MXC is not set
# CONFIG ARCH MEDIATEK is not set
#
#TI OMAP/AM/DM/DRA Family
#
# CONFIG_ARCH_OMAP3 is not set
# CONFIG_ARCH_OMAP4 is not set
# CONFIG SOC OMAP5 is not set
# CONFIG_SOC_AM33XX is not set
# CONFIG_SOC_AM43XX is not set
# CONFIG_SOC_DRA7XX is not set
# CONFIG_ARCH_MMP is not set
# CONFIG_ARCH_QCOM is not set
# CONFIG_ARCH_REALVIEW is not set
# CONFIG ARCH ROCKCHIP is not set
# CONFIG_ARCH_SOCFPGA is not set
# CONFIG_PLAT_SPEAR is not set
CONFIG_ARCH_MOSCHIP=y
# CONFIG_ARCH_STI is not set
# CONFIG_ARCH_S5PV210 is not set
```

```
# CONFIG_ARCH_EXYNOS is not set
# CONFIG_ARCH_RENESAS is not set
# CONFIG_ARCH_SUNXI is not set
# CONFIG_ARCH_SIRF is not set
# CONFIG_ARCH_TANGO is not set
# CONFIG_ARCH_TEGRA is not set
# CONFIG_ARCH_UNIPHIER is not set
# CONFIG_ARCH_U8500 is not set
# CONFIG_ARCH_VEXPRESS is not set
# CONFIG_ARCH_WM8850 is not set
# CONFIG_ARCH_ZX is not set
# CONFIG_ARCH_ZYNQ is not set
#
# Processor Type
CONFIG_CPU_V7=y
CONFIG_CPU_THUMB_CAPABLE=y
CONFIG_CPU_32v6K=y
CONFIG_CPU_32v7=y
CONFIG_CPU_ABRT_EV7=y
CONFIG_CPU_PABRT_V7=y
CONFIG_CPU_CACHE_V7=y
CONFIG_CPU_CACHE_VIPT=y
CONFIG_CPU_COPY_V6=y
CONFIG_CPU_TLB_V7=y
CONFIG_CPU_HAS_ASID=y
CONFIG_CPU_CP15=y
CONFIG_CPU_CP15_MMU=y
```

```
#
# Processor Features
#
# CONFIG_ARM_LPAE is not set
# CONFIG_ARCH_PHYS_ADDR_T_64BIT is not set
CONFIG_ARM_THUMB=y
# CONFIG_ARM_THUMBEE is not set
CONFIG_ARM_VIRT_EXT=y
CONFIG_SWP_EMULATE=y
# CONFIG_CPU_ICACHE_DISABLE is not set
# CONFIG_CPU_BPREDICT_DISABLE is not set
CONFIG_KUSER_HELPERS=y
# CONFIG_VDSO is not set
CONFIG_OUTER_CACHE=y
CONFIG_OUTER_CACHE_SYNC=y
CONFIG_MIGHT_HAVE_CACHE_L2X0=y
CONFIG_CACHE_L2X0=y
# CONFIG_PL310_ERRATA_588369 is not set
# CONFIG_PL310_ERRATA_727915 is not set
# CONFIG_PL310_ERRATA_753970 is not set
# CONFIG_PL310_ERRATA_769419 is not set
CONFIG_ARM_L1_CACHE_SHIFT_6=y
CONFIG_ARM_L1_CACHE_SHIFT=6
CONFIG_ARM_DMA_MEM_BUFFERABLE=y
CONFIG_ARM_HEAVY_MB=y
CONFIG_DEBUG_ALIGN_RODATA=y
```

CONFIG\_MULTI\_IRQ\_HANDLER=y

# CONFIG\_ARM\_ERRATA\_430973 is not set

```
CONFIG_ARM_ERRATA_643719=y
# CONFIG_ARM_ERRATA_720789 is not set
# CONFIG_ARM_ERRATA_754322 is not set
# CONFIG_ARM_ERRATA_754327 is not set
# CONFIG_ARM_ERRATA_764369 is not set
# CONFIG_ARM_ERRATA_775420 is not set
# CONFIG_ARM_ERRATA_798181 is not set
# CONFIG_ARM_ERRATA_773022 is not set
# CONFIG_ARM_ERRATA_818325_852422 is not set
# CONFIG_ARM_ERRATA_821420 is not set
# CONFIG_ARM_ERRATA_825619 is not set
# CONFIG_ARM_ERRATA_852421 is not set
# CONFIG_ARM_ERRATA_852423 is not set
#
# Bus support
#
# CONFIG_PCI is not set
# CONFIG_PCI_DOMAINS_GENERIC is not set
# CONFIG_PCI_SYSCALL is not set
#
# DesignWare PCI Core Support
#
#
# PCI Endpoint
#
# CONFIG_PCI_ENDPOINT is not set
```

## # CONFIG\_PCCARD is not set

```
#
# Kernel Features
#
CONFIG_HAVE_SMP=y
CONFIG_SMP=y
# CONFIG_SMP_ON_UP is not set
# CONFIG_ARM_CPU_TOPOLOGY is not set
CONFIG_HAVE_ARM_SCU=y
# CONFIG_HAVE_ARM_ARCH_TIMER is not set
CONFIG_HAVE_ARM_TWD=y
# CONFIG_MCPM is not set
# CONFIG_BIG_LITTLE is not set
CONFIG_VMSPLIT_3G=y
# CONFIG_VMSPLIT_3G_OPT is not set
# CONFIG_VMSPLIT_2G is not set
# CONFIG_VMSPLIT_1G is not set
CONFIG_PAGE_OFFSET=0xC0000000
CONFIG_NR_CPUS=2
CONFIG_HOTPLUG_CPU=y
# CONFIG_ARM_PSCI is not set
CONFIG_ARCH_NR_GPIO=0
CONFIG_PREEMPT_NONE=y
# CONFIG_PREEMPT_VOLUNTARY is not set
# CONFIG_PREEMPT is not set
CONFIG_HZ_FIXED=0
CONFIG_HZ_100=y
# CONFIG_HZ_200 is not set
```

```
# CONFIG_HZ_250 is not set
```

# CONFIG\_HZ\_300 is not set

# CONFIG\_HZ\_500 is not set

# CONFIG\_HZ\_1000 is not set

CONFIG\_HZ=100

# CONFIG\_SCHED\_HRTICK is not set

# CONFIG\_THUMB2\_KERNEL is not set

CONFIG\_ARM\_PATCH\_IDIV=y

CONFIG\_AEABI=y

# CONFIG\_OABI\_COMPAT is not set

# CONFIG\_ARCH\_SPARSEMEM\_DEFAULT is not set

# CONFIG\_ARCH\_SELECT\_MEMORY\_MODEL is not set

CONFIG\_HAVE\_ARCH\_PFN\_VALID=y

# CONFIG\_HIGHMEM is not set

CONFIG\_CPU\_SW\_DOMAIN\_PAN=y

CONFIG\_ARCH\_WANT\_GENERAL\_HUGETLB=y

# CONFIG\_ARM\_MODULE\_PLTS is not set

CONFIG\_FLATMEM=y

CONFIG\_FLAT\_NODE\_MEM\_MAP=y

CONFIG\_HAVE\_MEMBLOCK=y

CONFIG\_NO\_BOOTMEM=y

# CONFIG\_HAVE\_BOOTMEM\_INFO\_NODE is not set

CONFIG\_SPLIT\_PTLOCK\_CPUS=4

CONFIG\_COMPACTION=y

CONFIG\_MIGRATION=y

# CONFIG\_PHYS\_ADDR\_T\_64BIT is not set

# CONFIG\_KSM is not set

CONFIG\_DEFAULT\_MMAP\_MIN\_ADDR=4096

# CONFIG\_CLEANCACHE is not set

```
# CONFIG_FRONTSWAP is not set
# CONFIG_CMA is not set
# CONFIG_ZPOOL is not set
# CONFIG_ZBUD is not set
# CONFIG_ZSMALLOC is not set
CONFIG_GENERIC_EARLY_IOREMAP=y
# CONFIG_IDLE_PAGE_TRACKING is not set
CONFIG_FORCE_MAX_ZONEORDER=11
CONFIG_ALIGNMENT_TRAP=y
# CONFIG_UACCESS_WITH_MEMCPY is not set
# CONFIG_SECCOMP is not set
CONFIG_SWIOTLB=y
CONFIG_IOMMU_HELPER=y
# CONFIG PARAVIRT is not set
# CONFIG_PARAVIRT_TIME_ACCOUNTING is not set
# CONFIG_XEN is not set
#
# Boot options
#
CONFIG_USE_OF=y
CONFIG_ATAGS=y
# CONFIG_DEPRECATED_PARAM_STRUCT is not set
CONFIG ZBOOT ROM TEXT=0
CONFIG_ZBOOT_ROM_BSS=0
CONFIG_ARM_APPENDED_DTB=y
CONFIG_ARM_ATAG_DTB_COMPAT=y
CONFIG_ARM_ATAG_DTB_COMPAT_CMDLINE_FROM_BOOTLOADER=y
# CONFIG_ARM_ATAG_DTB_COMPAT_CMDLINE_EXTEND is not set
```

```
CONFIG_CMDLINE=""
# CONFIG_KEXEC is not set
# CONFIG_CRASH_DUMP is not set
CONFIG_AUTO_ZRELADDR=y
# CONFIG_EFI is not set
#
# CPU Power Management
#
#
# CPU Frequency scaling
#
# CONFIG_CPU_FREQ is not set
#
# CPU Idle
#
# CONFIG_CPU_IDLE is not set
# CONFIG_ARCH_NEEDS_CPU_IDLE_COUPLED is not set
#
# Floating point emulation
#
#
# At least one emulation must be selected
#
CONFIG\_VFP = y
```

```
CONFIG_VFPv3=y
# CONFIG_NEON is not set
#
# Userspace binary formats
#
CONFIG_BINFMT_ELF=y
CONFIG_ELFCORE=y
CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS=y
CONFIG_BINFMT_SCRIPT=y
# CONFIG_BINFMT_FLAT is not set
# CONFIG_HAVE_AOUT is not set
CONFIG_BINFMT_MISC=y
CONFIG_COREDUMP=y
#
# Power management options
#
CONFIG_SUSPEND=y
CONFIG_SUSPEND_FREEZER=y
# CONFIG_HIBERNATION is not set
CONFIG_PM_SLEEP=y
CONFIG_PM_SLEEP_SMP=y
# CONFIG_PM_AUTOSLEEP is not set
# CONFIG_PM_WAKELOCKS is not set
CONFIG_PM=y
# CONFIG_PM_DEBUG is not set
# CONFIG_APM_EMULATION is not set
CONFIG_PM_CLK=y
```

```
# CONFIG_WQ_POWER_EFFICIENT_DEFAULT is not set
CONFIG_CPU_PM=y
CONFIG_ARCH_SUSPEND_POSSIBLE=y
CONFIG_ARM_CPU_SUSPEND=y
CONFIG_ARCH_HIBERNATION_POSSIBLE=y
CONFIG_NET=y
#
# Networking options
#
# CONFIG_PACKET is not set
CONFIG_UNIX=y
# CONFIG_UNIX_DIAG is not set
CONFIG_XFRM=y
# CONFIG_XFRM_USER is not set
# CONFIG_XFRM_SUB_POLICY is not set
# CONFIG_XFRM_MIGRATE is not set
# CONFIG_XFRM_STATISTICS is not set
# CONFIG_NET_KEY is not set
CONFIG_INET=y
# CONFIG_IP_MULTICAST is not set
# CONFIG_IP_ADVANCED_ROUTER is not set
CONFIG_IP_PNP=y
CONFIG_IP_PNP_DHCP=y
CONFIG_IP_PNP_BOOTP=y
# CONFIG_IP_PNP_RARP is not set
CONFIG_NET_IPIP=y
# CONFIG_NET_IPGRE_DEMUX is not set
CONFIG_NET_IP_TUNNEL=y
```

```
# CONFIG_SYN_COOKIES is not set
```

- # CONFIG\_NET\_IPVTI is not set
- # CONFIG\_NET\_UDP\_TUNNEL is not set
- # CONFIG\_NET\_FOU is not set
- # CONFIG\_NET\_FOU\_IP\_TUNNELS is not set
- # CONFIG\_INET\_AH is not set
- # CONFIG INET ESP is not set
- # CONFIG\_INET\_IPCOMP is not set
- # CONFIG\_INET\_XFRM\_TUNNEL is not set
- CONFIG\_INET\_TUNNEL=y
- CONFIG\_INET\_XFRM\_MODE\_TRANSPORT=y
- CONFIG\_INET\_XFRM\_MODE\_TUNNEL=y
- CONFIG\_INET\_XFRM\_MODE\_BEET=y
- CONFIG\_INET\_DIAG=y
- CONFIG\_INET\_TCP\_DIAG=y
- # CONFIG\_INET\_UDP\_DIAG is not set
- # CONFIG INET RAW DIAG is not set
- # CONFIG\_INET\_DIAG\_DESTROY is not set
- # CONFIG\_TCP\_CONG\_ADVANCED is not set
- CONFIG\_TCP\_CONG\_CUBIC=y
- CONFIG\_DEFAULT\_TCP\_CONG="cubic"
- # CONFIG TCP MD5SIG is not set
- CONFIG\_IPV6=y
- # CONFIG IPV6 ROUTER PREF is not set
- # CONFIG\_IPV6\_OPTIMISTIC\_DAD is not set
- # CONFIG\_INET6\_AH is not set
- # CONFIG\_INET6\_ESP is not set
- # CONFIG\_INET6\_IPCOMP is not set
- # CONFIG\_IPV6\_MIP6 is not set

```
# CONFIG_INET6_XFRM_TUNNEL is not set
```

# CONFIG\_INET6\_TUNNEL is not set

CONFIG\_INET6\_XFRM\_MODE\_TRANSPORT=y

CONFIG\_INET6\_XFRM\_MODE\_TUNNEL=y

CONFIG\_INET6\_XFRM\_MODE\_BEET=y

# CONFIG\_INET6\_XFRM\_MODE\_ROUTEOPTIMIZATION is not set

# CONFIG IPV6 VTI is not set

CONFIG\_IPV6\_SIT=y

# CONFIG\_IPV6\_SIT\_6RD is not set

CONFIG\_IPV6\_NDISC\_NODETYPE=y

# CONFIG\_IPV6\_TUNNEL is not set

# CONFIG\_IPV6\_FOU is not set

# CONFIG\_IPV6\_FOU\_TUNNEL is not set

# CONFIG IPV6 MULTIPLE TABLES is not set

# CONFIG\_IPV6\_MROUTE is not set

# CONFIG\_IPV6\_SEG6\_LWTUNNEL is not set

# CONFIG\_IPV6\_SEG6\_HMAC is not set

# CONFIG\_NETWORK\_SECMARK is not set

CONFIG\_NET\_PTP\_CLASSIFY=y

# CONFIG\_NETWORK\_PHY\_TIMESTAMPING is not set

# CONFIG\_NETFILTER is not set

# CONFIG IP DCCP is not set

# CONFIG\_IP\_SCTP is not set

# CONFIG RDS is not set

# CONFIG\_TIPC is not set

# CONFIG\_ATM is not set

# CONFIG\_L2TP is not set

# CONFIG\_BRIDGE is not set

# CONFIG\_VLAN\_8021Q is not set

- # CONFIG\_DECNET is not set
- # CONFIG\_LLC2 is not set
- # CONFIG\_IPX is not set
- # CONFIG\_ATALK is not set
- # CONFIG\_X25 is not set
- # CONFIG\_LAPB is not set
- # CONFIG PHONET is not set
- # CONFIG\_6LOWPAN is not set
- # CONFIG\_IEEE802154 is not set
- # CONFIG\_NET\_SCHED is not set
- # CONFIG\_DCB is not set
- # CONFIG\_BATMAN\_ADV is not set
- # CONFIG\_OPENVSWITCH is not set
- # CONFIG\_VSOCKETS is not set
- # CONFIG\_NETLINK\_DIAG is not set
- # CONFIG\_MPLS is not set
- # CONFIG\_HSR is not set
- # CONFIG\_NET\_SWITCHDEV is not set
- # CONFIG\_NET\_L3\_MASTER\_DEV is not set
- # CONFIG\_NET\_NCSI is not set
- CONFIG\_RPS=y
- CONFIG\_RFS\_ACCEL=y
- CONFIG\_XPS=y
- CONFIG\_NET\_RX\_BUSY\_POLL=y
- CONFIG\_BQL=y
- # CONFIG\_BPF\_JIT is not set
- CONFIG\_NET\_FLOW\_LIMIT=y

```
# Network testing
#
# CONFIG_NET_PKTGEN is not set
# CONFIG_HAMRADIO is not set
# CONFIG_CAN is not set
# CONFIG_IRDA is not set
# CONFIG_BT is not set
# CONFIG_AF_RXRPC is not set
# CONFIG_AF_KCM is not set
# CONFIG_STREAM_PARSER is not set
CONFIG_WIRELESS=y
# CONFIG_CFG80211 is not set
# CONFIG_LIB80211 is not set
#
# CFG80211 needs to be enabled for MAC80211
#
CONFIG_MAC80211_STA_HASH_MAX_SIZE=0
# CONFIG_WIMAX is not set
# CONFIG_RFKILL is not set
# CONFIG_NET_9P is not set
# CONFIG_CAIF is not set
# CONFIG_CEPH_LIB is not set
# CONFIG NFC is not set
# CONFIG_PSAMPLE is not set
# CONFIG_NET_IFE is not set
# CONFIG_LWTUNNEL is not set
CONFIG_DST_CACHE=y
CONFIG_GRO_CELLS=y
```

```
# CONFIG_NET_DEVLINK is not set
CONFIG_MAY_USE_DEVLINK=y
CONFIG_HAVE_CBPF_JIT=y
#
# Device Drivers
CONFIG_ARM_AMBA=y
#
# Generic Driver Options
#
CONFIG_UEVENT_HELPER=y
CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug"
# CONFIG_DEVTMPFS is not set
CONFIG_STANDALONE=y
CONFIG_PREVENT_FIRMWARE_BUILD=y
CONFIG_FW_LOADER=y
CONFIG_FIRMWARE_IN_KERNEL=y
CONFIG_EXTRA_FIRMWARE=""
# CONFIG_FW_LOADER_USER_HELPER_FALLBACK is not set
CONFIG_ALLOW_DEV_COREDUMP=y
# CONFIG_DEBUG_DRIVER is not set
# CONFIG DEBUG DEVRES is not set
# CONFIG_DEBUG_TEST_DRIVER_REMOVE is not set
# CONFIG_TEST_ASYNC_DRIVER_PROBE is not set
# CONFIG_SYS_HYPERVISOR is not set
# CONFIG_GENERIC_CPU_DEVICES is not set
CONFIG_GENERIC_CPU_AUTOPROBE=y
```

```
CONFIG_REGMAP=y
CONFIG_REGMAP_I2C=y
CONFIG_REGMAP_SPI=y
CONFIG_REGMAP_MMIO=y
# CONFIG_DMA_SHARED_BUFFER is not set
#
# Bus devices
#
# CONFIG_BRCMSTB_GISB_ARB is not set
# CONFIG_VEXPRESS_CONFIG is not set
# CONFIG_CONNECTOR is not set
CONFIG_MTD=y
# CONFIG_MTD_TESTS is not set
# CONFIG_MTD_REDBOOT_PARTS is not set
# CONFIG_MTD_CMDLINE_PARTS is not set
# CONFIG_MTD_AFS_PARTS is not set
CONFIG_MTD_OF_PARTS=y
# CONFIG_MTD_AR7_PARTS is not set
#
# User Modules And Translation Layers
#
CONFIG_MTD_BLKDEVS=y
CONFIG_MTD_BLOCK=y
# CONFIG_FTL is not set
# CONFIG_NFTL is not set
# CONFIG_INFTL is not set
# CONFIG_RFD_FTL is not set
```

```
# CONFIG_SSFDC is not set
# CONFIG_SM_FTL is not set
# CONFIG_MTD_OOPS is not set
# CONFIG_MTD_SWAP is not set
# CONFIG_MTD_PARTITIONED_MASTER is not set
#
# RAM/ROM/Flash chip drivers
#
# CONFIG_MTD_CFI is not set
# CONFIG_MTD_JEDECPROBE is not set
CONFIG_MTD_MAP_BANK_WIDTH_1=y
CONFIG_MTD_MAP_BANK_WIDTH_2=y
CONFIG_MTD_MAP_BANK_WIDTH_4=y
# CONFIG_MTD_MAP_BANK_WIDTH_8 is not set
# CONFIG_MTD_MAP_BANK_WIDTH_16 is not set
# CONFIG_MTD_MAP_BANK_WIDTH_32 is not set
CONFIG_MTD_CFI_I1=y
CONFIG_MTD_CFI_I2=y
# CONFIG_MTD_CFI_I4 is not set
# CONFIG_MTD_CFI_I8 is not set
# CONFIG_MTD_RAM is not set
# CONFIG_MTD_ROM is not set
# CONFIG_MTD_ABSENT is not set
#
# Mapping drivers for chip access
#
# CONFIG_MTD_COMPLEX_MAPPINGS is not set
```

```
# CONFIG_MTD_PLATRAM is not set
```

```
#
# Self-contained MTD device drivers
#
# CONFIG_MTD_DATAFLASH is not set
# CONFIG MTD SST25L is not set
# CONFIG_MTD_SLRAM is not set
# CONFIG_MTD_PHRAM is not set
# CONFIG_MTD_MTDRAM is not set
# CONFIG_MTD_BLOCK2MTD is not set
#
# Disk-On-Chip Device Drivers
# CONFIG_MTD_DOCG3 is not set
CONFIG_MTD_NAND_ECC=y
# CONFIG_MTD_NAND_ECC_SMC is not set
CONFIG_MTD_NAND=y
# CONFIG_MTD_NAND_ECC_BCH is not set
# CONFIG_MTD_SM_COMMON is not set
# CONFIG_MTD_NAND_DENALI_DT is not set
# CONFIG_MTD_NAND_GPIO is not set
# CONFIG MTD NAND OMAP BCH BUILD is not set
# CONFIG_MTD_NAND_DISKONCHIP is not set
# CONFIG_MTD_NAND_DOCG4 is not set
# CONFIG_MTD_NAND_NANDSIM is not set
# CONFIG_MTD_NAND_BRCMNAND is not set
# CONFIG_MTD_NAND_PLATFORM is not set
```

```
# CONFIG_MTD_NAND_HISI504 is not set
# CONFIG_MTD_NAND_MTK is not set
# CONFIG_MTD_ONENAND is not set
#
# LPDDR & LPDDR2 PCM memory drivers
# CONFIG_MTD_LPDDR is not set
# CONFIG_MTD_LPDDR2_NVM is not set
# CONFIG_MTD_SPI_NOR is not set
# CONFIG_MTD_UBI is not set
CONFIG_DTC=y
CONFIG_OF=y
# CONFIG_OF_UNITTEST is not set
CONFIG_OF_FLATTREE=y
CONFIG_OF_EARLY_FLATTREE=y
CONFIG_OF_ADDRESS=y
CONFIG_OF_IRQ=y
CONFIG_OF_RESERVED_MEM=y
# CONFIG_OF_OVERLAY is not set
CONFIG_ARCH_MIGHT_HAVE_PC_PARPORT=y
# CONFIG_PARPORT is not set
CONFIG_BLK_DEV=y
# CONFIG BLK DEV NULL BLK is not set
# CONFIG_BLK_DEV_COW_COMMON is not set
# CONFIG_BLK_DEV_LOOP is not set
# CONFIG_BLK_DEV_DRBD is not set
# CONFIG_BLK_DEV_NBD is not set
CONFIG_BLK_DEV_RAM=y
```

```
CONFIG_BLK_DEV_RAM_COUNT=16
CONFIG_BLK_DEV_RAM_SIZE=16384
# CONFIG_CDROM_PKTCDVD is not set
# CONFIG_ATA_OVER_ETH is not set
# CONFIG_BLK_DEV_RBD is not set
# CONFIG_NVME_FC is not set
#
# Misc devices
#
# CONFIG_SENSORS_LIS3LV02D is not set
# CONFIG_AD525X_DPOT is not set
# CONFIG_DUMMY_IRQ is not set
# CONFIG ICS932S401 is not set
# CONFIG_ENCLOSURE_SERVICES is not set
# CONFIG_APDS9802ALS is not set
# CONFIG ISL29003 is not set
# CONFIG_ISL29020 is not set
# CONFIG_SENSORS_TSL2550 is not set
# CONFIG_SENSORS_BH1770 is not set
# CONFIG_SENSORS_APDS990X is not set
# CONFIG_HMC6352 is not set
# CONFIG_DS1682 is not set
# CONFIG TI DAC7512 is not set
# CONFIG_USB_SWITCH_FSA9480 is not set
# CONFIG_LATTICE_ECP3_CONFIG is not set
# CONFIG_SRAM is not set
# CONFIG_C2PORT is not set
```

```
# EEPROM support
#
# CONFIG_EEPROM_AT24 is not set
# CONFIG_EEPROM_AT25 is not set
# CONFIG_EEPROM_LEGACY is not set
# CONFIG_EEPROM_MAX6875 is not set
# CONFIG_EEPROM_93CX6 is not set
# CONFIG_EEPROM_93XX46 is not set
# CONFIG_EEPROM_IDT_89HPESX is not set
#
# Texas Instruments shared transport line discipline
#
# CONFIG_TI_ST is not set
# CONFIG_SENSORS_LIS3_SPI is not set
# CONFIG_SENSORS_LIS3_I2C is not set
#
# Altera FPGA firmware download module
#
# CONFIG_ALTERA_STAPL is not set
#
# Intel MIC Bus Driver
#
#
# SCIF Bus Driver
```

#

```
#
#
# VOP Bus Driver
#
#
# Intel MIC Host Driver
#
#
# Intel MIC Card Driver
#
#
# SCIF Driver
#
#
# Intel MIC Coprocessor State Management (COSM) Drivers
#
#
# VOP Driver
# CONFIG_ECHO is not set
# CONFIG_CXL_BASE is not set
# CONFIG_CXL_AFU_DRIVER_OPS is not set
```

```
#
# SCSI device support
#
CONFIG_SCSI_MOD=y
# CONFIG_RAID_ATTRS is not set
CONFIG_SCSI=y
CONFIG_SCSI_DMA=y
# CONFIG_SCSI_NETLINK is not set
# CONFIG_SCSI_MQ_DEFAULT is not set
CONFIG_SCSI_PROC_FS=y
#
# SCSI support type (disk, tape, CD-ROM)
#
CONFIG_BLK_DEV_SD=y
# CONFIG_CHR_DEV_ST is not set
# CONFIG_CHR_DEV_OSST is not set
# CONFIG_BLK_DEV_SR is not set
# CONFIG_CHR_DEV_SG is not set
# CONFIG_CHR_DEV_SCH is not set
# CONFIG_SCSI_CONSTANTS is not set
# CONFIG_SCSI_LOGGING is not set
# CONFIG_SCSI_SCAN_ASYNC is not set
#
# SCSI Transports
#
# CONFIG_SCSI_SPI_ATTRS is not set
# CONFIG_SCSI_FC_ATTRS is not set
```

```
# CONFIG_SCSI_SAS_ATTRS is not set
# CONFIG_SCSI_SAS_LIBSAS is not set
# CONFIG_SCSI_SRP_ATTRS is not set
CONFIG_SCSI_LOWLEVEL=y
# CONFIG_ISCSI_TCP is not set
# CONFIG_ISCSI_BOOT_SYSFS is not set
# CONFIG_SCSI_UFSHCD is not set
# CONFIG_SCSI_DEBUG is not set
# CONFIG_SCSI_DH is not set
# CONFIG_SCSI_OSD_INITIATOR is not set
# CONFIG_ATA is not set
# CONFIG_MD is not set
# CONFIG_TARGET_CORE is not set
# CONFIG_NETDEVICES is not set
# CONFIG_NVM is not set
#
# Input device support
#
CONFIG_INPUT=y
CONFIG_INPUT_FF_MEMLESS=y
# CONFIG_INPUT_POLLDEV is not set
# CONFIG_INPUT_SPARSEKMAP is not set
CONFIG_INPUT_MATRIXKMAP=y
#
# Userland interfaces
#
```

# CONFIG\_SCSI\_ISCSI\_ATTRS is not set

```
# CONFIG_INPUT_MOUSEDEV is not set
# CONFIG_INPUT_JOYDEV is not set
# CONFIG_INPUT_EVDEV is not set
# CONFIG INPUT EVBUG is not set
#
# Input Device Drivers
#
CONFIG_INPUT_KEYBOARD=y
# CONFIG_KEYBOARD_ADP5588 is not set
# CONFIG_KEYBOARD_ADP5589 is not set
# CONFIG_KEYBOARD_ATKBD is not set
# CONFIG_KEYBOARD_QT1070 is not set
# CONFIG KEYBOARD QT2160 is not set
# CONFIG_KEYBOARD_LKKBD is not set
# CONFIG_KEYBOARD_GPIO is not set
# CONFIG_KEYBOARD_GPIO_POLLED is not set
# CONFIG_KEYBOARD_TCA6416 is not set
# CONFIG_KEYBOARD_TCA8418 is not set
# CONFIG_KEYBOARD_MATRIX is not set
# CONFIG_KEYBOARD_LM8333 is not set
# CONFIG_KEYBOARD_MAX7359 is not set
# CONFIG_KEYBOARD_MCS is not set
# CONFIG KEYBOARD MPR121 is not set
# CONFIG_KEYBOARD_NEWTON is not set
# CONFIG_KEYBOARD_OPENCORES is not set
# CONFIG_KEYBOARD_SAMSUNG is not set
# CONFIG_KEYBOARD_STOWAWAY is not set
# CONFIG_KEYBOARD_SUNKBD is not set
```

```
# CONFIG_KEYBOARD_OMAP4 is not set
# CONFIG_KEYBOARD_XTKBD is not set
# CONFIG_KEYBOARD_CAP11XX is not set
# CONFIG_KEYBOARD_BCM is not set
# CONFIG_INPUT_MOUSE is not set
# CONFIG_INPUT_JOYSTICK is not set
# CONFIG INPUT TABLET is not set
# CONFIG_INPUT_TOUCHSCREEN is not set
# CONFIG_INPUT_MISC is not set
# CONFIG RMI4 CORE is not set
#
# Hardware I/O ports
CONFIG_SERIO=y
CONFIG_SERIO_SERPORT=y
# CONFIG_SERIO_AMBAKMI is not set
# CONFIG_SERIO_LIBPS2 is not set
# CONFIG_SERIO_RAW is not set
# CONFIG_SERIO_ALTERA_PS2 is not set
# CONFIG_SERIO_PS2MULT is not set
# CONFIG_SERIO_ARC_PS2 is not set
# CONFIG_SERIO_APBPS2 is not set
# CONFIG USERIO is not set
# CONFIG_GAMEPORT is not set
#
# Character devices
#
```

```
CONFIG_TTY=y
CONFIG_VT=y
CONFIG_CONSOLE_TRANSLATIONS=y
CONFIG_VT_CONSOLE=y
CONFIG_VT_CONSOLE_SLEEP=y
CONFIG_HW_CONSOLE=y
# CONFIG_VT_HW_CONSOLE_BINDING is not set
CONFIG_UNIX98_PTYS=y
# CONFIG_LEGACY_PTYS is not set
# CONFIG_SERIAL_NONSTANDARD is not set
# CONFIG_N_GSM is not set
# CONFIG_TRACE_SINK is not set
CONFIG_DEVMEM=y
# CONFIG_DEVKMEM is not set
#
# Serial drivers
CONFIG_SERIAL_EARLYCON=y
# CONFIG_SERIAL_8250 is not set
#
# Non-8250 serial port support
# CONFIG_SERIAL_AMBA_PL010 is not set
CONFIG_SERIAL_AMBA_PL011=y
CONFIG_SERIAL_AMBA_PL011_CONSOLE=y
# CONFIG_SERIAL_EARLYCON_ARM_SEMIHOST is not set
# CONFIG_SERIAL_MAX3100 is not set
```

```
# CONFIG_SERIAL_UARTLITE is not set
CONFIG_SERIAL_CORE=y
CONFIG_SERIAL_CORE_CONSOLE=y
# CONFIG_SERIAL_SCCNXP is not set
# CONFIG_SERIAL_SC16IS7XX is not set
# CONFIG SERIAL BCM63XX is not set
# CONFIG_SERIAL_ALTERA_JTAGUART is not set
# CONFIG_SERIAL_ALTERA_UART is not set
# CONFIG_SERIAL_IFX6X60 is not set
# CONFIG_SERIAL_XILINX_PS_UART is not set
# CONFIG_SERIAL_ARC is not set
# CONFIG_SERIAL_FSL_LPUART is not set
# CONFIG_SERIAL_CONEXANT_DIGICOLOR is not set
# CONFIG_SERIAL_ST_ASC is not set
# CONFIG_SERIAL_DEV_BUS is not set
# CONFIG_HVC_DCC is not set
# CONFIG_IPMI_HANDLER is not set
# CONFIG_HW_RANDOM is not set
# CONFIG_R3964 is not set
CONFIG_RAW_DRIVER=y
CONFIG_MAX_RAW_DEVS=8192
# CONFIG_TCG_TPM is not set
# CONFIG XILLYBUS is not set
#
# I2C support
#
CONFIG_I2C=y
```

# CONFIG\_SERIAL\_MAX310X is not set

```
CONFIG_I2C_BOARDINFO=y
CONFIG_I2C_COMPAT=y
# CONFIG_I2C_CHARDEV is not set
# CONFIG_I2C_MUX is not set
CONFIG_I2C_HELPER_AUTO=y
#
# I2C Hardware Bus support
#
#
# I2C system bus drivers (mostly embedded / system-on-chip)
#
# CONFIG_I2C_CBUS_GPIO is not set
CONFIG_I2C_DESIGNWARE_CORE=y
CONFIG_I2C_DESIGNWARE_PLATFORM=y
# CONFIG_I2C_EMEV2 is not set
# CONFIG_I2C_GPIO is not set
# CONFIG_I2C_NOMADIK is not set
# CONFIG_I2C_OCORES is not set
# CONFIG_I2C_PCA_PLATFORM is not set
# CONFIG_I2C_PXA_PCI is not set
# CONFIG_I2C_RK3X is not set
# CONFIG_I2C_SIMTEC is not set
# CONFIG_I2C_XILINX is not set
#
# External I2C/SMBus adapter drivers
#
```

```
# CONFIG_I2C_DIOLAN_U2C is not set
# CONFIG_I2C_PARPORT_LIGHT is not set
# CONFIG_I2C_ROBOTFUZZ_OSIF is not set
# CONFIG_I2C_TAOS_EVM is not set
# CONFIG_I2C_TINY_USB is not set
#
# Other I2C/SMBus bus drivers
#
# CONFIG I2C STUB is not set
# CONFIG_I2C_SLAVE is not set
# CONFIG_I2C_DEBUG_CORE is not set
# CONFIG_I2C_DEBUG_ALGO is not set
# CONFIG_I2C_DEBUG_BUS is not set
CONFIG_SPI=y
# CONFIG_SPI_DEBUG is not set
CONFIG_SPI_MASTER=y
#
# SPI Master Controller Drivers
#
# CONFIG_SPI_ALTERA is not set
# CONFIG_SPI_AXI_SPI_ENGINE is not set
# CONFIG SPI BITBANG is not set
# CONFIG_SPI_CADENCE is not set
# CONFIG_SPI_DESIGNWARE is not set
# CONFIG_SPI_GPIO is not set
# CONFIG_SPI_FSL_SPI is not set
# CONFIG_SPI_OC_TINY is not set
```

```
CONFIG_SPI_PL022=y
# CONFIG_SPI_PXA2XX_PCI is not set
# CONFIG_SPI_ROCKCHIP is not set
# CONFIG_SPI_SC18IS602 is not set
# CONFIG_SPI_XCOMM is not set
# CONFIG_SPI_XILINX is not set
# CONFIG_SPI_ZYNQMP_GQSPI is not set
#
# SPI Protocol Masters
#
# CONFIG_SPI_SPIDEV is not set
# CONFIG_SPI_LOOPBACK_TEST is not set
# CONFIG_SPI_TLE62X0 is not set
# CONFIG_SPMI is not set
# CONFIG_HSI is not set
#
# PPS support
#
CONFIG_PPS=y
# CONFIG_PPS_DEBUG is not set
# CONFIG_NTP_PPS is not set
#
# PPS clients support
#
# CONFIG_PPS_CLIENT_KTIMER is not set
# CONFIG_PPS_CLIENT_LDISC is not set
```

```
# CONFIG_PPS_CLIENT_GPIO is not set
#
# PPS generators support
#
#
# PTP clock support
#
CONFIG_PTP_1588_CLOCK=y
#
# Enable PHYLIB and NETWORK_PHY_TIMESTAMPING to see the additional clocks.
#
CONFIG_PINCTRL=y
#
# Pin controllers
#
# CONFIG_DEBUG_PINCTRL is not set
# CONFIG_PINCTRL_AMD is not set
# CONFIG_PINCTRL_SINGLE is not set
# CONFIG_PINCTRL_SX150X is not set
CONFIG_ARCH_HAVE_CUSTOM_GPIO_H=y
CONFIG_GPIOLIB=y
CONFIG_OF_GPIO=y
CONFIG_GPIOLIB_IRQCHIP=y
# CONFIG_DEBUG_GPIO is not set
CONFIG_GPIO_SYSFS=y
```

```
# Memory mapped GPIO drivers
#
# CONFIG_GPIO_74XX_MMIO is not set
# CONFIG_GPIO_ALTERA is not set
# CONFIG_GPIO_DWAPB is not set
# CONFIG_GPIO_FTGPIO010 is not set
# CONFIG_GPIO_GENERIC_PLATFORM is not set
# CONFIG_GPIO_GRGPIO is not set
# CONFIG_GPIO_MOCKUP is not set
# CONFIG_GPIO_MPC8XXX is not set
CONFIG_GPIO_PL061=y
# CONFIG_GPIO_SYSCON is not set
# CONFIG_GPIO_XILINX is not set
# CONFIG_GPIO_ZEVIO is not set
#
# I2C GPIO expanders
#
# CONFIG_GPIO_ADP5588 is not set
# CONFIG_GPIO_ADNP is not set
# CONFIG_GPIO_MAX7300 is not set
# CONFIG GPIO MAX732X is not set
# CONFIG_GPIO_PCA953X is not set
# CONFIG_GPIO_PCF857X is not set
# CONFIG_GPIO_SX150X is not set
# CONFIG_GPIO_TPIC2810 is not set
```

#

```
#
# MFD GPIO expanders
#
# CONFIG_HTC_EGPIO is not set
#
# SPI GPIO expanders
#
# CONFIG_GPIO_74X164 is not set
# CONFIG_GPIO_MAX7301 is not set
# CONFIG_GPIO_MC33880 is not set
# CONFIG_GPIO_PISOSR is not set
#
# SPI or I2C GPIO expanders
# CONFIG_GPIO_MCP23S08 is not set
#
# USB GPIO expanders
#
# CONFIG_W1 is not set
# CONFIG_POWER_AVS is not set
# CONFIG_POWER_RESET is not set
# CONFIG_POWER_SUPPLY is not set
# CONFIG_HWMON is not set
# CONFIG_THERMAL is not set
CONFIG_WATCHDOG=y
CONFIG_WATCHDOG_CORE=y
```

```
# CONFIG_WATCHDOG_NOWAYOUT is not set
# CONFIG_WATCHDOG_SYSFS is not set
#
# Watchdog Device Drivers
#
# CONFIG_SOFT_WATCHDOG is not set
# CONFIG_GPIO_WATCHDOG is not set
# CONFIG_XILINX_WATCHDOG is not set
# CONFIG_ZIIRAVE_WATCHDOG is not set
CONFIG_ARM_SP805_WATCHDOG=y
# CONFIG_CADENCE_WATCHDOG is not set
# CONFIG_DW_WATCHDOG is not set
# CONFIG_MAX63XX_WATCHDOG is not set
# CONFIG_MEN_A21_WDT is not set
#
# USB-based Watchdog Cards
#
# CONFIG_USBPCWATCHDOG is not set
#
# Watchdog Pretimeout Governors
# CONFIG_WATCHDOG_PRETIMEOUT_GOV is not set
CONFIG_SSB_POSSIBLE=y
#
# Sonics Silicon Backplane
```

```
#
# CONFIG_SSB is not set
CONFIG_BCMA_POSSIBLE=y
#
# Broadcom specific AMBA
# CONFIG_BCMA is not set
#
# Multifunction device drivers
#
# CONFIG_MFD_CORE is not set
# CONFIG_MFD_ACT8945A is not set
# CONFIG_MFD_AS3711 is not set
# CONFIG_MFD_AS3722 is not set
# CONFIG_PMIC_ADP5520 is not set
# CONFIG_MFD_AAT2870_CORE is not set
# CONFIG_MFD_ATMEL_FLEXCOM is not set
# CONFIG_MFD_ATMEL_HLCDC is not set
# CONFIG_MFD_BCM590XX is not set
# CONFIG_MFD_AXP20X_I2C is not set
# CONFIG_MFD_CROS_EC is not set
# CONFIG MFD ASIC3 is not set
# CONFIG_PMIC_DA903X is not set
# CONFIG_MFD_DA9052_SPI is not set
# CONFIG_MFD_DA9052_I2C is not set
# CONFIG_MFD_DA9055 is not set
# CONFIG_MFD_DA9062 is not set
```

- # CONFIG\_MFD\_DA9063 is not set
- # CONFIG\_MFD\_DA9150 is not set
- # CONFIG\_MFD\_DLN2 is not set
- # CONFIG\_MFD\_MC13XXX\_SPI is not set
- # CONFIG\_MFD\_MC13XXX\_I2C is not set
- # CONFIG\_MFD\_HI6421\_PMIC is not set
- # CONFIG HTC PASIC3 is not set
- # CONFIG\_HTC\_I2CPLD is not set
- # CONFIG\_INTEL\_SOC\_PMIC is not set
- # CONFIG\_MFD\_KEMPLD is not set
- # CONFIG\_MFD\_88PM800 is not set
- # CONFIG\_MFD\_88PM805 is not set
- # CONFIG\_MFD\_88PM860X is not set
- # CONFIG MFD MAX14577 is not set
- # CONFIG\_MFD\_MAX77620 is not set
- # CONFIG\_MFD\_MAX77686 is not set
- # CONFIG\_MFD\_MAX77693 is not set
- # CONFIG\_MFD\_MAX77843 is not set
- # CONFIG\_MFD\_MAX8907 is not set
- # CONFIG\_MFD\_MAX8925 is not set
- # CONFIG\_MFD\_MAX8997 is not set
- # CONFIG\_MFD\_MAX8998 is not set
- # CONFIG\_MFD\_MT6397 is not set
- # CONFIG MFD MENF21BMC is not set
- # CONFIG\_EZX\_PCAP is not set
- # CONFIG\_MFD\_CPCAP is not set
- # CONFIG\_MFD\_VIPERBOARD is not set
- # CONFIG\_MFD\_RETU is not set
- # CONFIG\_MFD\_PCF50633 is not set

- # CONFIG\_MFD\_PM8XXX is not set
- # CONFIG\_MFD\_RT5033 is not set
- # CONFIG\_MFD\_RTSX\_USB is not set
- # CONFIG\_MFD\_RC5T583 is not set
- # CONFIG\_MFD\_RK808 is not set
- # CONFIG\_MFD\_RN5T618 is not set
- # CONFIG\_MFD\_SEC\_CORE is not set
- # CONFIG\_MFD\_SI476X\_CORE is not set
- # CONFIG\_MFD\_SM501 is not set
- # CONFIG MFD SKY81452 is not set
- # CONFIG\_MFD\_SMSC is not set
- # CONFIG\_ABX500\_CORE is not set
- # CONFIG\_MFD\_STMPE is not set
- CONFIG MFD SYSCON=v
- # CONFIG\_MFD\_TI\_AM335X\_TSCADC is not set
- # CONFIG\_MFD\_LP3943 is not set
- # CONFIG\_MFD\_LP8788 is not set
- # CONFIG\_MFD\_TI\_LMU is not set
- # CONFIG\_MFD\_PALMAS is not set
- # CONFIG\_TPS6105X is not set
- # CONFIG\_TPS65010 is not set
- # CONFIG\_TPS6507X is not set
- # CONFIG\_MFD\_TPS65086 is not set
- # CONFIG MFD TPS65090 is not set
- # CONFIG\_MFD\_TPS65217 is not set
- # CONFIG\_MFD\_TI\_LP873X is not set
- # CONFIG\_MFD\_TPS65218 is not set
- # CONFIG\_MFD\_TPS6586X is not set
- # CONFIG\_MFD\_TPS65910 is not set

```
# CONFIG_MFD_TPS65912_I2C is not set
# CONFIG_MFD_TPS65912_SPI is not set
# CONFIG_MFD_TPS80031 is not set
# CONFIG_TWL4030_CORE is not set
# CONFIG_TWL6040_CORE is not set
# CONFIG_MFD_WL1273_CORE is not set
# CONFIG MFD LM3533 is not set
# CONFIG_MFD_TC3589X is not set
# CONFIG_MFD_TMIO is not set
# CONFIG_MFD_T7L66XB is not set
# CONFIG_MFD_TC6387XB is not set
# CONFIG_MFD_TC6393XB is not set
# CONFIG_MFD_ARIZONA_I2C is not set
# CONFIG_MFD_ARIZONA_SPI is not set
# CONFIG_MFD_WM8400 is not set
# CONFIG_MFD_WM831X_I2C is not set
# CONFIG_MFD_WM831X_SPI is not set
# CONFIG_MFD_WM8350_I2C is not set
# CONFIG_MFD_WM8994 is not set
# CONFIG_REGULATOR is not set
# CONFIG_MEDIA_SUPPORT is not set
#
# Graphics support
#
# CONFIG_IMX_IPUV3_CORE is not set
# CONFIG_DRM is not set
```

```
# ACP (Audio CoProcessor) Configuration
#
# CONFIG_DRM_LIB_RANDOM is not set
#
# Frame buffer Devices
# CONFIG_FB is not set
# CONFIG_BACKLIGHT_LCD_SUPPORT is not set
# CONFIG_VGASTATE is not set
#
# Console display driver support
CONFIG_DUMMY_CONSOLE=y
# CONFIG_SOUND is not set
#
# HID support
#
CONFIG_HID=y
# CONFIG_HID_BATTERY_STRENGTH is not set
# CONFIG_HIDRAW is not set
# CONFIG_UHID is not set
CONFIG_HID_GENERIC=y
#
# Special HID drivers
#
```

CONFIG\_HID\_A4TECH=y

# CONFIG\_HID\_ACCUTOUCH is not set

# CONFIG\_HID\_ACRUX is not set

CONFIG\_HID\_APPLE=y

# CONFIG\_HID\_APPLEIR is not set

# CONFIG\_HID\_AUREAL is not set

CONFIG\_HID\_BELKIN=y

# CONFIG\_HID\_BETOP\_FF is not set

CONFIG\_HID\_CHERRY=y

CONFIG\_HID\_CHICONY=y

# CONFIG\_HID\_CMEDIA is not set

# CONFIG\_HID\_CP2112 is not set

CONFIG\_HID\_CYPRESS=y

# CONFIG HID DRAGONRISE is not set

# CONFIG\_HID\_EMS\_FF is not set

# CONFIG\_HID\_ELECOM is not set

# CONFIG\_HID\_ELO is not set

CONFIG\_HID\_EZKEY=y

# CONFIG\_HID\_GEMBIRD is not set

# CONFIG\_HID\_GFRM is not set

# CONFIG\_HID\_HOLTEK is not set

# CONFIG\_HID\_KEYTOUCH is not set

# CONFIG\_HID\_KYE is not set

# CONFIG HID UCLOGIC is not set

# CONFIG\_HID\_WALTOP is not set

# CONFIG\_HID\_GYRATION is not set

# CONFIG\_HID\_ICADE is not set

# CONFIG\_HID\_TWINHAN is not set

CONFIG\_HID\_KENSINGTON=y

```
# CONFIG_HID_LCPOWER is not set
```

# CONFIG\_HID\_LENOVO is not set

CONFIG\_HID\_LOGITECH=y

- # CONFIG\_HID\_LOGITECH\_HIDPP is not set
- # CONFIG\_LOGITECH\_FF is not set
- # CONFIG\_LOGIRUMBLEPAD2\_FF is not set
- # CONFIG LOGIG940 FF is not set
- # CONFIG\_LOGIWHEELS\_FF is not set
- # CONFIG\_HID\_MAGICMOUSE is not set
- # CONFIG HID MAYFLASH is not set
- CONFIG\_HID\_MICROSOFT=y
- CONFIG\_HID\_MONTEREY=y
- # CONFIG\_HID\_MULTITOUCH is not set
- # CONFIG\_HID\_NTI is not set
- # CONFIG\_HID\_NTRIG is not set
- # CONFIG\_HID\_ORTEK is not set
- # CONFIG HID PANTHERLORD is not set
- # CONFIG\_HID\_PENMOUNT is not set
- # CONFIG\_HID\_PETALYNX is not set
- # CONFIG\_HID\_PICOLCD is not set
- # CONFIG\_HID\_PLANTRONICS is not set
- # CONFIG\_HID\_PRIMAX is not set
- # CONFIG\_HID\_ROCCAT is not set
- # CONFIG HID SAITEK is not set
- # CONFIG\_HID\_SAMSUNG is not set
- # CONFIG\_HID\_SPEEDLINK is not set
- # CONFIG\_HID\_STEELSERIES is not set
- # CONFIG\_HID\_SUNPLUS is not set
- # CONFIG\_HID\_RMI is not set

```
# CONFIG_HID_GREENASIA is not set
# CONFIG_HID_SMARTJOYPLUS is not set
# CONFIG_HID_TIVO is not set
# CONFIG_HID_TOPSEED is not set
# CONFIG_HID_THRUSTMASTER is not set
# CONFIG_HID_UDRAW_PS3 is not set
# CONFIG_HID_WACOM is not set
# CONFIG_HID_XINMO is not set
# CONFIG_HID_ZEROPLUS is not set
# CONFIG_HID_ZYDACRON is not set
# CONFIG_HID_SENSOR_HUB is not set
# CONFIG_HID_ALPS is not set
#
# USB HID support
CONFIG_USB_HID=y
# CONFIG_HID_PID is not set
# CONFIG_USB_HIDDEV is not set
#
# I2C HID support
# CONFIG_I2C_HID is not set
CONFIG_USB_OHCI_LITTLE_ENDIAN=y
CONFIG_USB_SUPPORT=y
CONFIG_USB_COMMON=y
CONFIG_USB_ARCH_HAS_HCD=y
CONFIG_USB=y
```

```
# CONFIG_USB_ANNOUNCE_NEW_DEVICES is not set
```

```
#
# Miscellaneous USB options
#
CONFIG_USB_DEFAULT_PERSIST=y
# CONFIG_USB_DYNAMIC_MINORS is not set
# CONFIG_USB_OTG is not set
# CONFIG_USB_OTG_WHITELIST is not set
# CONFIG_USB_MON is not set
# CONFIG_USB_WUSB_CBAF is not set
#
# USB Host Controller Drivers
# CONFIG_USB_C67X00_HCD is not set
# CONFIG USB XHCI HCD is not set
CONFIG_USB_EHCI_HCD=y
# CONFIG_USB_EHCI_ROOT_HUB_TT is not set
CONFIG_USB_EHCI_TT_NEWSCHED=y
# CONFIG_USB_EHCI_HCD_PLATFORM is not set
# CONFIG_USB_OXU210HP_HCD is not set
# CONFIG_USB_ISP116X_HCD is not set
# CONFIG USB ISP1362 HCD is not set
# CONFIG_USB_FOTG210_HCD is not set
# CONFIG_USB_MAX3421_HCD is not set
CONFIG_USB_OHCI_HCD=y
# CONFIG_USB_OHCI_HCD_PLATFORM is not set
# CONFIG_USB_SL811_HCD is not set
```

```
# CONFIG_USB_R8A66597_HCD is not set
# CONFIG_USB_HCD_TEST_MODE is not set
#
# USB Device Class drivers
#
# CONFIG USB ACM is not set
# CONFIG_USB_PRINTER is not set
# CONFIG_USB_WDM is not set
# CONFIG_USB_TMC is not set
#
# NOTE: USB_STORAGE depends on SCSI but BLK_DEV_SD may
#
#
# also be needed; see USB_STORAGE Help for more info
#
CONFIG_USB_STORAGE=y
# CONFIG_USB_STORAGE_DEBUG is not set
# CONFIG_USB_STORAGE_REALTEK is not set
# CONFIG_USB_STORAGE_DATAFAB is not set
# CONFIG_USB_STORAGE_FREECOM is not set
# CONFIG_USB_STORAGE_ISD200 is not set
# CONFIG_USB_STORAGE_USBAT is not set
# CONFIG_USB_STORAGE_SDDR09 is not set
# CONFIG_USB_STORAGE_SDDR55 is not set
# CONFIG_USB_STORAGE_JUMPSHOT is not set
# CONFIG_USB_STORAGE_ALAUDA is not set
```

```
# CONFIG_USB_STORAGE_KARMA is not set
# CONFIG_USB_STORAGE_CYPRESS_ATACB is not set
# CONFIG_USB_STORAGE_ENE_UB6250 is not set
# CONFIG_USB_UAS is not set
#
# USB Imaging devices
#
# CONFIG_USB_MDC800 is not set
# CONFIG_USB_MICROTEK is not set
# CONFIG_USBIP_CORE is not set
# CONFIG_USB_MUSB_HDRC is not set
CONFIG_USB_DWC3=y
CONFIG_USB_DWC3_HOST=y
#
# Platform Glue Driver Support
#
CONFIG_USB_DWC3_OF_SIMPLE=y
# CONFIG_USB_DWC2 is not set
# CONFIG_USB_CHIPIDEA is not set
# CONFIG_USB_ISP1760 is not set
#
# USB port drivers
#
# CONFIG_USB_SERIAL is not set
```

# CONFIG\_USB\_STORAGE\_ONETOUCH is not set

```
#
# USB Miscellaneous drivers
#
# CONFIG_USB_EMI62 is not set
# CONFIG_USB_EMI26 is not set
# CONFIG_USB_ADUTUX is not set
# CONFIG USB SEVSEG is not set
# CONFIG_USB_RIO500 is not set
# CONFIG_USB_LEGOTOWER is not set
# CONFIG USB LCD is not set
# CONFIG_USB_CYPRESS_CY7C63 is not set
# CONFIG_USB_CYTHERM is not set
# CONFIG_USB_IDMOUSE is not set
# CONFIG_USB_FTDI_ELAN is not set
# CONFIG_USB_APPLEDISPLAY is not set
# CONFIG_USB_SISUSBVGA is not set
# CONFIG USB LD is not set
# CONFIG_USB_TRANCEVIBRATOR is not set
# CONFIG_USB_IOWARRIOR is not set
# CONFIG_USB_TEST is not set
# CONFIG_USB_EHSET_TEST_FIXTURE is not set
# CONFIG_USB_ISIGHTFW is not set
# CONFIG_USB_YUREX is not set
# CONFIG USB EZUSB FX2 is not set
# CONFIG_USB_HUB_USB251XB is not set
# CONFIG_USB_HSIC_USB3503 is not set
# CONFIG_USB_HSIC_USB4604 is not set
# CONFIG_USB_LINK_LAYER_TEST is not set
```

```
#
# USB Physical Layer drivers
#
# CONFIG_USB_PHY is not set
# CONFIG_NOP_USB_XCEIV is not set
# CONFIG_USB_GPIO_VBUS is not set
# CONFIG_USB_ISP1301 is not set
# CONFIG_USB_ULPI is not set
# CONFIG_USB_GADGET is not set
#
# USB Power Delivery and Type-C drivers
#
# CONFIG_USB_ULPI_BUS is not set
# CONFIG_UWB is not set
CONFIG_MMC=y
# CONFIG_MMC_DEBUG is not set
CONFIG_PWRSEQ_EMMC=y
CONFIG_PWRSEQ_SIMPLE=y
CONFIG_MMC_BLOCK=y
CONFIG_MMC_BLOCK_MINORS=8
CONFIG_MMC_BLOCK_BOUNCE=y
# CONFIG_SDIO_UART is not set
# CONFIG_MMC_TEST is not set
#
# MMC/SD/SDIO Host Controller Drivers
#
# CONFIG_MMC_ARMMMCI is not set
```

```
CONFIG_MMC_SDHCI=y
# CONFIG_MMC_SDHCI_PLTFM is not set
# CONFIG_MMC_SPI is not set
CONFIG_MMC_DW=y
CONFIG_MMC_DW_PLTFM=y
# CONFIG_MMC_DW_EXYNOS is not set
# CONFIG MMC DW K3 is not set
# CONFIG_MMC_VUB300 is not set
# CONFIG_MMC_USHC is not set
# CONFIG_MMC_USDHI6ROL0 is not set
# CONFIG_MMC_MTK is not set
# CONFIG_MEMSTICK is not set
# CONFIG_NEW_LEDS is not set
# CONFIG_ACCESSIBILITY is not set
CONFIG_EDAC_ATOMIC_SCRUB=y
CONFIG_EDAC_SUPPORT=y
# CONFIG_EDAC is not set
CONFIG_RTC_LIB=y
CONFIG_RTC_CLASS=y
CONFIG_RTC_HCTOSYS=y
CONFIG_RTC_HCTOSYS_DEVICE="rtc0"
CONFIG_RTC_SYSTOHC=y
CONFIG_RTC_SYSTOHC_DEVICE="rtc0"
# CONFIG RTC DEBUG is not set
#
# RTC interfaces
#
CONFIG_RTC_INTF_SYSFS=y
```

```
CONFIG_RTC_INTF_PROC=y
CONFIG_RTC_INTF_DEV=y
# CONFIG_RTC_INTF_DEV_UIE_EMUL is not set
# CONFIG_RTC_DRV_TEST is not set
#
# I2C RTC drivers
#
# CONFIG_RTC_DRV_ABB5ZES3 is not set
# CONFIG_RTC_DRV_ABX80X is not set
# CONFIG_RTC_DRV_DS1307 is not set
# CONFIG_RTC_DRV_DS1374 is not set
# CONFIG_RTC_DRV_DS1672 is not set
# CONFIG RTC DRV HYM8563 is not set
# CONFIG_RTC_DRV_MAX6900 is not set
# CONFIG_RTC_DRV_RS5C372 is not set
# CONFIG RTC DRV ISL1208 is not set
# CONFIG_RTC_DRV_ISL12022 is not set
# CONFIG_RTC_DRV_X1205 is not set
# CONFIG_RTC_DRV_PCF8523 is not set
# CONFIG_RTC_DRV_PCF85063 is not set
# CONFIG_RTC_DRV_PCF8563 is not set
# CONFIG_RTC_DRV_PCF8583 is not set
# CONFIG RTC DRV M41T80 is not set
# CONFIG_RTC_DRV_BQ32K is not set
# CONFIG_RTC_DRV_S35390A is not set
# CONFIG_RTC_DRV_FM3130 is not set
# CONFIG_RTC_DRV_RX8010 is not set
# CONFIG_RTC_DRV_RX8581 is not set
```

```
# CONFIG_RTC_DRV_RX8025 is not set
# CONFIG_RTC_DRV_EM3027 is not set
# CONFIG_RTC_DRV_RV8803 is not set
#
# SPI RTC drivers
# CONFIG_RTC_DRV_M41T93 is not set
# CONFIG_RTC_DRV_M41T94 is not set
# CONFIG_RTC_DRV_DS1302 is not set
# CONFIG_RTC_DRV_DS1305 is not set
# CONFIG_RTC_DRV_DS1343 is not set
# CONFIG_RTC_DRV_DS1347 is not set
# CONFIG_RTC_DRV_DS1390 is not set
# CONFIG_RTC_DRV_MAX6916 is not set
# CONFIG_RTC_DRV_R9701 is not set
# CONFIG_RTC_DRV_RX4581 is not set
# CONFIG_RTC_DRV_RX6110 is not set
# CONFIG_RTC_DRV_RS5C348 is not set
# CONFIG_RTC_DRV_MAX6902 is not set
# CONFIG_RTC_DRV_PCF2123 is not set
# CONFIG_RTC_DRV_MCP795 is not set
CONFIG_RTC_I2C_AND_SPI=y
#
# SPI and I2C RTC drivers
#
# CONFIG_RTC_DRV_DS3232 is not set
# CONFIG_RTC_DRV_PCF2127 is not set
```

```
# CONFIG_RTC_DRV_RV3029C2 is not set
#
# Platform RTC drivers
#
# CONFIG_RTC_DRV_CMOS is not set
# CONFIG RTC DRV DS1286 is not set
# CONFIG_RTC_DRV_DS1511 is not set
# CONFIG_RTC_DRV_DS1553 is not set
# CONFIG_RTC_DRV_DS1685_FAMILY is not set
# CONFIG_RTC_DRV_DS1742 is not set
# CONFIG_RTC_DRV_DS2404 is not set
# CONFIG_RTC_DRV_STK17TA8 is not set
# CONFIG_RTC_DRV_M48T86 is not set
# CONFIG_RTC_DRV_M48T35 is not set
# CONFIG_RTC_DRV_M48T59 is not set
# CONFIG_RTC_DRV_MSM6242 is not set
# CONFIG_RTC_DRV_BQ4802 is not set
# CONFIG_RTC_DRV_RP5C01 is not set
# CONFIG_RTC_DRV_V3020 is not set
# CONFIG_RTC_DRV_ZYNQMP is not set
#
# on-CPU RTC drivers
CONFIG_RTC_DRV_PL030=y
```

CONFIG\_RTC\_DRV\_PL031=y

# CONFIG\_RTC\_DRV\_SNVS is not set

# CONFIG\_RTC\_DRV\_R7301 is not set

```
# HID Sensor RTC drivers
#
# CONFIG_RTC_DRV_HID_SENSOR_TIME is not set
CONFIG_DMADEVICES=y
# CONFIG_DMADEVICES_DEBUG is not set
#
# DMA Devices
#
CONFIG_DMA_ENGINE=y
CONFIG_DMA_OF=y
# CONFIG_AMBA_PL08X is not set
# CONFIG_FSL_EDMA is not set
# CONFIG_INTEL_IDMA64 is not set
# CONFIG_NBPFAXI_DMA is not set
# CONFIG_PL330_DMA is not set
# CONFIG_QCOM_HIDMA_MGMT is not set
# CONFIG_QCOM_HIDMA is not set
CONFIG_DW_DMAC_CORE=y
CONFIG_DW_DMAC=y
#
# DMA Clients
#
# CONFIG_ASYNC_TX_DMA is not set
CONFIG_DMATEST=m
CONFIG_DMA_ENGINE_RAID=y
```

#

```
#
# DMABUF options
#
# CONFIG_SYNC_FILE is not set
# CONFIG_AUXDISPLAY is not set
# CONFIG_UIO is not set
# CONFIG_VIRT_DRIVERS is not set
#
# Virtio drivers
#
# CONFIG_VIRTIO_MMIO is not set
#
# Microsoft Hyper-V guest support
#
# CONFIG_HYPERV_TSCPAGE is not set
# CONFIG_STAGING is not set
# CONFIG_GOLDFISH is not set
# CONFIG_CHROME_PLATFORMS is not set
CONFIG_CLKDEV_LOOKUP=y
CONFIG_HAVE_CLK_PREPARE=y
CONFIG_COMMON_CLK=y
#
# Common Clock Framework
#
# CONFIG_COMMON_CLK_SI5351 is not set
```

```
# CONFIG_COMMON_CLK_SI514 is not set
# CONFIG_COMMON_CLK_SI570 is not set
# CONFIG_COMMON_CLK_CDCE706 is not set
# CONFIG_COMMON_CLK_CDCE925 is not set
# CONFIG_COMMON_CLK_CS2000_CP is not set
# CONFIG_CLK_QORIQ is not set
# CONFIG_COMMON_CLK_NXP is not set
# CONFIG_COMMON_CLK_PXA is not set
# CONFIG_COMMON_CLK_PIC32 is not set
# CONFIG_COMMON_CLK_VC5 is not set
#
# Hardware Spinlock drivers
#
#
# Clock Source drivers
#
CONFIG_CLKSRC_OF=y
CONFIG_CLKSRC_PROBE=y
CONFIG_CLKSRC_MMIO=y
CONFIG_ARM_GLOBAL_TIMER=y
CONFIG_ARM_TIMER_SP804=y
CONFIG_CLKSRC_ARM_GLOBAL_TIMER_SCHED_CLOCK=y
# CONFIG_ATMEL_PIT is not set
# CONFIG_SH_TIMER_CMT is not set
# CONFIG_SH_TIMER_MTU2 is not set
# CONFIG_SH_TIMER_TMU is not set
# CONFIG_EM_TIMER_STI is not set
```

```
# CONFIG_MAILBOX is not set
CONFIG_IOMMU_SUPPORT=y
#
# Generic IOMMU Pagetable Support
#
# CONFIG_IOMMU_IO_PGTABLE_LPAE is not set
# CONFIG_IOMMU_IO_PGTABLE_ARMV7S is not set
# CONFIG_ARM_SMMU is not set
#
# Remoteproc drivers
#
# CONFIG_REMOTEPROC is not set
#
# Rpmsg drivers
#
#
# SOC (System On Chip) specific Drivers
#
#
# Broadcom SoC drivers
#
# CONFIG_SOC_BRCMSTB is not set
```

#

```
# i.MX SoC drivers
#
# CONFIG_SUNXI_SRAM is not set
# CONFIG_SOC_TI is not set
# CONFIG_SOC_ZTE is not set
# CONFIG_PM_DEVFREQ is not set
# CONFIG EXTCON is not set
# CONFIG_MEMORY is not set
# CONFIG_IIO is not set
# CONFIG PWM is not set
CONFIG_IRQCHIP=y
CONFIG_ARM_GIC=y
CONFIG_ARM_GIC_MAX_NR=1
# CONFIG_IPACK_BUS is not set
CONFIG_RESET_CONTROLLER=y
# CONFIG_RESET_ATH79 is not set
# CONFIG RESET BERLIN is not set
# CONFIG_RESET_IMX7 is not set
# CONFIG_RESET_LPC18XX is not set
# CONFIG_RESET_MESON is not set
# CONFIG_RESET_PISTACHIO is not set
# CONFIG_RESET_SOCFPGA is not set
# CONFIG_RESET_STM32 is not set
# CONFIG RESET SUNXI is not set
# CONFIG_TI_SYSCON_RESET is not set
# CONFIG_RESET_ZYNQ is not set
# CONFIG_RESET_TEGRA_BPMP is not set
# CONFIG_FMC is not set
```

```
#
# PHY Subsystem
#
CONFIG_GENERIC_PHY=y
# CONFIG_PHY_PXA_28NM_HSIC is not set
# CONFIG_PHY_PXA_28NM_USB2 is not set
# CONFIG_BCM_KONA_USB2_PHY is not set
# CONFIG_POWERCAP is not set
# CONFIG_MCB is not set
#
# Performance monitor support
#
CONFIG_RAS=y
#
# Android
# CONFIG_ANDROID is not set
# CONFIG_DAX is not set
# CONFIG_NVMEM is not set
# CONFIG_STM is not set
# CONFIG_INTEL_TH is not set
#
# FPGA Configuration Support
#
# CONFIG_FPGA is not set
```

```
#
# FSI support
#
# CONFIG_FSI is not set
# CONFIG_TEE is not set
#
# Firmware Drivers
#
# CONFIG_FIRMWARE_MEMMAP is not set
# CONFIG_FW_CFG_SYSFS is not set
CONFIG_HAVE_ARM_SMCCC=y
# CONFIG_GOOGLE_FIRMWARE is not set
#
# Tegra firmware driver
#
#
# File systems
#
CONFIG_DCACHE_WORD_ACCESS=y
CONFIG_EXT2_FS=y
CONFIG_EXT2_FS_XATTR=y
# CONFIG_EXT2_FS_POSIX_ACL is not set
CONFIG_EXT2_FS_SECURITY=y
CONFIG_EXT3_FS=y
# CONFIG_EXT3_FS_POSIX_ACL is not set
CONFIG_EXT3_FS_SECURITY=y
```

```
CONFIG_EXT4_FS=y
```

# CONFIG\_EXT4\_FS\_POSIX\_ACL is not set

CONFIG\_EXT4\_FS\_SECURITY=y

# CONFIG\_EXT4\_ENCRYPTION is not set

# CONFIG\_EXT4\_DEBUG is not set

CONFIG\_JBD2=y

# CONFIG JBD2 DEBUG is not set

CONFIG\_FS\_MBCACHE=y

# CONFIG\_REISERFS\_FS is not set

# CONFIG\_JFS\_FS is not set

# CONFIG\_XFS\_FS is not set

# CONFIG\_GFS2\_FS is not set

# CONFIG\_BTRFS\_FS is not set

# CONFIG\_NILFS2\_FS is not set

# CONFIG\_F2FS\_FS is not set

CONFIG\_FS\_POSIX\_ACL=y

CONFIG EXPORTFS=v

# CONFIG\_EXPORTFS\_BLOCK\_OPS is not set

CONFIG\_FILE\_LOCKING=y

CONFIG\_MANDATORY\_FILE\_LOCKING=y

# CONFIG\_FS\_ENCRYPTION is not set

CONFIG\_FSNOTIFY=y

CONFIG\_DNOTIFY=y

CONFIG\_INOTIFY\_USER=y

# CONFIG\_FANOTIFY is not set

# CONFIG\_QUOTA is not set

# CONFIG\_QUOTACTL is not set

CONFIG\_AUTOFS4\_FS=m

CONFIG\_FUSE\_FS=y

```
# CONFIG_CUSE is not set
# CONFIG_OVERLAY_FS is not set
#
# Caches
# CONFIG_FSCACHE is not set
#
# CD-ROM/DVD Filesystems
#
# CONFIG_ISO9660_FS is not set
# CONFIG_UDF_FS is not set
#
# DOS/FAT/NT Filesystems
#
CONFIG_FAT_FS=m
CONFIG_MSDOS_FS=m
CONFIG_VFAT_FS=m
CONFIG_FAT_DEFAULT_CODEPAGE=437
CONFIG_FAT_DEFAULT_IOCHARSET="ascii"
# CONFIG_FAT_DEFAULT_UTF8 is not set
# CONFIG_NTFS_FS is not set
#
# Pseudo filesystems
#
CONFIG_PROC_FS=y
```

```
CONFIG_PROC_SYSCTL=y
```

CONFIG\_PROC\_PAGE\_MONITOR=y

# CONFIG\_PROC\_CHILDREN is not set

CONFIG\_KERNFS=y

CONFIG\_SYSFS=y

CONFIG\_TMPFS=y

# CONFIG\_TMPFS\_POSIX\_ACL is not set

# CONFIG\_TMPFS\_XATTR is not set

# CONFIG\_HUGETLB\_PAGE is not set

# CONFIG\_CONFIGFS\_FS is not set

CONFIG\_MISC\_FILESYSTEMS=y

# CONFIG\_ORANGEFS\_FS is not set

# CONFIG\_ADFS\_FS is not set

# CONFIG AFFS FS is not set

# CONFIG\_HFS\_FS is not set

# CONFIG\_HFSPLUS\_FS is not set

# CONFIG BEFS FS is not set

# CONFIG\_BFS\_FS is not set

# CONFIG\_EFS\_FS is not set

CONFIG\_JFFS2\_FS=y

CONFIG\_JFFS2\_FS\_DEBUG=0

CONFIG\_JFFS2\_FS\_WRITEBUFFER=y

# CONFIG\_JFFS2\_FS\_WBUF\_VERIFY is not set

# CONFIG JFFS2 SUMMARY is not set

# CONFIG\_JFFS2\_FS\_XATTR is not set

# CONFIG\_JFFS2\_COMPRESSION\_OPTIONS is not set

CONFIG\_JFFS2\_ZLIB=y

# CONFIG\_JFFS2\_LZO is not set

CONFIG\_JFFS2\_RTIME=y

```
# CONFIG_JFFS2_RUBIN is not set
```

- # CONFIG\_CRAMFS is not set
- # CONFIG\_SQUASHFS is not set
- # CONFIG\_VXFS\_FS is not set
- # CONFIG\_MINIX\_FS is not set
- # CONFIG\_OMFS\_FS is not set
- # CONFIG\_HPFS\_FS is not set
- # CONFIG\_QNX4FS\_FS is not set
- # CONFIG\_QNX6FS\_FS is not set
- # CONFIG\_ROMFS\_FS is not set
- # CONFIG\_PSTORE is not set
- # CONFIG\_SYSV\_FS is not set
- # CONFIG\_UFS\_FS is not set
- CONFIG\_NETWORK\_FILESYSTEMS=y
- CONFIG\_NFS\_FS=y
- CONFIG\_NFS\_V2=y
- CONFIG\_NFS\_V3=y
- # CONFIG\_NFS\_V3\_ACL is not set
- # CONFIG\_NFS\_V4 is not set
- # CONFIG\_NFS\_SWAP is not set
- CONFIG\_ROOT\_NFS=y
- # CONFIG\_NFSD is not set
- CONFIG\_GRACE\_PERIOD=y
- CONFIG\_LOCKD=y
- CONFIG\_LOCKD\_V4=y
- CONFIG\_NFS\_COMMON=y
- CONFIG\_SUNRPC=y
- # CONFIG\_SUNRPC\_DEBUG is not set
- # CONFIG\_CEPH\_FS is not set

- # CONFIG\_CIFS is not set
- # CONFIG\_NCP\_FS is not set
- # CONFIG\_CODA\_FS is not set
- # CONFIG\_AFS\_FS is not set
- CONFIG\_NLS=y
- CONFIG\_NLS\_DEFAULT="utf8"
- CONFIG NLS CODEPAGE 437=v
- # CONFIG\_NLS\_CODEPAGE\_737 is not set
- # CONFIG\_NLS\_CODEPAGE\_775 is not set
- # CONFIG\_NLS\_CODEPAGE\_850 is not set
- # CONFIG\_NLS\_CODEPAGE\_852 is not set
- # CONFIG\_NLS\_CODEPAGE\_855 is not set
- # CONFIG\_NLS\_CODEPAGE\_857 is not set
- # CONFIG\_NLS\_CODEPAGE\_860 is not set
- # CONFIG\_NLS\_CODEPAGE\_861 is not set
- # CONFIG\_NLS\_CODEPAGE\_862 is not set
- # CONFIG NLS CODEPAGE 863 is not set
- # CONFIG\_NLS\_CODEPAGE\_864 is not set
- # CONFIG\_NLS\_CODEPAGE\_865 is not set
- # CONFIG\_NLS\_CODEPAGE\_866 is not set
- # CONFIG\_NLS\_CODEPAGE\_869 is not set
- # CONFIG\_NLS\_CODEPAGE\_936 is not set
- # CONFIG\_NLS\_CODEPAGE\_950 is not set
- # CONFIG NLS CODEPAGE 932 is not set
- # CONFIG\_NLS\_CODEPAGE\_949 is not set
- # CONFIG\_NLS\_CODEPAGE\_874 is not set
- # CONFIG\_NLS\_ISO8859\_8 is not set
- # CONFIG\_NLS\_CODEPAGE\_1250 is not set
- # CONFIG\_NLS\_CODEPAGE\_1251 is not set

```
CONFIG_NLS_ASCII=m
# CONFIG_NLS_ISO8859_1 is not set
# CONFIG_NLS_ISO8859_2 is not set
# CONFIG_NLS_ISO8859_3 is not set
# CONFIG_NLS_ISO8859_4 is not set
# CONFIG_NLS_ISO8859_5 is not set
# CONFIG NLS ISO8859 6 is not set
# CONFIG_NLS_ISO8859_7 is not set
# CONFIG_NLS_ISO8859_9 is not set
# CONFIG NLS ISO8859 13 is not set
# CONFIG_NLS_ISO8859_14 is not set
# CONFIG_NLS_ISO8859_15 is not set
# CONFIG_NLS_KOI8_R is not set
# CONFIG NLS KOI8 U is not set
# CONFIG_NLS_MAC_ROMAN is not set
# CONFIG_NLS_MAC_CELTIC is not set
# CONFIG NLS MAC CENTEURO is not set
# CONFIG_NLS_MAC_CROATIAN is not set
# CONFIG_NLS_MAC_CYRILLIC is not set
# CONFIG_NLS_MAC_GAELIC is not set
# CONFIG_NLS_MAC_GREEK is not set
# CONFIG_NLS_MAC_ICELAND is not set
# CONFIG_NLS_MAC_INUIT is not set
# CONFIG NLS MAC ROMANIAN is not set
# CONFIG_NLS_MAC_TURKISH is not set
# CONFIG_NLS_UTF8 is not set
```

```
#
```

# # printk and dmesg options # # CONFIG\_PRINTK\_TIME is not set CONFIG\_CONSOLE\_LOGLEVEL\_DEFAULT=7 CONFIG\_MESSAGE\_LOGLEVEL\_DEFAULT=4 # CONFIG\_BOOT\_PRINTK\_DELAY is not set # CONFIG DYNAMIC DEBUG is not set # # Compile-time checks and compiler options # CONFIG\_DEBUG\_INFO=y # CONFIG\_DEBUG\_INFO\_REDUCED is not set # CONFIG\_DEBUG\_INFO\_SPLIT is not set # CONFIG\_DEBUG\_INFO\_DWARF4 is not set # CONFIG\_GDB\_SCRIPTS is not set CONFIG\_ENABLE\_WARN\_DEPRECATED=y CONFIG\_ENABLE\_MUST\_CHECK=y CONFIG\_FRAME\_WARN=1024 # CONFIG\_STRIP\_ASM\_SYMS is not set # CONFIG READABLE ASM is not set # CONFIG\_UNUSED\_SYMBOLS is not set # CONFIG\_PAGE\_OWNER is not set CONFIG\_DEBUG\_FS=y # CONFIG\_HEADERS\_CHECK is not set # CONFIG\_DEBUG\_SECTION\_MISMATCH is not set

```
CONFIG_SECTION_MISMATCH_WARN_ONLY=y
# CONFIG_DEBUG_FORCE_WEAK_PER_CPU is not set
CONFIG_MAGIC_SYSRQ=y
CONFIG_MAGIC_SYSRQ_DEFAULT_ENABLE=0x1
CONFIG_MAGIC_SYSRQ_SERIAL=y
CONFIG_DEBUG_KERNEL=y
#
# Memory Debugging
#
# CONFIG_PAGE_EXTENSION is not set
# CONFIG_DEBUG_PAGEALLOC is not set
# CONFIG_PAGE_POISONING is not set
# CONFIG_DEBUG_RODATA_TEST is not set
# CONFIG_DEBUG_OBJECTS is not set
# CONFIG_SLUB_DEBUG_ON is not set
# CONFIG_SLUB_STATS is not set
CONFIG_HAVE_DEBUG_KMEMLEAK=y
# CONFIG_DEBUG_KMEMLEAK is not set
# CONFIG_DEBUG_STACK_USAGE is not set
# CONFIG_DEBUG_VM is not set
CONFIG_ARCH_HAS_DEBUG_VIRTUAL=y
# CONFIG_DEBUG_VIRTUAL is not set
CONFIG_DEBUG_MEMORY_INIT=y
# CONFIG_DEBUG_PER_CPU_MAPS is not set
# CONFIG_DEBUG_SHIRQ is not set
#
```

# Debug Lockups and Hangs

```
# CONFIG_LOCKUP_DETECTOR is not set
# CONFIG_DETECT_HUNG_TASK is not set
# CONFIG_WQ_WATCHDOG is not set
# CONFIG_PANIC_ON_OOPS is not set
CONFIG_PANIC_ON_OOPS_VALUE=0
CONFIG_PANIC_TIMEOUT=0
CONFIG_SCHED_DEBUG=y
# CONFIG_SCHED_INFO is not set
# CONFIG_SCHEDSTATS is not set
# CONFIG_SCHED_STACK_END_CHECK is not set
# CONFIG_DEBUG_TIMEKEEPING is not set
#
# Lock Debugging (spinlocks, mutexes, etc...)
# CONFIG_DEBUG_RT_MUTEXES is not set
CONFIG_DEBUG_SPINLOCK=y
# CONFIG_DEBUG_MUTEXES is not set
# CONFIG_DEBUG_WW_MUTEX_SLOWPATH is not set
# CONFIG_DEBUG_LOCK_ALLOC is not set
# CONFIG_PROVE_LOCKING is not set
# CONFIG_LOCK_STAT is not set
# CONFIG DEBUG ATOMIC SLEEP is not set
# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set
# CONFIG_LOCK_TORTURE_TEST is not set
# CONFIG_WW_MUTEX_SELFTEST is not set
# CONFIG_STACKTRACE is not set
# CONFIG_DEBUG_KOBJECT is not set
```

#

```
CONFIG_DEBUG_BUGVERBOSE=y
# CONFIG_DEBUG_LIST is not set
# CONFIG_DEBUG_PI_LIST is not set
# CONFIG DEBUG SG is not set
# CONFIG_DEBUG_NOTIFIERS is not set
# CONFIG_DEBUG_CREDENTIALS is not set
#
# RCU Debugging
#
# CONFIG_PROVE_RCU is not set
# CONFIG_SPARSE_RCU_POINTER is not set
# CONFIG_TORTURE_TEST is not set
# CONFIG_RCU_PERF_TEST is not set
# CONFIG_RCU_TORTURE_TEST is not set
CONFIG_RCU_CPU_STALL_TIMEOUT=21
CONFIG RCU TRACE=y
# CONFIG_RCU_EQS_DEBUG is not set
# CONFIG_DEBUG_WQ_FORCE_RR_CPU is not set
# CONFIG_DEBUG_BLOCK_EXT_DEVT is not set
# CONFIG_CPU_HOTPLUG_STATE_CONTROL is not set
# CONFIG_NOTIFIER_ERROR_INJECTION is not set
# CONFIG_FAULT_INJECTION is not set
# CONFIG LATENCYTOP is not set
CONFIG_HAVE_FUNCTION_TRACER=y
CONFIG_HAVE_FUNCTION_GRAPH_TRACER=y
CONFIG_HAVE_DYNAMIC_FTRACE=y
CONFIG_HAVE_FTRACE_MCOUNT_RECORD=y
CONFIG_HAVE_SYSCALL_TRACEPOINTS=y
```

```
CONFIG_HAVE_C_RECORDMCOUNT=y
CONFIG_TRACE_CLOCK=y
CONFIG_TRACING_SUPPORT=y
CONFIG_FTRACE=y
# CONFIG_FUNCTION_TRACER is not set
# CONFIG_IRQSOFF_TRACER is not set
# CONFIG SCHED TRACER is not set
# CONFIG_HWLAT_TRACER is not set
# CONFIG_ENABLE_DEFAULT_TRACERS is not set
# CONFIG FTRACE SYSCALLS is not set
# CONFIG_TRACER_SNAPSHOT is not set
CONFIG_BRANCH_PROFILE_NONE=y
# CONFIG_PROFILE_ANNOTATED_BRANCHES is not set
# CONFIG PROFILE ALL BRANCHES is not set
# CONFIG_STACK_TRACER is not set
# CONFIG_BLK_DEV_IO_TRACE is not set
# CONFIG PROBE EVENTS is not set
# CONFIG_TRACEPOINT_BENCHMARK is not set
CONFIG_TRACING_EVENTS_GPIO=y
#
# Runtime Testing
# CONFIG LKDTM is not set
# CONFIG_TEST_LIST_SORT is not set
# CONFIG_TEST_SORT is not set
# CONFIG_BACKTRACE_SELF_TEST is not set
# CONFIG_RBTREE_TEST is not set
# CONFIG_INTERVAL_TREE_TEST is not set
```

```
# CONFIG_PERCPU_TEST is not set
```

- # CONFIG\_ATOMIC64\_SELFTEST is not set
- # CONFIG\_TEST\_HEXDUMP is not set
- # CONFIG\_TEST\_STRING\_HELPERS is not set
- # CONFIG\_TEST\_KSTRTOX is not set
- # CONFIG\_TEST\_PRINTF is not set
- # CONFIG TEST BITMAP is not set
- # CONFIG\_TEST\_UUID is not set
- # CONFIG\_TEST\_RHASHTABLE is not set
- # CONFIG TEST HASH is not set
- # CONFIG\_DMA\_API\_DEBUG is not set
- # CONFIG\_TEST\_LKM is not set
- # CONFIG\_TEST\_USER\_COPY is not set
- # CONFIG TEST BPF is not set
- # CONFIG\_TEST\_FIRMWARE is not set
- # CONFIG\_TEST\_UDELAY is not set
- # CONFIG MEMTEST is not set
- # CONFIG\_TEST\_STATIC\_KEYS is not set
- # CONFIG\_BUG\_ON\_DATA\_CORRUPTION is not set
- # CONFIG\_SAMPLES is not set
- CONFIG\_HAVE\_ARCH\_KGDB=y
- # CONFIG KGDB is not set
- # CONFIG\_ARCH\_WANTS\_UBSAN\_NO\_NULL is not set
- # CONFIG UBSAN is not set
- CONFIG\_ARCH\_HAS\_DEVMEM\_IS\_ALLOWED=y
- # CONFIG\_STRICT\_DEVMEM is not set
- # CONFIG\_ARM\_PTDUMP is not set
- CONFIG\_ARM\_UNWIND=y
- # CONFIG\_DEBUG\_USER is not set

```
CONFIG_DEBUG_LL=y
# CONFIG_DEBUG_SHIKHARA is not set
# CONFIG_DEBUG_ICEDCC is not set
# CONFIG_DEBUG_SEMIHOSTING is not set
# CONFIG_DEBUG_LL_UART_8250 is not set
CONFIG_DEBUG_LL_UART_PL01X=y
CONFIG DEBUG LL INCLUDE="debug/pl01x.S"
# CONFIG_DEBUG_UART_8250 is not set
CONFIG_DEBUG_UART_PHYS=0xd457b000
CONFIG DEBUG UART VIRT=0xf457b000
CONFIG_DEBUG_UNCOMPRESS=y
CONFIG_UNCOMPRESS_INCLUDE="debug/uncompress.h"
CONFIG_EARLY_PRINTK=y
# CONFIG PID IN CONTEXTIDR is not set
# CONFIG_CORESIGHT is not set
#
# Security options
#
# CONFIG_KEYS is not set
# CONFIG_SECURITY_DMESG_RESTRICT is not set
# CONFIG_SECURITY is not set
# CONFIG_SECURITYFS is not set
CONFIG_HAVE_HARDENED_USERCOPY_ALLOCATOR=y
# CONFIG_HARDENED_USERCOPY is not set
# CONFIG_STATIC_USERMODEHELPER is not set
CONFIG_DEFAULT_SECURITY_DAC=y
CONFIG_DEFAULT_SECURITY=""
CONFIG_CRYPTO=y
```

# Crypto core or helper

#

CONFIG\_CRYPTO\_ALGAPI=y

CONFIG\_CRYPTO\_ALGAPI2=y

CONFIG\_CRYPTO\_AEAD=m

CONFIG\_CRYPTO\_AEAD2=y

CONFIG\_CRYPTO\_BLKCIPHER2=y

CONFIG\_CRYPTO\_HASH=y

CONFIG\_CRYPTO\_HASH2=y

CONFIG\_CRYPTO\_RNG=m

CONFIG\_CRYPTO\_RNG2=y

CONFIG\_CRYPTO\_RNG\_DEFAULT=m

CONFIG\_CRYPTO\_AKCIPHER2=y

CONFIG\_CRYPTO\_KPP2=y

CONFIG\_CRYPTO\_ACOMP2=y

# CONFIG\_CRYPTO\_RSA is not set

# CONFIG\_CRYPTO\_DH is not set

# CONFIG\_CRYPTO\_ECDH is not set

CONFIG\_CRYPTO\_MANAGER=m

CONFIG\_CRYPTO\_MANAGER2=y

# CONFIG\_CRYPTO\_USER is not set

CONFIG\_CRYPTO\_MANAGER\_DISABLE\_TESTS=y

# CONFIG\_CRYPTO\_GF128MUL is not set

CONFIG\_CRYPTO\_NULL=m

CONFIG\_CRYPTO\_NULL2=y

# CONFIG\_CRYPTO\_PCRYPT is not set

CONFIG\_CRYPTO\_WORKQUEUE=y

```
# CONFIG_CRYPTO_CRYPTD is not set
# CONFIG_CRYPTO_MCRYPTD is not set
# CONFIG_CRYPTO_AUTHENC is not set
# CONFIG_CRYPTO_TEST is not set
#
# Authenticated Encryption with Associated Data
#
# CONFIG_CRYPTO_CCM is not set
# CONFIG_CRYPTO_GCM is not set
# CONFIG_CRYPTO_CHACHA20POLY1305 is not set
# CONFIG_CRYPTO_SEQIV is not set
CONFIG_CRYPTO_ECHAINIV=m
#
# Block modes
#
# CONFIG_CRYPTO_CBC is not set
# CONFIG_CRYPTO_CTR is not set
# CONFIG_CRYPTO_CTS is not set
# CONFIG_CRYPTO_ECB is not set
# CONFIG_CRYPTO_LRW is not set
# CONFIG_CRYPTO_PCBC is not set
# CONFIG_CRYPTO_XTS is not set
# CONFIG_CRYPTO_KEYWRAP is not set
#
# Hash modes
#
```

```
# CONFIG_CRYPTO_CMAC is not set
CONFIG_CRYPTO_HMAC=m
# CONFIG_CRYPTO_XCBC is not set
# CONFIG_CRYPTO_VMAC is not set
#
# Digest
#
CONFIG_CRYPTO_CRC32C=y
# CONFIG_CRYPTO_CRC32 is not set
# CONFIG_CRYPTO_CRCT10DIF is not set
# CONFIG_CRYPTO_GHASH is not set
# CONFIG_CRYPTO_POLY1305 is not set
# CONFIG_CRYPTO_MD4 is not set
# CONFIG_CRYPTO_MD5 is not set
# CONFIG_CRYPTO_MICHAEL_MIC is not set
# CONFIG_CRYPTO_RMD128 is not set
# CONFIG_CRYPTO_RMD160 is not set
# CONFIG_CRYPTO_RMD256 is not set
# CONFIG_CRYPTO_RMD320 is not set
# CONFIG_CRYPTO_SHA1 is not set
CONFIG_CRYPTO_SHA256=m
# CONFIG_CRYPTO_SHA512 is not set
# CONFIG_CRYPTO_SHA3 is not set
# CONFIG_CRYPTO_TGR192 is not set
# CONFIG_CRYPTO_WP512 is not set
#
```

# Ciphers

```
#
CONFIG_CRYPTO_AES=y
# CONFIG_CRYPTO_AES_TI is not set
# CONFIG_CRYPTO_ANUBIS is not set
# CONFIG_CRYPTO_ARC4 is not set
# CONFIG_CRYPTO_BLOWFISH is not set
# CONFIG_CRYPTO_CAMELLIA is not set
# CONFIG_CRYPTO_CAST5 is not set
# CONFIG_CRYPTO_CAST6 is not set
# CONFIG_CRYPTO_DES is not set
# CONFIG_CRYPTO_FCRYPT is not set
# CONFIG_CRYPTO_KHAZAD is not set
# CONFIG_CRYPTO_SALSA20 is not set
# CONFIG_CRYPTO_CHACHA20 is not set
# CONFIG_CRYPTO_SEED is not set
# CONFIG_CRYPTO_SERPENT is not set
# CONFIG_CRYPTO_TEA is not set
# CONFIG_CRYPTO_TWOFISH is not set
#
# Compression
#
# CONFIG_CRYPTO_DEFLATE is not set
# CONFIG CRYPTO LZO is not set
```

# CONFIG\_CRYPTO\_842 is not set

# CONFIG\_CRYPTO\_LZ4 is not set

# CONFIG\_CRYPTO\_LZ4HC is not set

```
# Random Number Generation
#
# CONFIG_CRYPTO_ANSI_CPRNG is not set
CONFIG_CRYPTO_DRBG_MENU=m
CONFIG_CRYPTO_DRBG_HMAC=y
# CONFIG_CRYPTO_DRBG_HASH is not set
CONFIG CRYPTO DRBG=m
CONFIG_CRYPTO_JITTERENTROPY=m
# CONFIG_CRYPTO_USER_API_HASH is not set
# CONFIG CRYPTO USER API SKCIPHER is not set
# CONFIG_CRYPTO_USER_API_RNG is not set
# CONFIG_CRYPTO_USER_API_AEAD is not set
CONFIG_CRYPTO_HW=y
# CONFIG_CRYPTO_DEV_FSL_CAAM_CRYPTO_API_DESC is not set
#
# Certificates for signature checking
#
# CONFIG_ARM_CRYPTO is not set
# CONFIG_BINARY_PRINTF is not set
#
# Library routines
CONFIG_BITREVERSE=y
CONFIG_HAVE_ARCH_BITREVERSE=y
CONFIG_RATIONAL=y
CONFIG_GENERIC_STRNCPY_FROM_USER=y
CONFIG_GENERIC_STRNLEN_USER=y
```

CONFIG\_GENERIC\_NET\_UTILS=y

CONFIG\_GENERIC\_PCI\_IOMAP=y

CONFIG\_GENERIC\_IO=y

CONFIG\_ARCH\_USE\_CMPXCHG\_LOCKREF=y

# CONFIG\_CRC\_CCITT is not set

CONFIG\_CRC16=y

# CONFIG CRC T10DIF is not set

# CONFIG\_CRC\_ITU\_T is not set

CONFIG\_CRC32=y

# CONFIG\_CRC32\_SELFTEST is not set

CONFIG\_CRC32\_SLICEBY8=y

# CONFIG\_CRC32\_SLICEBY4 is not set

# CONFIG\_CRC32\_SARWATE is not set

# CONFIG\_CRC32\_BIT is not set

# CONFIG\_CRC7 is not set

# CONFIG\_LIBCRC32C is not set

# CONFIG\_CRC8 is not set

# CONFIG\_AUDIT\_ARCH\_COMPAT\_GENERIC is not set

# CONFIG\_RANDOM32\_SELFTEST is not set

CONFIG\_ZLIB\_INFLATE=y

CONFIG\_ZLIB\_DEFLATE=y

CONFIG\_LZO\_COMPRESS=y

CONFIG\_LZO\_DECOMPRESS=y

CONFIG\_LZ4\_DECOMPRESS=y

CONFIG\_XZ\_DEC=y

CONFIG\_XZ\_DEC\_X86=y

CONFIG\_XZ\_DEC\_POWERPC=y

CONFIG\_XZ\_DEC\_IA64=y

CONFIG\_XZ\_DEC\_ARM=y

CONFIG\_XZ\_DEC\_ARMTHUMB=y

CONFIG\_XZ\_DEC\_SPARC=y

CONFIG\_XZ\_DEC\_BCJ=y

# CONFIG\_XZ\_DEC\_TEST is not set

CONFIG\_DECOMPRESS\_GZIP=y

CONFIG\_DECOMPRESS\_BZIP2=y

CONFIG\_DECOMPRESS\_LZMA=y

CONFIG\_DECOMPRESS\_XZ=y

CONFIG\_DECOMPRESS\_LZO=y

CONFIG\_DECOMPRESS\_LZ4=y

CONFIG\_GENERIC\_ALLOCATOR=y

CONFIG\_HAS\_IOMEM=y

CONFIG\_HAS\_IOPORT\_MAP=y

CONFIG\_HAS\_DMA=y

# CONFIG\_DMA\_NOOP\_OPS is not set

# CONFIG\_DMA\_VIRT\_OPS is not set

CONFIG\_CPU\_RMAP=y

CONFIG\_DQL=y

CONFIG\_NLATTR=y

# CONFIG\_CORDIC is not set

# CONFIG\_DDR is not set

# CONFIG\_IRQ\_POLL is not set

CONFIG\_LIBFDT=y

# CONFIG SG SPLIT is not set

CONFIG\_SG\_POOL=y

CONFIG\_ARCH\_HAS\_SG\_CHAIN=y

CONFIG\_SBITMAP=y

# CONFIG\_VIRTUALIZATION is not set

## Step 8: building

gcc version 4.7.3 (Ubuntu/Linaro 4.7.3-12ubuntu1)

## make ARCH=arm CROSS\_COMPILE=arm-linux-gnueabi- shikhara\_defconfig make ARCH=arm CROSS\_COMPILE=arm-linux-gnueabi- vmlinux

AR lib/lib.a

EXPORTS lib/lib-ksyms.o

LD lib/built-in.o

LD virt/lib/built-in.o

LD virt/built-in.o

GEN .version

CHK include/generated/compile.h

UPD include/generated/compile.h

CC init/version.o

LD init/built-in.o

LD vmlinux.o

MODPOST vmlinux.o

KSYM .tmp\_kallsyms1.o

KSYM .tmp\_kallsyms2.o

LD vmlinux

SORTEX vmlinux

SYSMAP System.map

## make ARCH=arm CROSS\_COMPILE=arm-linux-gnueabi- dtbs

make ARCH=arm CROSS\_COMPILE=arm-linux-gnueabi- dtbs

CHK include/config/kernel.release

CHK include/generated/uapi/linux/version.h

CHK include/generated/utsrelease.h

CHK include/generated/bounds.h

 $CHK \quad include/generated/timeconst.h$ 

CHK include/generated/asm-offsets.h

CALL scripts/checksyscalls.sh

CHK scripts/mod/devicetable-offsets.h DTC arch/arm/boot/dts/shikhara.dtb