Initial commit
This commit is contained in:
@@ -0,0 +1,11 @@
|
||||
# We have a conf and classes directory, add to BBPATH
|
||||
BBPATH .= ":${LAYERDIR}"
|
||||
|
||||
# We have recipes-* directories, add to BBFILES
|
||||
BBFILES += "${LAYERDIR}/recipes-*/*/*.bb \
|
||||
${LAYERDIR}/recipes-*/*/*.bbappend"
|
||||
|
||||
BBFILE_COLLECTIONS += "yosemitev2-layer"
|
||||
BBFILE_PATTERN_yosemitev2-layer := "^${LAYERDIR}/"
|
||||
|
||||
LAYERSERIES_COMPAT_yosemitev2-layer := "langdale mickledore"
|
||||
@@ -0,0 +1,19 @@
|
||||
KMACHINE = "aspeed"
|
||||
KERNEL_DEVICETREE = "${KMACHINE}-bmc-facebook-${MACHINE}.dtb"
|
||||
|
||||
PREFERRED_PROVIDER_virtual/bootloader = "u-boot-aspeed-sdk"
|
||||
PREFERRED_PROVIDER_u-boot = "u-boot-aspeed-sdk"
|
||||
PREFERRED_PROVIDER_u-boot-fw-utils = "u-boot-fw-utils-aspeed-sdk"
|
||||
|
||||
UBOOT_DEVICETREE = "ast2500-evb"
|
||||
UBOOT_MACHINE = "evb-ast2500_defconfig"
|
||||
|
||||
OBMC_COMPATIBLE_NAMES = "com.meta.Hardware.BMC.Model.YosemiteV2"
|
||||
|
||||
require conf/distro/include/phosphor-static-norootfs.inc
|
||||
require conf/machine/include/facebook-compute-multihost.inc
|
||||
require conf/machine/include/ast2500.inc
|
||||
require conf/machine/include/obmc-bsp-common.inc
|
||||
|
||||
FLASH_SIZE = "32768"
|
||||
OBMC_HOST_INSTANCES = "1 2 3 4"
|
||||
@@ -0,0 +1,18 @@
|
||||
# LAYER_CONF_VERSION is increased each time build/conf/bblayers.conf
|
||||
# changes incompatibly
|
||||
LCONF_VERSION = "8"
|
||||
|
||||
BBPATH = "${TOPDIR}"
|
||||
BBFILES ?= ""
|
||||
|
||||
BBLAYERS ?= " \
|
||||
##OEROOT##/meta \
|
||||
##OEROOT##/meta-poky \
|
||||
##OEROOT##/meta-openembedded/meta-oe \
|
||||
##OEROOT##/meta-openembedded/meta-networking \
|
||||
##OEROOT##/meta-openembedded/meta-python \
|
||||
##OEROOT##/meta-phosphor \
|
||||
##OEROOT##/meta-aspeed \
|
||||
##OEROOT##/meta-facebook \
|
||||
##OEROOT##/meta-facebook/meta-yosemitev2 \
|
||||
"
|
||||
@@ -0,0 +1,2 @@
|
||||
Common targets are:
|
||||
obmc-phosphor-image
|
||||
@@ -0,0 +1,258 @@
|
||||
#
|
||||
# This file is your local configuration file and is where all local user settings
|
||||
# are placed. The comments in this file give some guide to the options a new user
|
||||
# to the system might want to change but pretty much any configuration option can
|
||||
# be set in this file. More adventurous users can look at local.conf.extended
|
||||
# which contains other examples of configuration which can be placed in this file
|
||||
# but new users likely won't need any of them initially.
|
||||
#
|
||||
# Lines starting with the '#' character are commented out and in some cases the
|
||||
# default values are provided as comments to show people example syntax. Enabling
|
||||
# the option is a question of removing the # character and making any change to the
|
||||
# variable as required.
|
||||
|
||||
#
|
||||
# Machine Selection
|
||||
#
|
||||
MACHINE ??= "yosemitev2"
|
||||
|
||||
#
|
||||
# Where to place downloads
|
||||
#
|
||||
# During a first build the system will download many different source code tarballs
|
||||
# from various upstream projects. This can take a while, particularly if your network
|
||||
# connection is slow. These are all stored in DL_DIR. When wiping and rebuilding you
|
||||
# can preserve this directory to speed up this part of subsequent builds. This directory
|
||||
# is safe to share between multiple builds on the same machine too.
|
||||
#
|
||||
# The default is a downloads directory under TOPDIR which is the build directory.
|
||||
#
|
||||
#DL_DIR ?= "${TOPDIR}/downloads"
|
||||
|
||||
#
|
||||
# Where to place shared-state files
|
||||
#
|
||||
# BitBake has the capability to accelerate builds based on previously built output.
|
||||
# This is done using "shared state" files which can be thought of as cache objects
|
||||
# and this option determines where those files are placed.
|
||||
#
|
||||
# You can wipe out TMPDIR leaving this directory intact and the build would regenerate
|
||||
# from these files if no changes were made to the configuration. If changes were made
|
||||
# to the configuration, only shared state files where the state was still valid would
|
||||
# be used (done using checksums).
|
||||
#
|
||||
# The default is a sstate-cache directory under TOPDIR.
|
||||
#
|
||||
#SSTATE_DIR ?= "${TOPDIR}/sstate-cache"
|
||||
|
||||
#
|
||||
# Where to place the build output
|
||||
#
|
||||
# This option specifies where the bulk of the building work should be done and
|
||||
# where BitBake should place its temporary files and output. Keep in mind that
|
||||
# this includes the extraction and compilation of many applications and the toolchain
|
||||
# which can use Gigabytes of hard disk space.
|
||||
#
|
||||
# The default is a tmp directory under TOPDIR.
|
||||
#
|
||||
#TMPDIR = "${TOPDIR}/tmp"
|
||||
|
||||
#
|
||||
# Default policy config
|
||||
#
|
||||
# The distribution setting controls which policy settings are used as defaults.
|
||||
# The default value is fine for general Yocto project use, at least initially.
|
||||
# Ultimately when creating custom policy, people will likely end up subclassing
|
||||
# these defaults.
|
||||
#
|
||||
DISTRO ?= "openbmc-phosphor"
|
||||
# As an example of a subclass there is a "bleeding" edge policy configuration
|
||||
# where many versions are set to the absolute latest code from the upstream
|
||||
# source control systems. This is just mentioned here as an example, its not
|
||||
# useful to most new users.
|
||||
# DISTRO ?= "poky-bleeding"
|
||||
|
||||
#
|
||||
# Package Management configuration
|
||||
#
|
||||
# This variable lists which packaging formats to enable. Multiple package backends
|
||||
# can be enabled at once and the first item listed in the variable will be used
|
||||
# to generate the root filesystems.
|
||||
# Options are:
|
||||
# - 'package_deb' for debian style deb files
|
||||
# - 'package_ipk' for ipk files are used by opkg (a debian style embedded package manager)
|
||||
# - 'package_rpm' for rpm style packages
|
||||
# E.g.: PACKAGE_CLASSES ?= "package_rpm package_deb package_ipk"
|
||||
# We default to ipk:
|
||||
PACKAGE_CLASSES ?= "package_ipk"
|
||||
|
||||
#
|
||||
# SDK target architecture
|
||||
#
|
||||
# This variable specifies the architecture to build SDK items for and means
|
||||
# you can build the SDK packages for architectures other than the machine you are
|
||||
# running the build on (i.e. building i686 packages on an x86_64 host).
|
||||
# Supported values are i686, x86_64, aarch64
|
||||
#SDKMACHINE ?= "i686"
|
||||
|
||||
SANITY_TESTED_DISTROS:append ?= " *"
|
||||
|
||||
#
|
||||
# Extra image configuration defaults
|
||||
#
|
||||
# The EXTRA_IMAGE_FEATURES variable allows extra packages to be added to the generated
|
||||
# images. Some of these options are added to certain image types automatically. The
|
||||
# variable can contain the following options:
|
||||
# "dbg-pkgs" - add -dbg packages for all installed packages
|
||||
# (adds symbol information for debugging/profiling)
|
||||
# "src-pkgs" - add -src packages for all installed packages
|
||||
# (adds source code for debugging)
|
||||
# "dev-pkgs" - add -dev packages for all installed packages
|
||||
# (useful if you want to develop against libs in the image)
|
||||
# "ptest-pkgs" - add -ptest packages for all ptest-enabled packages
|
||||
# (useful if you want to run the package test suites)
|
||||
# "tools-sdk" - add development tools (gcc, make, pkgconfig etc.)
|
||||
# "tools-debug" - add debugging tools (gdb, strace)
|
||||
# "eclipse-debug" - add Eclipse remote debugging support
|
||||
# "tools-profile" - add profiling tools (oprofile, lttng, valgrind)
|
||||
# "tools-testapps" - add useful testing tools (ts_print, aplay, arecord etc.)
|
||||
# "debug-tweaks" - make an image suitable for development
|
||||
# e.g. ssh root access has a blank password
|
||||
# There are other application targets that can be used here too, see
|
||||
# meta/classes/image.bbclass and meta/classes/core-image.bbclass for more details.
|
||||
# We default to enabling the debugging tweaks.
|
||||
EXTRA_IMAGE_FEATURES ?= "debug-tweaks"
|
||||
|
||||
#
|
||||
# Additional image features
|
||||
#
|
||||
# The following is a list of additional classes to use when building images which
|
||||
# enable extra features. Some available options which can be included in this variable
|
||||
# are:
|
||||
# - 'buildstats' collect build statistics
|
||||
USER_CLASSES ?= "buildstats"
|
||||
|
||||
#
|
||||
# Runtime testing of images
|
||||
#
|
||||
# The build system can test booting virtual machine images under qemu (an emulator)
|
||||
# after any root filesystems are created and run tests against those images. It can also
|
||||
# run tests against any SDK that are built. To enable this uncomment these lines.
|
||||
# See classes/test{image,sdk}.bbclass for further details.
|
||||
#IMAGE_CLASSES += "testimage testsdk"
|
||||
#TESTIMAGE_AUTO_qemuall = "1"
|
||||
|
||||
#
|
||||
# Interactive shell configuration
|
||||
#
|
||||
# Under certain circumstances the system may need input from you and to do this it
|
||||
# can launch an interactive shell. It needs to do this since the build is
|
||||
# multithreaded and needs to be able to handle the case where more than one parallel
|
||||
# process may require the user's attention. The default is iterate over the available
|
||||
# terminal types to find one that works.
|
||||
#
|
||||
# Examples of the occasions this may happen are when resolving patches which cannot
|
||||
# be applied, to use the devshell or the kernel menuconfig
|
||||
#
|
||||
# Supported values are auto, gnome, xfce, rxvt, screen, konsole (KDE 3.x only), none
|
||||
# Note: currently, Konsole support only works for KDE 3.x due to the way
|
||||
# newer Konsole versions behave
|
||||
#OE_TERMINAL = "auto"
|
||||
# By default disable interactive patch resolution (tasks will just fail instead):
|
||||
PATCHRESOLVE = "noop"
|
||||
|
||||
#
|
||||
# Disk Space Monitoring during the build
|
||||
#
|
||||
# Monitor the disk space during the build. If there is less that 1GB of space or less
|
||||
# than 100K inodes in any key build location (TMPDIR, DL_DIR, SSTATE_DIR), gracefully
|
||||
# shutdown the build. If there is less than 100MB or 1K inodes, perform a hard abort
|
||||
# of the build. The reason for this is that running completely out of space can corrupt
|
||||
# files and damages the build in ways which may not be easily recoverable.
|
||||
# It's necessary to monitor /tmp, if there is no space left the build will fail
|
||||
# with very exotic errors.
|
||||
BB_DISKMON_DIRS ??= "\
|
||||
STOPTASKS,${TMPDIR},1G,100K \
|
||||
STOPTASKS,${DL_DIR},1G,100K \
|
||||
STOPTASKS,${SSTATE_DIR},1G,100K \
|
||||
STOPTASKS,/tmp,100M,100K \
|
||||
HALT,${TMPDIR},100M,1K \
|
||||
HALT,${DL_DIR},100M,1K \
|
||||
HALT,${SSTATE_DIR},100M,1K \
|
||||
HALT,/tmp,10M,1K"
|
||||
|
||||
#
|
||||
# Shared-state files from other locations
|
||||
#
|
||||
# As mentioned above, shared state files are prebuilt cache data objects which can be
|
||||
# used to accelerate build time. This variable can be used to configure the system
|
||||
# to search other mirror locations for these objects before it builds the data itself.
|
||||
#
|
||||
# This can be a filesystem directory, or a remote url such as http or ftp. These
|
||||
# would contain the sstate-cache results from previous builds (possibly from other
|
||||
# machines). This variable works like fetcher MIRRORS/PREMIRRORS and points to the
|
||||
# cache locations to check for the shared objects.
|
||||
# NOTE: if the mirror uses the same structure as SSTATE_DIR, you need to add PATH
|
||||
# at the end as shown in the examples below. This will be substituted with the
|
||||
# correct path within the directory structure.
|
||||
#SSTATE_MIRRORS ?= "\
|
||||
#file://.* http://someserver.tld/share/sstate/PATH;downloadfilename=PATH \n \
|
||||
#file://.* file:///some/local/dir/sstate/PATH"
|
||||
|
||||
#
|
||||
# Yocto Project SState Mirror
|
||||
#
|
||||
# The Yocto Project has prebuilt artefacts available for its releases, you can enable
|
||||
# use of these by uncommenting the following line. This will mean the build uses
|
||||
# the network to check for artefacts at the start of builds, which does slow it down
|
||||
# equally, it will also speed up the builds by not having to build things if they are
|
||||
# present in the cache. It assumes you can download something faster than you can build it
|
||||
# which will depend on your network.
|
||||
#
|
||||
#SSTATE_MIRRORS ?= "file://.* http://sstate.yoctoproject.org/2.5/PATH;downloadfilename=PATH"
|
||||
|
||||
#
|
||||
# Qemu configuration
|
||||
#
|
||||
# By default native qemu will build with a builtin VNC server where graphical output can be
|
||||
# seen. The line below enables the SDL UI frontend too.
|
||||
PACKAGECONFIG:append:pn-qemu-system-native = " sdl"
|
||||
# By default libsdl2-native will be built, if you want to use your host's libSDL instead of
|
||||
# the minimal libsdl built by libsdl2-native then uncomment the ASSUME_PROVIDED line below.
|
||||
#ASSUME_PROVIDED += "libsdl2-native"
|
||||
|
||||
# You can also enable the Gtk UI frontend, which takes somewhat longer to build, but adds
|
||||
# a handy set of menus for controlling the emulator.
|
||||
#PACKAGECONFIG:append:pn-qemu-system-native = " gtk+"
|
||||
|
||||
#
|
||||
# Hash Equivalence
|
||||
#
|
||||
# Enable support for automatically running a local hash equivalence server and
|
||||
# instruct bitbake to use a hash equivalence aware signature generator. Hash
|
||||
# equivalence improves reuse of sstate by detecting when a given sstate
|
||||
# artifact can be reused as equivalent, even if the current task hash doesn't
|
||||
# match the one that generated the artifact.
|
||||
#
|
||||
# A shared hash equivalent server can be set with "<HOSTNAME>:<PORT>" format
|
||||
#
|
||||
#BB_HASHSERVE = "auto"
|
||||
#BB_SIGNATURE_HANDLER = "OEEquivHash"
|
||||
|
||||
#
|
||||
# Memory Resident Bitbake
|
||||
#
|
||||
# Bitbake's server component can stay in memory after the UI for the current command
|
||||
# has completed. This means subsequent commands can run faster since there is no need
|
||||
# for bitbake to reload cache files and so on. Number is in seconds, after which the
|
||||
# server will shut down.
|
||||
#
|
||||
#BB_SERVER_TIMEOUT = "60"
|
||||
|
||||
# CONF_VERSION is increased each time build/conf/ changes incompatibly and is used to
|
||||
# track the version of this file when it was generated. This can safely be ignored if
|
||||
# this doesn't mean anything to you.
|
||||
CONF_VERSION = "2"
|
||||
|
||||
# Set the root password to '0penBmc'
|
||||
# Defaults from meta-phosphor/conf/distro/include/phosphor-defaults.inc
|
||||
+235
@@ -0,0 +1,235 @@
|
||||
From 5a649c3dd0452eba0028c51546e2981e0b04de4f Mon Sep 17 00:00:00 2001
|
||||
From: Logananth Sundararaj <logananth_s@hcl.com>
|
||||
Date: Tue, 8 Mar 2022 19:18:27 +0530
|
||||
Subject: [PATCH] board-aspeed-Add-Mux-for-yosemitev2
|
||||
|
||||
Signed-off-by: Logananth Sundararaj <logananth_s@hcl.com>
|
||||
---
|
||||
arch/arm/mach-aspeed/ast2500/platform.S | 191 ++++++++++++++++++++----
|
||||
1 file changed, 162 insertions(+), 29 deletions(-)
|
||||
|
||||
diff --git a/arch/arm/mach-aspeed/ast2500/platform.S b/arch/arm/mach-aspeed/ast2500/platform.S
|
||||
index aef55c4a0a..137ed2c587 100644
|
||||
--- a/arch/arm/mach-aspeed/ast2500/platform.S
|
||||
+++ b/arch/arm/mach-aspeed/ast2500/platform.S
|
||||
@@ -302,6 +302,156 @@ TIME_TABLE_DDR4_1600:
|
||||
ldr r2, =0x00000800
|
||||
.endm
|
||||
|
||||
+ .macro console_bmc
|
||||
+ ldr r0, =0x1e780024
|
||||
+ ldr r1, [r0]
|
||||
+ orr r1, r1, #0xF
|
||||
+ str r1, [r0]
|
||||
+
|
||||
+ ldr r0, =0x1e780020
|
||||
+ ldr r1, [r0]
|
||||
+ and r1, r1, #0xFFFFFFF0
|
||||
+ orr r1, r1, #0xC
|
||||
+ str r1, [r0]
|
||||
+ .endm
|
||||
+
|
||||
+.macro console_sel
|
||||
+
|
||||
+ // Disable SoL UARTs[1-4]
|
||||
+ ldr r0, =0x1e6e2080
|
||||
+ ldr r1, [r0]
|
||||
+ ldr r2, =0xBFBFFFFF
|
||||
+ and r1, r1, r2
|
||||
+ str r1, [r0]
|
||||
+
|
||||
+ ldr r0, =0x1e6e2084
|
||||
+ ldr r1, [r0]
|
||||
+ and r1, r1, r2
|
||||
+ str r1, [r0]
|
||||
+ // Enable GPIOE[0-3] Tolerant
|
||||
+ ldr r0, =0x1e78003c
|
||||
+ ldr r1, [r0]
|
||||
+ orr r1, r1, #0xF
|
||||
+ str r1, [r0]
|
||||
+
|
||||
+ // Read debug card present
|
||||
+ ldr r2, =0x1e780080
|
||||
+ ldr r0, [r2]
|
||||
+ and r0, r0, #0x00000800
|
||||
+ ldr r1, =0x0800
|
||||
+ cmp r0, r1
|
||||
+ bne dbg_card_pres\@
|
||||
+ console_bmc
|
||||
+ b case_end\@
|
||||
+
|
||||
+dbg_card_pres\@:
|
||||
+ // Read key position
|
||||
+ ldr r2, =0x1e7801e0
|
||||
+ ldr r0, [r2]
|
||||
+ bic r1, r0, #0xFF0FFFFF
|
||||
+ mov r0, r1, lsr #20
|
||||
+ //Test for position#1
|
||||
+ ldr r1, =0x00
|
||||
+ cmp r0, r1
|
||||
+ bne case_pos2\@
|
||||
+ console_bmc
|
||||
+ b case_end\@
|
||||
+case_pos2\@:
|
||||
+ //Test for position#2
|
||||
+ ldr r1, =0x01
|
||||
+ cmp r0, r1
|
||||
+ bne case_pos3\@
|
||||
+ console_bmc
|
||||
+ b case_end\@
|
||||
+case_pos3\@:
|
||||
+ //Test for position#3
|
||||
+ ldr r1, =0x02
|
||||
+ cmp r0, r1
|
||||
+ bne case_pos4\@
|
||||
+ console_bmc
|
||||
+ b case_end\@
|
||||
+case_pos4\@:
|
||||
+//Test for position#4
|
||||
+ ldr r1, =0x03
|
||||
+ cmp r0, r1
|
||||
+ bne case_pos5\@
|
||||
+ console_bmc
|
||||
+ b case_end\@
|
||||
+case_pos5\@:
|
||||
+ //Test for position#5
|
||||
+ ldr r1, =0x04
|
||||
+ cmp r0, r1
|
||||
+ bne case_pos6\@
|
||||
+ console_bmc
|
||||
+ b case_end\@
|
||||
+case_pos6\@:
|
||||
+ //Test for position#6
|
||||
+ ldr r1, =0x05
|
||||
+ cmp r0, r1
|
||||
+ bne case_pos7\@
|
||||
+ console_bmc
|
||||
+ b case_end\@
|
||||
+case_pos7\@:
|
||||
+ //Test for position#7
|
||||
+ ldr r1, =0x06
|
||||
+ cmp r0, r1
|
||||
+ bne case_pos8\@
|
||||
+ console_bmc
|
||||
+ b case_end\@
|
||||
+case_pos8\@:
|
||||
+ //Test for position#8
|
||||
+ ldr r1, =0x07
|
||||
+ cmp r0, r1
|
||||
+ bne case_pos9\@
|
||||
+ console_bmc
|
||||
+ b case_end\@
|
||||
+case_pos9\@:
|
||||
+ //Test for position#9
|
||||
+ ldr r1, =0x08
|
||||
+ cmp r0, r1
|
||||
+ bne case_pos10\@
|
||||
+ console_bmc
|
||||
+ b case_end\@
|
||||
+case_pos10\@:
|
||||
+ //Test for position#10
|
||||
+ ldr r1, =0x09
|
||||
+ cmp r0, r1
|
||||
+ bne case_end\@
|
||||
+ console_bmc
|
||||
+ b case_end\@
|
||||
+case_end\@:
|
||||
+.endm
|
||||
+
|
||||
+ .macro uart_console_setup
|
||||
+ console_sel
|
||||
+ /* setup UART console */
|
||||
+ ldr r0, =0x1E78400C
|
||||
+ mov r1, #0x83
|
||||
+ str r1, [r0]
|
||||
+
|
||||
+ ldr r0, =0x1e6e202c
|
||||
+ ldr r2, [r0]
|
||||
+ mov r2, r2, lsr #12
|
||||
+ tst r2, #0x01
|
||||
+ ldr r0, =0x1E784000
|
||||
+ moveq r1, #0x1A @ Baudrate 57600
|
||||
+ movne r1, #0x02 @ Baudrate 57600, div13
|
||||
+
|
||||
+ str r1, [r0]
|
||||
+
|
||||
+ ldr r0, =0x1E784004
|
||||
+ mov r1, #0x00
|
||||
+ str r1, [r0]
|
||||
+
|
||||
+ ldr r0, =0x1E78400C
|
||||
+ mov r1, #0x03
|
||||
+ str r1, [r0]
|
||||
+
|
||||
+ ldr r0, =0x1E784008
|
||||
+ mov r1, #0x07
|
||||
+ str r1, [r0]
|
||||
+ .endm
|
||||
+
|
||||
.macro print_hex_char
|
||||
and r1, r1, #0xF
|
||||
cmp r1, #9
|
||||
@@ -321,6 +471,16 @@ init_dram:
|
||||
/********************************************
|
||||
Initial Reset Procedure : Begin
|
||||
*******************************************/
|
||||
+ /* save into SRAM */
|
||||
+ ldr r0, =0x1e720200 /* vbs.uboot_exec_address */
|
||||
+ str r4, [r0]
|
||||
+
|
||||
+ uart_console_setup
|
||||
+
|
||||
+ ldr r0, =0x1E720204
|
||||
+ mov r1, #0x0
|
||||
+ str r1, [r0]
|
||||
+
|
||||
/* Clear AHB bus lock condition */
|
||||
ldr r0, =0x1e600000
|
||||
ldr r1, =0xAEED1A03
|
||||
@@ -794,6 +954,8 @@ wait_ddr_reset:
|
||||
clear_delay_timer
|
||||
/* end delay 10ms */
|
||||
|
||||
+ uart_console_setup
|
||||
+
|
||||
/* Debug - UART console message */
|
||||
#ifdef CONFIG_DRAM_UART_TO_UART1
|
||||
ldr r0, =0x1e78909c @ route UART5 to UART Port1, 2016.08.29
|
||||
@@ -807,35 +969,6 @@ wait_ddr_reset:
|
||||
str r1, [r0]
|
||||
#endif
|
||||
|
||||
- ldr r0, =0x1e78400c
|
||||
- mov r1, #0x83
|
||||
- str r1, [r0]
|
||||
-
|
||||
- ldr r0, =0x1e6e202c
|
||||
- ldr r2, [r0]
|
||||
- mov r2, r2, lsr #12
|
||||
- tst r2, #0x01
|
||||
- ldr r0, =0x1e784000
|
||||
- moveq r1, #0x0D @ Baudrate 115200
|
||||
- movne r1, #0x01 @ Baudrate 115200, div13
|
||||
-#ifdef CONFIG_DRAM_UART_38400
|
||||
- moveq r1, #0x27 @ Baudrate 38400
|
||||
- movne r1, #0x03 @ Baudrate 38400 , div13
|
||||
-#endif
|
||||
- str r1, [r0]
|
||||
-
|
||||
- ldr r0, =0x1e784004
|
||||
- mov r1, #0x00
|
||||
- str r1, [r0]
|
||||
-
|
||||
- ldr r0, =0x1e78400c
|
||||
- mov r1, #0x03
|
||||
- str r1, [r0]
|
||||
-
|
||||
- ldr r0, =0x1e784008
|
||||
- mov r1, #0x07
|
||||
- str r1, [r0]
|
||||
-
|
||||
ldr r0, =0x1e784000
|
||||
mov r1, #0x0D @ '\r'
|
||||
str r1, [r0]
|
||||
--
|
||||
2.17.1
|
||||
+185
@@ -0,0 +1,185 @@
|
||||
From 1fb38f86a77ec6656f87f427124a65dc6c0fdf5f Mon Sep 17 00:00:00 2001
|
||||
From: Logananth Sundararaj <logananth_s@hcl.com>
|
||||
Date: Tue, 8 Mar 2022 19:24:49 +0530
|
||||
Subject: [PATCH] spl-host-console-handle
|
||||
|
||||
This patch adds four 1S server console through debug card
|
||||
connected to YosemiteV2 during boot.
|
||||
|
||||
Handswitch in the adaptor card connected to AST2500 GPIOs as below,
|
||||
GPIOAA7 ---SW_ID8
|
||||
GPIOAA6 ---SW_ID4
|
||||
GPIOAA5 ---SW_ID2
|
||||
GPIOAA4 ---SW_ID1
|
||||
|
||||
SW_ID8 SW_ID4 SW_ID2 SW_ID1 Position Descritpion
|
||||
L L L L 1 1s server slot1 select
|
||||
|
||||
L L L H 2 1s server slot2 select
|
||||
|
||||
L L H L 3 1s server slot3 select
|
||||
|
||||
L L H H 4 1s server slot4 select
|
||||
|
||||
L H L L 5 BMC Debug port select
|
||||
|
||||
L H L H 6 1s server slot1 select
|
||||
|
||||
L H H L 7 1s server slot2 select
|
||||
|
||||
L H H H 8 1s server slot3 select
|
||||
|
||||
H L L L 9 1s server slot4 select
|
||||
|
||||
H L L H 10 BMC Debug port select
|
||||
|
||||
BMC and Hosts UART control flow
|
||||
GPIOE0 --- DEBUG_UART_SEL_0
|
||||
GPIOE1 --- DEBUG_UART_SEL_1
|
||||
GPIOE2 --- DEBUG_UART_SEL_2
|
||||
GPIOE2 --- DEBUG_UART_RX_SEL_N
|
||||
|
||||
SEL_2 SEL_1 SEL_0 RX_SEL_N CONSOLE
|
||||
0 0 0 0 SLOT1
|
||||
0 0 1 0 SLOT2
|
||||
0 1 0 0 SLOT3
|
||||
0 1 1 0 SLOT4
|
||||
1 0 0 1 BMC Debug
|
||||
|
||||
Signed-off-by: Logananth Sundararaj <logananth_s@hcl.com>
|
||||
---
|
||||
arch/arm/mach-aspeed/ast2500/platform.S | 69 ++++++++++++++++++++++---
|
||||
1 file changed, 61 insertions(+), 8 deletions(-)
|
||||
|
||||
diff --git a/arch/arm/mach-aspeed/ast2500/platform.S b/arch/arm/mach-aspeed/ast2500/platform.S
|
||||
index 137ed2c587..76a31c709a 100644
|
||||
--- a/arch/arm/mach-aspeed/ast2500/platform.S
|
||||
+++ b/arch/arm/mach-aspeed/ast2500/platform.S
|
||||
@@ -315,6 +315,59 @@ TIME_TABLE_DDR4_1600:
|
||||
str r1, [r0]
|
||||
.endm
|
||||
|
||||
+ .macro console_slot1
|
||||
+ ldr r0, =0x1e780024
|
||||
+ ldr r1, [r0]
|
||||
+ orr r1, r1, #0xF
|
||||
+ str r1, [r0]
|
||||
+
|
||||
+ ldr r0, =0x1e780020
|
||||
+ ldr r1, [r0]
|
||||
+ and r1, r1, #0xFFFFFFF0
|
||||
+ orr r1, r1, #0x0
|
||||
+ str r1, [r0]
|
||||
+ .endm
|
||||
+
|
||||
+ .macro console_slot2
|
||||
+ ldr r0, =0x1e780024
|
||||
+ ldr r1, [r0]
|
||||
+ orr r1, r1, #0xF
|
||||
+ str r1, [r0]
|
||||
+
|
||||
+ ldr r0, =0x1e780020
|
||||
+ ldr r1, [r0]
|
||||
+ and r1, r1, #0xFFFFFFF0
|
||||
+ orr r1, r1, #0x1
|
||||
+ str r1, [r0]
|
||||
+ .endm
|
||||
+
|
||||
+ .macro console_slot3
|
||||
+ ldr r0, =0x1e780024
|
||||
+ ldr r1, [r0]
|
||||
+ orr r1, r1, #0xF
|
||||
+ str r1, [r0]
|
||||
+
|
||||
+ ldr r0, =0x1e780020
|
||||
+ ldr r1, [r0]
|
||||
+ and r1, r1, #0xFFFFFFF0
|
||||
+ orr r1, r1, #0x2
|
||||
+ str r1, [r0]
|
||||
+ .endm
|
||||
+
|
||||
+ .macro console_slot4
|
||||
+ ldr r0, =0x1e780024
|
||||
+ ldr r1, [r0]
|
||||
+ orr r1, r1, #0xF
|
||||
+ str r1, [r0]
|
||||
+
|
||||
+ ldr r0, =0x1e780020
|
||||
+ ldr r1, [r0]
|
||||
+ and r1, r1, #0xFFFFFFF0
|
||||
+ orr r1, r1, #0x3
|
||||
+ str r1, [r0]
|
||||
+ .endm
|
||||
+
|
||||
+
|
||||
.macro console_sel
|
||||
|
||||
// Disable SoL UARTs[1-4]
|
||||
@@ -354,28 +407,28 @@ dbg_card_pres\@:
|
||||
ldr r1, =0x00
|
||||
cmp r0, r1
|
||||
bne case_pos2\@
|
||||
- console_bmc
|
||||
+ console_slot1
|
||||
b case_end\@
|
||||
case_pos2\@:
|
||||
//Test for position#2
|
||||
ldr r1, =0x01
|
||||
cmp r0, r1
|
||||
bne case_pos3\@
|
||||
- console_bmc
|
||||
+ console_slot2
|
||||
b case_end\@
|
||||
case_pos3\@:
|
||||
//Test for position#3
|
||||
ldr r1, =0x02
|
||||
cmp r0, r1
|
||||
bne case_pos4\@
|
||||
- console_bmc
|
||||
+ console_slot3
|
||||
b case_end\@
|
||||
case_pos4\@:
|
||||
//Test for position#4
|
||||
ldr r1, =0x03
|
||||
cmp r0, r1
|
||||
bne case_pos5\@
|
||||
- console_bmc
|
||||
+ console_slot4
|
||||
b case_end\@
|
||||
case_pos5\@:
|
||||
//Test for position#5
|
||||
@@ -389,28 +442,28 @@ case_pos6\@:
|
||||
ldr r1, =0x05
|
||||
cmp r0, r1
|
||||
bne case_pos7\@
|
||||
- console_bmc
|
||||
+ console_slot1
|
||||
b case_end\@
|
||||
case_pos7\@:
|
||||
//Test for position#7
|
||||
ldr r1, =0x06
|
||||
cmp r0, r1
|
||||
bne case_pos8\@
|
||||
- console_bmc
|
||||
+ console_slot2
|
||||
b case_end\@
|
||||
case_pos8\@:
|
||||
//Test for position#8
|
||||
ldr r1, =0x07
|
||||
cmp r0, r1
|
||||
bne case_pos9\@
|
||||
- console_bmc
|
||||
+ console_slot3
|
||||
b case_end\@
|
||||
case_pos9\@:
|
||||
//Test for position#9
|
||||
ldr r1, =0x08
|
||||
cmp r0, r1
|
||||
bne case_pos10\@
|
||||
- console_bmc
|
||||
+ console_slot4
|
||||
b case_end\@
|
||||
case_pos10\@:
|
||||
//Test for position#10
|
||||
--
|
||||
2.17.1
|
||||
@@ -0,0 +1,5 @@
|
||||
CONFIG_USE_BOOTARGS=y
|
||||
CONFIG_BOOTARGS="console=ttyS4,57600n8 root=/dev/ram rw"
|
||||
CONFIG_USE_BOOTCOMMAND=y
|
||||
CONFIG_BOOTCOMMAND="bootm 20080000"
|
||||
CONFIG_BAUDRATE=57600
|
||||
@@ -0,0 +1,4 @@
|
||||
FILESEXTRAPATHS:prepend := "${THISDIR}/${PN}:"
|
||||
SRC_URI +="file://0001-board-aspeed-Add-Mux-for-yosemitev2.patch"
|
||||
SRC_URI +="file://0002-spl-host-console-handle.patch"
|
||||
SRC_URI +="file://yosemitev2.cfg"
|
||||
@@ -0,0 +1,2 @@
|
||||
FILESEXTRAPATHS:prepend := "${THISDIR}/u-boot-aspeed-sdk:"
|
||||
SRC_URI += "file://yosemitev2.cfg"
|
||||
@@ -0,0 +1,3 @@
|
||||
CONFIG_NCSI_OEM_CMD_GET_MAC=y
|
||||
CONFIG_I2C_SLAVE=y
|
||||
CONFIG_IPMB_DEVICE_INTERFACE=y
|
||||
@@ -0,0 +1,2 @@
|
||||
FILESEXTRAPATHS:prepend := "${THISDIR}/linux-aspeed:"
|
||||
SRC_URI += "file://yosemitev2.cfg"
|
||||
@@ -0,0 +1,7 @@
|
||||
IPMB_CHANNELS:yosemitev2 = "\
|
||||
/dev/ipmb-1 \
|
||||
/dev/ipmb-3 \
|
||||
/dev/ipmb-5 \
|
||||
/dev/ipmb-7 \
|
||||
/dev/ipmb-13 \
|
||||
"
|
||||
+43
@@ -0,0 +1,43 @@
|
||||
[
|
||||
{
|
||||
"Desc": {
|
||||
"Name": "Virtual_CFM_Sensor",
|
||||
"SensorType": "airflow"
|
||||
},
|
||||
"Threshold": {
|
||||
"CriticalHigh": 40,
|
||||
"CriticalLow": 10,
|
||||
"WarningHigh": 30,
|
||||
"WarningLow": 15
|
||||
},
|
||||
"Params": {
|
||||
"ConstParam": [
|
||||
{
|
||||
"ParamName": "P1",
|
||||
"Value": 0.00565
|
||||
},
|
||||
{
|
||||
"ParamName": "P2",
|
||||
"Value": 3.7427
|
||||
}
|
||||
],
|
||||
"DbusParam": [
|
||||
{
|
||||
"ParamName": "P3",
|
||||
"Desc": {
|
||||
"Name": "SP_FAN0_TACH",
|
||||
"SensorType": "fan_tach"
|
||||
}
|
||||
},
|
||||
{
|
||||
"ParamName": "P4",
|
||||
"Desc": {
|
||||
"Name": "SP_FAN1_TACH",
|
||||
"SensorType": "fan_tach"
|
||||
}
|
||||
}
|
||||
]
|
||||
},
|
||||
"Expression": "(P3 * P1) + (P4 * P1) - P2"
|
||||
}
|
||||
]
|
||||
+1
@@ -0,0 +1 @@
|
||||
FILESEXTRAPATHS:prepend := "${THISDIR}/${PN}:"
|
||||
@@ -0,0 +1,3 @@
|
||||
recipes-kernel - The kernel and generic applications/libraries with strong kernel dependencies
|
||||
recipes-bsp - Aspeed BSP with uboot
|
||||
recipes-phosphor - Phosphor OpenBMC applications and configuration
|
||||
Reference in New Issue
Block a user