nexus: Use a linker set for the devices

This commit is contained in:
Sebastian Huber 2014-10-01 14:20:42 +02:00
parent d43544ef12
commit 6cfc98de31
8 changed files with 28 additions and 56 deletions

View File

@ -109,7 +109,6 @@ LIB_C_FILES += rtemsbsd/telnetd/check_passwd.c
LIB_C_FILES += rtemsbsd/telnetd/des.c LIB_C_FILES += rtemsbsd/telnetd/des.c
LIB_C_FILES += rtemsbsd/telnetd/pty.c LIB_C_FILES += rtemsbsd/telnetd/pty.c
LIB_C_FILES += rtemsbsd/telnetd/telnetd.c LIB_C_FILES += rtemsbsd/telnetd/telnetd.c
LIB_C_FILES += rtemsbsd/bsp/bsp-bsd-nexus-devices.c
LIB_GEN_FILES += rtemsbsd/rtems/rtems-kvm-symbols.c LIB_GEN_FILES += rtemsbsd/rtems/rtems-kvm-symbols.c
LIB_C_FILES += rtemsbsd/rtems/rtems-kvm-symbols.c LIB_C_FILES += rtemsbsd/rtems/rtems-kvm-symbols.c
rtemsbsd/rtems/rtems-kvm-symbols.c: rtemsbsd/rtems/generate_kvm_symbols rtemsbsd/rtems/rtems-kvm-symbols.c: rtemsbsd/rtems/generate_kvm_symbols

View File

@ -707,7 +707,6 @@ rtems.addRTEMSSourceFiles(
'telnetd/des.c', 'telnetd/des.c',
'telnetd/pty.c', 'telnetd/pty.c',
'telnetd/telnetd.c', 'telnetd/telnetd.c',
'bsp/bsp-bsd-nexus-devices.c',
] ]
) )

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2013 embedded brains GmbH. All rights reserved. * Copyright (c) 2013-2014 embedded brains GmbH. All rights reserved.
* *
* embedded brains GmbH * embedded brains GmbH
* Dornierstr. 4 * Dornierstr. 4
@ -31,8 +31,6 @@
#include <rtems/bsd/bsd.h> #include <rtems/bsd/bsd.h>
#include <machine/rtems-bsd-sysinit.h>
#include <bsp.h> #include <bsp.h>
#if defined(LIBBSP_ARM_REALVIEW_PBX_A9_BSP_H) #if defined(LIBBSP_ARM_REALVIEW_PBX_A9_BSP_H)
@ -51,36 +49,13 @@ static const rtems_bsd_device_resource smc0_res[] = {
} }
}; };
const rtems_bsd_device rtems_bsd_nexus_devices[] = { RTEMS_BSD_DEFINE_NEXUS_DEVICE(smc, 0, RTEMS_ARRAY_SIZE(smc0_res),
{ &smc0_res[0]);
.name = "smc",
.unit = 0,
.resource_count = RTEMS_ARRAY_SIZE(smc0_res),
.resources = &smc0_res[0]
}
};
SYSINIT_DRIVER_REFERENCE(smc, nexus);
#elif defined(__GENMCF548X_BSP_H) #elif defined(__GENMCF548X_BSP_H)
const rtems_bsd_device rtems_bsd_nexus_devices[] = { RTEMS_BSD_DEFINE_NEXUS_DEVICE(fec, 0, 0, NULL);
{
.name = "fec",
.unit = 0
}, {
.name = "fec",
.unit = 1
}
};
SYSINIT_DRIVER_REFERENCE(fec, nexus); RTEMS_BSD_DEFINE_NEXUS_DEVICE(fec, 1, 0, NULL);
#else
const rtems_bsd_device rtems_bsd_nexus_devices[0];
#endif #endif
const size_t rtems_bsd_nexus_device_count =
RTEMS_ARRAY_SIZE(rtems_bsd_nexus_devices);

View File

@ -40,12 +40,16 @@
#ifndef _RTEMS_BSD_BSD_H_ #ifndef _RTEMS_BSD_BSD_H_
#define _RTEMS_BSD_BSD_H_ #define _RTEMS_BSD_BSD_H_
#include <sys/cdefs.h>
#include <sys/queue.h>
#include <sys/kernel.h>
#include <rtems.h>
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
#endif /* __cplusplus */ #endif /* __cplusplus */
#include <rtems.h>
typedef enum { typedef enum {
RTEMS_BSD_RES_IRQ = 1, RTEMS_BSD_RES_IRQ = 1,
RTEMS_BSD_RES_MEMORY = 3 RTEMS_BSD_RES_MEMORY = 3
@ -62,11 +66,14 @@ typedef struct {
int unit; int unit;
size_t resource_count; size_t resource_count;
const rtems_bsd_device_resource *resources; const rtems_bsd_device_resource *resources;
const struct sysinit *driver_reference;
} rtems_bsd_device; } rtems_bsd_device;
extern const rtems_bsd_device rtems_bsd_nexus_devices[]; #define RTEMS_BSD_DEFINE_NEXUS_DEVICE(name, unit, resource_count, resources) \
extern struct sysinit SYSINIT_ENTRY_NAME(name##_nexusmodule); \
extern const size_t rtems_bsd_nexus_device_count; RTEMS_BSD_DEFINE_SET_ITEM(nexus, name##unit, rtems_bsd_device) = \
{ #name, unit, (resource_count), (resources), \
&SYSINIT_ENTRY_NAME(name##_nexusmodule) }
rtems_status_code rtems_bsd_initialize(void); rtems_status_code rtems_bsd_initialize(void);

View File

@ -7,7 +7,7 @@
*/ */
/* /*
* Copyright (c) 2009-2013 embedded brains GmbH. All rights reserved. * Copyright (c) 2009-2014 embedded brains GmbH. All rights reserved.
* *
* embedded brains GmbH * embedded brains GmbH
* Dornierstr. 4 * Dornierstr. 4
@ -54,6 +54,10 @@
/* #define DISABLE_INTERRUPT_EXTENSION */ /* #define DISABLE_INTERRUPT_EXTENSION */
RTEMS_BSD_DECLARE_SET(nexus, rtems_bsd_device);
RTEMS_BSD_DEFINE_SET(nexus, rtems_bsd_device);
RTEMS_STATIC_ASSERT(SYS_RES_MEMORY == RTEMS_BSD_RES_MEMORY, RTEMS_BSD_RES_MEMORY); RTEMS_STATIC_ASSERT(SYS_RES_MEMORY == RTEMS_BSD_RES_MEMORY, RTEMS_BSD_RES_MEMORY);
RTEMS_STATIC_ASSERT(SYS_RES_IRQ == RTEMS_BSD_RES_IRQ, RTEMS_BSD_RES_IRQ); RTEMS_STATIC_ASSERT(SYS_RES_IRQ == RTEMS_BSD_RES_IRQ, RTEMS_BSD_RES_IRQ);
@ -67,7 +71,7 @@ nexus_probe(device_t dev)
{ {
rtems_status_code status; rtems_status_code status;
int err; int err;
size_t i; const rtems_bsd_device *nd;
device_set_desc(dev, "RTEMS Nexus device"); device_set_desc(dev, "RTEMS Nexus device");
@ -100,9 +104,7 @@ nexus_probe(device_t dev)
err = rman_manage_region(&irq_rman, irq_rman.rm_start, irq_rman.rm_end); err = rman_manage_region(&irq_rman, irq_rman.rm_start, irq_rman.rm_end);
BSD_ASSERT(err == 0); BSD_ASSERT(err == 0);
for (i = 0; i < rtems_bsd_nexus_device_count; ++i) { SET_FOREACH(nd, nexus) {
const rtems_bsd_device *nd = &rtems_bsd_nexus_devices[i];
device_add_child(dev, nd->name, nd->unit); device_add_child(dev, nd->name, nd->unit);
} }
@ -133,7 +135,7 @@ nexus_alloc_resource(device_t bus, device_t child, int type, int *rid,
u_long start, u_long end, u_long count, u_int flags) u_long start, u_long end, u_long count, u_int flags)
{ {
struct rman *rm; struct rman *rm;
size_t i; const rtems_bsd_device *nd;
switch (type) { switch (type) {
case SYS_RES_MEMORY: case SYS_RES_MEMORY:
@ -146,9 +148,7 @@ nexus_alloc_resource(device_t bus, device_t child, int type, int *rid,
return (NULL); return (NULL);
} }
for (i = 0; i < rtems_bsd_nexus_device_count; ++i) { SET_FOREACH(nd, nexus) {
const rtems_bsd_device *nd = &rtems_bsd_nexus_devices[i];
if (strcmp(device_get_name(child), nd->name) == 0 if (strcmp(device_get_name(child), nd->name) == 0
&& device_get_unit(child) == nd->unit) { && device_get_unit(child) == nd->unit) {
struct resource *res = NULL; struct resource *res = NULL;

View File

@ -272,6 +272,8 @@ Init(rtems_task_argument arg)
SYSINIT_NEED_NET_PF_UNIX; SYSINIT_NEED_NET_PF_UNIX;
#include <bsp/nexus-devices.h>
#define CONFIGURE_APPLICATION_NEEDS_CLOCK_DRIVER #define CONFIGURE_APPLICATION_NEEDS_CLOCK_DRIVER
#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER #define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER
#define CONFIGURE_APPLICATION_NEEDS_STUB_DRIVER #define CONFIGURE_APPLICATION_NEEDS_STUB_DRIVER

View File

@ -39,11 +39,6 @@
#include "swi_test.h" #include "swi_test.h"
const rtems_bsd_device rtems_bsd_nexus_devices[0];
const size_t rtems_bsd_nexus_device_count =
RTEMS_ARRAY_SIZE(rtems_bsd_nexus_devices);
static void Init(rtems_task_argument arg) static void Init(rtems_task_argument arg)
{ {
rtems_status_code sc; rtems_status_code sc;

View File

@ -39,11 +39,6 @@
#include "timeout_test.h" #include "timeout_test.h"
const rtems_bsd_device rtems_bsd_nexus_devices[0];
const size_t rtems_bsd_nexus_device_count =
RTEMS_ARRAY_SIZE(rtems_bsd_nexus_devices);
static void Init(rtems_task_argument arg) static void Init(rtems_task_argument arg)
{ {
rtems_status_code sc; rtems_status_code sc;