On Wed, Jan 23, 2013 at 9:51 PM, Sascha Hauer <s.hauer@xxxxxxxxxxxxxx> wrote: > On Sat, Jan 19, 2013 at 06:23:27PM +0100, Vicente Bergas wrote: >> Hi Sascha, >> I've made the changes you suggested in this resent patch. >> >> Everything related to custom ATAGs has been moved to the board >> directory. >> >> The generic code does not make any references to feature lists or >> bootloader versions. >> >> About the setup_feature_list prototype: >> it has been renamed to atag_appender >> it's not a function, it's a pointer to a function. Can it have a >> prototype other than it's own declaration? >> >> All non-related changes has been dropped. They were checkpatch.pl >> warnings unrelated to this patch. >> > > Applied, some days ago already. > > Sascha > Oh, Thanks! Vitente. >> Regards, >> Vicente. >> >> Signed-off-by: Vicente Bergas <vicencb@xxxxxxxxx> >> --- >> arch/arm/Kconfig | 7 + >> arch/arm/boards/archosg9/Makefile | 1 + >> arch/arm/boards/archosg9/archos_features.c | 225 ++++++++++++++++++ >> arch/arm/boards/archosg9/archos_features.h | 22 ++ >> arch/arm/boards/archosg9/board.c | 2 + >> arch/arm/boards/archosg9/feature_list.h | 352 +++++++++++++++++++++++++++++ >> arch/arm/configs/archosg9_defconfig | 1 + >> arch/arm/include/asm/armlinux.h | 9 + >> arch/arm/lib/armlinux.c | 12 + >> 9 files changed, 631 insertions(+) >> create mode 100644 arch/arm/boards/archosg9/archos_features.c >> create mode 100644 arch/arm/boards/archosg9/archos_features.h >> create mode 100644 arch/arm/boards/archosg9/feature_list.h >> >> diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig >> index f567531..6f7a71f 100644 >> --- a/arch/arm/Kconfig >> +++ b/arch/arm/Kconfig >> @@ -152,6 +152,13 @@ config THUMB2_BAREBOX >> your board lowlevel init code may break in thumb-2 mode. You have been >> warned. >> >> +config ARM_BOARD_APPEND_ATAG >> + bool "Let board specific code to add ATAGs to be passed to the kernel" >> + depends on ARM_LINUX >> + help >> + This option is purely to start some vendor provided kernels. >> + ** DO NOT USE FOR YOUR OWN DESIGNS! ** >> + >> endmenu >> >> menu "Arm specific settings" >> diff --git a/arch/arm/boards/archosg9/Makefile b/arch/arm/boards/archosg9/Makefile >> index 256eaf6..450c03f 100644 >> --- a/arch/arm/boards/archosg9/Makefile >> +++ b/arch/arm/boards/archosg9/Makefile >> @@ -1,3 +1,4 @@ >> obj-y += board.o >> +obj-$(CONFIG_ARM_BOARD_APPEND_ATAG) += archos_features.o >> obj-$(CONFIG_MACH_DO_LOWLEVEL_INIT) += lowlevel.o mux.o >> pbl-$(CONFIG_MACH_DO_LOWLEVEL_INIT) += lowlevel.o mux.o >> diff --git a/arch/arm/boards/archosg9/archos_features.c b/arch/arm/boards/archosg9/archos_features.c >> new file mode 100644 >> index 0000000..cd20984 >> --- /dev/null >> +++ b/arch/arm/boards/archosg9/archos_features.c >> @@ -0,0 +1,225 @@ >> +/* >> + * 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. >> + */ >> + >> +#include <boot.h> >> +#include <asm/setup.h> >> +#include "archos_features.h" >> +#include "feature_list.h" >> + >> +static inline void *atag_data(struct tag *t) >> +{ >> + return ((void *)t) + sizeof(struct tag_header); >> +} >> + >> +static struct feature_tag *features; >> + >> +static void setup_feature_core(void) >> +{ >> + features->hdr.tag = FTAG_CORE; >> + features->hdr.size = feature_tag_size(feature_tag_core); >> + >> + features->u.core.magic = FEATURE_LIST_MAGIC; >> + features->u.core.list_revision = FEATURE_LIST_REV; >> + features->u.core.flags = 0; >> + >> + features = feature_tag_next(features); >> +} >> +static void setup_feature_product_name(void) >> +{ >> + features->hdr.tag = FTAG_PRODUCT_NAME; >> + features->hdr.size = feature_tag_size(feature_tag_product_name); >> + >> + memset(features->u.product_name.name, 0, >> + sizeof(features->u.product_name.name)); >> + sprintf(features->u.product_name.name, "A80S"); >> + features->u.product_name.id = 0x13A8; >> + >> + features = feature_tag_next(features); >> +} >> +static void setup_feature_product_serial_number(void) >> +{ >> + features->hdr.tag = FTAG_PRODUCT_SERIAL_NUMBER; >> + features->hdr.size = feature_tag_size(feature_tag_product_serial); >> + >> + features->u.product_serial.serial[0] = 0; >> + features->u.product_serial.serial[1] = 0; >> + features->u.product_serial.serial[2] = 0; >> + features->u.product_serial.serial[3] = 0; >> + >> + features = feature_tag_next(features); >> +} >> +static void setup_feature_product_mac_address(void) >> +{ >> + features->hdr.tag = FTAG_PRODUCT_MAC_ADDRESS; >> + features->hdr.size = feature_tag_size(feature_tag_product_mac_address); >> + >> + features->u.mac_address.addr[0] = 0; >> + features->u.mac_address.addr[1] = 0; >> + features->u.mac_address.addr[2] = 0; >> + features->u.mac_address.addr[3] = 0; >> + features->u.mac_address.addr[4] = 0; >> + features->u.mac_address.addr[5] = 0; >> + features->u.mac_address.reserved1 = 0; >> + features->u.mac_address.reserved2 = 0; >> + >> + features = feature_tag_next(features); >> +} >> +static void setup_feature_board_pcb_revision(void) >> +{ >> + features->hdr.tag = FTAG_BOARD_PCB_REVISION; >> + features->hdr.size = feature_tag_size(feature_tag_board_revision); >> + >> + features->u.board_revision.revision = 5; >> + >> + features = feature_tag_next(features); >> +} >> +static void setup_feature_sdram(void) >> +{ >> + features->hdr.tag = FTAG_SDRAM; >> + features->hdr.size = feature_tag_size(feature_tag_sdram); >> + >> + memset(features->u.sdram.vendor, 0, sizeof(features->u.sdram.vendor)); >> + memset(features->u.sdram.product, 0, >> + sizeof(features->u.sdram.product)); >> + sprintf(features->u.sdram.vendor , "elpida"); >> + sprintf(features->u.sdram.product, "EDB8064B1PB"/*"EDB4064B2PB"*/); >> + features->u.sdram.type = 0; >> + features->u.sdram.revision = 0; >> + features->u.sdram.flags = 0; >> + features->u.sdram.clock = 400; >> + features->u.sdram.param_0 = 0; >> + features->u.sdram.param_1 = 0; >> + features->u.sdram.param_2 = 0; >> + features->u.sdram.param_3 = 0; >> + features->u.sdram.param_4 = 0; >> + features->u.sdram.param_5 = 0; >> + features->u.sdram.param_6 = 0; >> + features->u.sdram.param_7 = 0; >> + >> + features = feature_tag_next(features); >> +} >> +static void setup_feature_pmic(void) >> +{ >> + features->hdr.tag = FTAG_PMIC; >> + features->hdr.size = feature_tag_size(feature_tag_pmic); >> + >> + features->u.pmic.flags = FTAG_PMIC_TPS62361; >> + >> + features = feature_tag_next(features); >> +} >> +static void setup_feature_serial_port(void) >> +{ >> + features->hdr.tag = FTAG_SERIAL_PORT; >> + features->hdr.size = feature_tag_size(feature_tag_serial_port); >> + >> + features->u.serial_port.uart_id = 1; >> + features->u.serial_port.speed = 115200; >> + >> + features = feature_tag_next(features); >> +} >> +static void setup_feature_has_gpio_volume_keys(void) >> +{ >> + features->hdr.tag = FTAG_HAS_GPIO_VOLUME_KEYS; >> + features->hdr.size = feature_tag_size(feature_tag_gpio_volume_keys); >> + >> + features->u.gpio_volume_keys.gpio_vol_up = 0x2B; >> + features->u.gpio_volume_keys.gpio_vol_down = 0x2C; >> + features->u.gpio_volume_keys.flags = 0; >> + >> + features = feature_tag_next(features); >> +} >> +static void setup_feature_screen(void) >> +{ >> + features->hdr.tag = FTAG_SCREEN; >> + features->hdr.size = feature_tag_size(feature_tag_screen); >> + >> + memset(features->u.screen.vendor, 0, >> + sizeof(features->u.screen.vendor)); >> + sprintf(features->u.screen.vendor, "CMI"); >> + features->u.screen.type = 0; >> + features->u.screen.revision = 0; >> + features->u.screen.vcom = 0; >> + features->u.screen.backlight = 0xC8; >> + features->u.screen.reserved[0] = 0; >> + features->u.screen.reserved[1] = 0; >> + features->u.screen.reserved[2] = 0; >> + features->u.screen.reserved[3] = 0; >> + features->u.screen.reserved[4] = 0; >> + >> + features = feature_tag_next(features); >> +} >> +static void setup_feature_turbo(void) >> +{ >> + features->hdr.tag = FTAG_TURBO; >> + features->hdr.size = feature_tag_size(feature_tag_turbo); >> + >> + features->u.turbo.flag = 1; >> + >> + features = feature_tag_next(features); >> +} >> +static void setup_feature_none(void) >> +{ >> + features->hdr.tag = FTAG_NONE; >> + features->hdr.size = sizeof(struct feature_tag_header) >> 2; >> + >> + features = feature_tag_next(features); >> +} >> +static struct tag *setup_feature_list(struct tag * params) >> +{ >> + struct tag_feature_list *fl; >> + >> + fl = atag_data(params); >> + features = (struct feature_tag *)fl->data; >> + >> + setup_feature_core(); >> + setup_feature_product_name(); >> + setup_feature_product_serial_number(); >> + setup_feature_product_mac_address(); >> + setup_feature_board_pcb_revision(); >> + setup_feature_sdram(); >> + setup_feature_pmic(); >> + setup_feature_serial_port(); >> + setup_feature_has_gpio_volume_keys(); >> + setup_feature_screen(); >> + setup_feature_turbo(); >> + setup_feature_none(); >> + >> + fl->size = ((u32)features) - ((u32)(fl->data)); >> + >> + params->hdr.tag = ATAG_FEATURE_LIST; >> + params->hdr.size = (sizeof(struct tag_feature_list) + fl->size) >> 2; >> + >> + return tag_next(params); >> +} >> + >> +static struct tag *setup_boot_version(struct tag *params) >> +{ >> + struct tag_boot_version *bv; >> + >> + bv = atag_data(params); >> + >> + params->hdr.tag = ATAG_BOOT_VERSION; >> + params->hdr.size = tag_size(tag_boot_version); >> + >> + bv->major = 5; >> + bv->minor = 5; >> + bv->extra = 3; >> + >> + return tag_next(params); >> +} >> + >> +struct tag *archos_append_atags(struct tag *params) >> +{ >> + params = setup_feature_list(params); >> + params = setup_boot_version(params); >> + return params; >> +} >> diff --git a/arch/arm/boards/archosg9/archos_features.h b/arch/arm/boards/archosg9/archos_features.h >> new file mode 100644 >> index 0000000..5769c6c >> --- /dev/null >> +++ b/arch/arm/boards/archosg9/archos_features.h >> @@ -0,0 +1,22 @@ >> +#ifndef __ARCHOS_FEATURES_H >> +#define __ARCHOS_FEATURES_H >> + >> +/* bootloader version */ >> +#define ATAG_BOOT_VERSION 0x5441000A >> + >> +struct tag_boot_version { >> + u32 major; >> + u32 minor; >> + u32 extra; >> +}; >> + >> +#define ATAG_FEATURE_LIST 0x5441000B >> + >> +struct tag_feature_list { >> + u32 size; >> + u8 data[0]; >> +}; >> + >> +struct tag *archos_append_atags(struct tag * params); >> + >> +#endif /* __ARCHOS_FEATURES_H */ >> diff --git a/arch/arm/boards/archosg9/board.c b/arch/arm/boards/archosg9/board.c >> index 200fe92..8366cca 100644 >> --- a/arch/arm/boards/archosg9/board.c >> +++ b/arch/arm/boards/archosg9/board.c >> @@ -20,6 +20,7 @@ >> #include <sizes.h> >> #include <i2c/i2c.h> >> #include <gpio.h> >> +#include "archos_features.h" >> >> static int archosg9_console_init(void){ >> if (IS_ENABLED(CONFIG_DRIVER_SERIAL_OMAP4_USBBOOT)) >> @@ -59,6 +60,7 @@ static int archosg9_devices_init(void){ >> */ >> armlinux_set_architecture(5032); >> armlinux_set_revision(5); >> + armlinux_set_atag_appender(archos_append_atags); >> >> return 0; >> } >> diff --git a/arch/arm/boards/archosg9/feature_list.h b/arch/arm/boards/archosg9/feature_list.h >> new file mode 100644 >> index 0000000..51f33ab >> --- /dev/null >> +++ b/arch/arm/boards/archosg9/feature_list.h >> @@ -0,0 +1,352 @@ >> +#ifndef _FEATURE_LIST_H >> +#define _FEATURE_LIST_H >> + >> +/* >> + This file comes from: >> + http://gitorious.org/archos/archos-gpl-gen9-kernel-ics/blobs/raw/master/ >> + arch/arm/include/asm/feature_list.h >> +*/ >> + >> +#define FEATURE_LIST_MAGIC 0xFEA01234 >> + >> +#define FEATURE_LIST_REV 0x00000001 >> + >> +struct feature_tag_header { >> + u32 size; >> + u32 tag; >> +}; >> + >> +struct feature_tag_generic { >> + u32 vendor; >> + u32 product; >> + u32 type; >> + u32 revision; >> + u32 flags; >> +}; >> + >> +#define FTAG_NONE 0x00000000 >> + >> +#define FTAG_CORE 0x00000001 >> +struct feature_tag_core { >> + u32 magic; >> + u32 list_revision; >> + u32 flags; >> +}; >> + >> +/* product specific */ >> +#define FTAG_PRODUCT_NAME 0x00000002 >> +struct feature_tag_product_name { >> + char name[64]; >> + u32 id; >> +}; >> +#define FTAG_PRODUCT_SERIAL_NUMBER 0x00000003 >> +struct feature_tag_product_serial { >> + u32 serial[4]; >> +}; >> + >> +#define FTAG_PRODUCT_MAC_ADDRESS 0x00000004 >> +struct feature_tag_product_mac_address { >> + u8 addr[6]; >> + u8 reserved1; >> + u8 reserved2; >> +}; >> + >> +#define FTAG_PRODUCT_OEM 0x00000005 >> +struct feature_tag_product_oem { >> + char name[16]; >> + u32 id; >> +}; >> + >> +#define FTAG_PRODUCT_ZONE 0x00000006 >> +struct feature_tag_product_zone { >> + char name[16]; >> + u32 id; >> +}; >> + >> +/* board pcb specific */ >> +#define FTAG_BOARD_PCB_REVISION 0x00000010 >> +struct feature_tag_board_revision { >> + u32 revision; >> +}; >> + >> +/* clock and ram setup */ >> +#define FTAG_CLOCK 0x00000011 >> +struct feature_tag_clock { >> + u32 clock; >> +}; >> + >> +#define FTAG_SDRAM 0x00000012 >> +struct feature_tag_sdram { >> + char vendor[16]; >> + char product[32]; >> + u32 type; >> + u32 revision; >> + u32 flags; >> + u32 clock; >> + /* custom params */ >> + u32 param_0; >> + u32 param_1; >> + u32 param_2; >> + u32 param_3; >> + u32 param_4; >> + u32 param_5; >> + u32 param_6; >> + u32 param_7; >> +}; >> + >> +/* PMIC */ >> +#define FTAG_PMIC 0x00000013 >> +#define FTAG_PMIC_TPS62361 0x00000001 >> +struct feature_tag_pmic { >> + u32 flags; >> +}; >> + >> +/* serial port */ >> +#define FTAG_SERIAL_PORT 0x00000020 >> +struct feature_tag_serial_port { >> + u32 uart_id; >> + u32 speed; >> +}; >> + >> +/* turbo bit */ >> +#define FTAG_TURBO 0x00000014 >> +struct feature_tag_turbo { >> + u32 flag; >> +}; >> + >> +/*** features ****/ >> +#define FTAG_HAS_GPIO_VOLUME_KEYS 0x00010001 >> +struct feature_tag_gpio_volume_keys { >> + u32 gpio_vol_up; >> + u32 gpio_vol_down; >> + u32 flags; >> +}; >> + >> +#define FTAG_HAS_ELECTRICAL_SHORTCUT 0x00010002 >> +#define FTAG_HAS_DCIN 0x00010003 >> +struct feature_tag_dcin { >> + u32 autodetect; >> +}; >> + >> +/* external screen support */ >> +#define FTAG_HAS_EXT_SCREEN 0x00010004 >> + >> +#define EXT_SCREEN_TYPE_TVOUT 0x00000001 >> +#define EXT_SCREEN_TYPE_HDMI 0x00000002 >> +#define EXT_SCREEN_TYPE_VGA 0x00000004 >> +struct feature_tag_ext_screen { >> + u32 type; >> + u32 revision; >> +}; >> + >> +/* wireless lan */ >> +#define FTAG_HAS_WIFI 0x00010005 >> + >> +#define WIFI_TYPE_TIWLAN 0x00000001 >> +struct feature_tag_wifi { >> + u32 vendor; >> + u32 product; >> + u32 type; >> + u32 revision; >> + u32 flags; >> +}; >> + >> +/* bluetooth */ >> +#define FTAG_HAS_BLUETOOTH 0x00010006 >> + >> +#define BLUETOOTH_TYPE_TIWLAN 0x00000001 >> +struct feature_tag_bluetooth { >> + u32 vendor; >> + u32 product; >> + u32 type; >> + u32 revision; >> + u32 flags; >> +}; >> + >> +/* accelerometer */ >> +#define FTAG_HAS_ACCELEROMETER 0x00010007 >> +struct feature_tag_accelerometer { >> + u32 vendor; >> + u32 product; >> + u32 type; >> + u32 revision; >> + u32 flags; >> +}; >> + >> +/* gyroscope */ >> +#define FTAG_HAS_GYROSCOPE 0x00010008 >> + >> +/* compass */ >> +#define FTAG_HAS_COMPASS 0x00010009 >> + >> +/* gps */ >> +#define FTAG_HAS_GPS 0x0001000a >> +#define GPS_FLAG_DISABLED 0x00000001 >> +struct feature_tag_gps { >> + u32 vendor; >> + u32 product; >> + u32 revision; >> + u32 flags; >> +}; >> + >> +/* camera */ >> +#define FTAG_HAS_CAMERA 0x0001000b >> + >> +/* harddisk controller */ >> +#define FTAG_HAS_HARDDISK_CONTROLLER 0x0001000c >> +#define HDCONTROLLER_TYPE_SATA 0x00000001 >> +struct feature_tag_harddisk_controller { >> + u32 vendor; >> + u32 product; >> + u32 type; >> + u32 revision; >> + u32 flags; >> +}; >> + >> +/* harddisk */ >> +#define FTAG_HAS_HARDDISK 0x0001000d >> + >> +#define HARDDISK_TYPE_SATA 0x00000001 >> +#define HARDDISK_TYPE_PATA 0x00000002 >> +struct feature_tag_harddisk { >> + u32 vendor; >> + u32 product; >> + u32 type; >> + u32 revision; >> + u32 flags; >> +}; >> + >> +/* touchscreen */ >> +#define FTAG_HAS_TOUCHSCREEN 0x0001000e >> + >> +#define TOUCHSCREEN_TYPE_CAPACITIVE 0x00000001 >> +#define TOUCHSCREEN_TYPE_RESISTIVE 0x00000002 >> + >> +#define TOUCHSCREEN_FLAG_MULTITOUCH 0x00000001 >> +struct feature_tag_touchscreen { >> + u32 vendor; >> + u32 product; >> + u32 type; >> + u32 revision; >> + u32 flags; >> +}; >> + >> +/* microphone */ >> +#define FTAG_HAS_MICROPHONE 0x0001000f >> + >> +/* external SDMMC slot */ >> +#define FTAG_HAS_EXT_MMCSD_SLOT 0x00010010 >> +#define MMCSD_FLAG_CARDDETECT 0x00000001 >> +#define MMCSD_FLAG_CARDPREDETECT 0x00000002 >> + >> +struct feature_tag_mmcsd { >> + u32 width; >> + u32 voltagemask; >> + u32 revision; >> + u32 flags; >> +}; >> + >> +/* ambient light sensor */ >> +#define FTAG_HAS_AMBIENT_LIGHT_SENSOR 0x00010011 >> + >> +/* proximity sensor */ >> +#define FTAG_HAS_PROXIMITY_SENSOR 0x00010012 >> + >> +/* gps */ >> +#define FTAG_HAS_GSM 0x00010013 >> + >> +/* dect */ >> +#define FTAG_HAS_DECT 0x00010014 >> + >> +/* hsdpa data modem */ >> +#define FTAG_HAS_HSDPA 0x00010015 >> + >> +/* near field communication */ >> +#define FTAG_HAS_NFC 0x00010016 >> + >> +#define FTAG_GPIO_KEYS 0x00010017 >> +struct feature_tag_gpio_keys { >> +#define GPIO_KEYS_LONG_PRESS 0x00010000 >> + u32 vol_up; >> + u32 vol_down; >> + u32 ok; >> + u32 reserved[5]; >> +}; >> + >> +#define FTAG_SCREEN 0x00010018 >> +struct feature_tag_screen { >> + char vendor[16]; >> + u32 type; >> + u32 revision; >> + u32 vcom; >> + u32 backlight; >> + u32 reserved[5]; >> +}; >> + >> +#define FTAG_WIFI_PA 0x00010019 >> +struct feature_tag_wifi_pa { >> + char vendor[16]; >> + u32 type; >> +}; >> + >> +/* loudspeaker */ >> +#define FTAG_HAS_SPEAKER 0x0001001a >> + >> +#define SPEAKER_FLAG_STEREO 0x00000001 >> +#define SPEAKER_FLAG_OWN_VOLCTRL 0x00000002 >> +struct feature_tag_speaker { >> + u32 flags; >> +}; >> + >> +#define FTAG_BATTERY 0x0001001b >> +struct feature_tag_battery { >> + u32 type; >> +}; >> +#define BATTERY_TYPE_HIGHRS 0x00000000 >> +#define BATTERY_TYPE_LOWRS 0x00000001 >> + >> + >> +#define feature_tag_next(t) \ >> + ((struct feature_tag *)((u32 *)(t) + (t)->hdr.size)) >> +#define feature_tag_size(type) \ >> + ((sizeof(struct feature_tag_header) + sizeof(struct type)) >> 2) >> +#define for_each_feature_tag(t, base) \ >> + for (t = base; t->hdr.size; t = feature_tag_next(t)) >> + >> + >> +struct feature_tag { >> + struct feature_tag_header hdr; >> + union { >> + struct feature_tag_core core; >> + struct feature_tag_generic generic; >> + struct feature_tag_product_name product_name; >> + struct feature_tag_product_serial product_serial; >> + struct feature_tag_product_oem product_oem; >> + struct feature_tag_product_zone product_zone; >> + struct feature_tag_product_mac_address mac_address; >> + struct feature_tag_board_revision board_revision; >> + struct feature_tag_clock clock; >> + struct feature_tag_sdram sdram; >> + struct feature_tag_pmic pmic; >> + struct feature_tag_turbo turbo; >> + struct feature_tag_serial_port serial_port; >> + struct feature_tag_gpio_volume_keys gpio_volume_keys; >> + struct feature_tag_dcin dcin; >> + struct feature_tag_ext_screen ext_screen; >> + struct feature_tag_wifi wifi; >> + struct feature_tag_bluetooth bluetooth; >> + struct feature_tag_accelerometer accelerometer; >> + struct feature_tag_harddisk_controller harddisk_controller; >> + struct feature_tag_harddisk harddisk; >> + struct feature_tag_touchscreen touchscreen; >> + struct feature_tag_gps gps; >> + struct feature_tag_speaker speaker; >> + struct feature_tag_mmcsd mmcsd; >> + struct feature_tag_gpio_keys gpio_keys; >> + struct feature_tag_screen screen; >> + struct feature_tag_wifi_pa wifi_pa; >> + struct feature_tag_battery battery; >> + } u; >> +}; >> + >> +#endif /* _FEATURE_LIST_H */ >> diff --git a/arch/arm/configs/archosg9_defconfig b/arch/arm/configs/archosg9_defconfig >> index 2a20dd7..1f3d105 100644 >> --- a/arch/arm/configs/archosg9_defconfig >> +++ b/arch/arm/configs/archosg9_defconfig >> @@ -11,6 +11,7 @@ CONFIG_TEXT_BASE=0xa0000000 >> CONFIG_MALLOC_BASE=0x90000000 >> CONFIG_MALLOC_SIZE=0x10000000 >> CONFIG_KALLSYMS=y >> +CONFIG_ARM_BOARD_APPEND_ATAG=y >> CONFIG_PROMPT="barebox> " >> CONFIG_LONGHELP=y >> CONFIG_GLOB=y >> diff --git a/arch/arm/include/asm/armlinux.h b/arch/arm/include/asm/armlinux.h >> index 8ec8c4d..07479fb 100644 >> --- a/arch/arm/include/asm/armlinux.h >> +++ b/arch/arm/include/asm/armlinux.h >> @@ -2,6 +2,7 @@ >> #define __ARCH_ARMLINUX_H >> >> #include <asm/memory.h> >> +#include <asm/setup.h> >> >> #if defined CONFIG_ARM_LINUX >> void armlinux_set_bootparams(void *params); >> @@ -26,6 +27,14 @@ static inline void armlinux_set_serial(u64 serial) >> } >> #endif >> >> +#if defined CONFIG_ARM_BOARD_APPEND_ATAG >> +void armlinux_set_atag_appender(struct tag *(*)(struct tag *)); >> +#else >> +static inline void armlinux_set_atag_appender(struct tag *(*func)(struct tag *)) >> +{ >> +} >> +#endif >> + >> struct image_data; >> >> void start_linux(void *adr, int swap, unsigned long initrd_address, >> diff --git a/arch/arm/lib/armlinux.c b/arch/arm/lib/armlinux.c >> index 9c134ed..40a63ea 100644 >> --- a/arch/arm/lib/armlinux.c >> +++ b/arch/arm/lib/armlinux.c >> @@ -106,6 +106,14 @@ u64 armlinux_get_serial(void) >> #endif >> } >> >> +#ifdef CONFIG_ARM_BOARD_APPEND_ATAG >> +static struct tag *(*atag_appender)(struct tag *); >> +void armlinux_set_atag_appender(struct tag *(*func)(struct tag *)) >> +{ >> + atag_appender = func; >> +} >> +#endif >> + >> static void setup_start_tag(void) >> { >> params = (struct tag *)armlinux_bootparams; >> @@ -233,6 +241,10 @@ static void setup_tags(unsigned long initrd_address, >> >> setup_revision_tag(); >> setup_serial_tag(); >> +#ifdef CONFIG_ARM_BOARD_APPEND_ATAG >> + if (atag_appender != NULL) >> + params = atag_appender(params); >> +#endif >> setup_end_tag(); >> >> printf("commandline: %s\n" >> -- >> 1.8.1.1 >> >> >> _______________________________________________ >> barebox mailing list >> barebox@xxxxxxxxxxxxxxxxxxx >> http://lists.infradead.org/mailman/listinfo/barebox >> > > -- > Pengutronix e.K. | | > Industrial Linux Solutions | http://www.pengutronix.de/ | > Peiner Str. 6-8, 31137 Hildesheim, Germany | Phone: +49-5121-206917-0 | > Amtsgericht Hildesheim, HRA 2686 | Fax: +49-5121-206917-5555 | _______________________________________________ barebox mailing list barebox@xxxxxxxxxxxxxxxxxxx http://lists.infradead.org/mailman/listinfo/barebox