source: rtems-libbsd/rtemsbsd/rtems/rtems-kernel-init.c @ e9a8b5a

55-freebsd-126-freebsd-12
Last change on this file since e9a8b5a was e9a8b5a, checked in by Christian Mauderer <Christian.Mauderer@…>, on 11/17/16 at 08:15:27

wlan ratectl and sta: Call init.

  • Property mode set to 100644
File size: 4.5 KB
Line 
1/**
2 * @file
3 *
4 * @ingroup rtems_bsd_rtems
5 *
6 * @brief TODO.
7 */
8
9/*
10 * Copyright (c) 2009-2015 embedded brains GmbH.  All rights reserved.
11 *
12 *  embedded brains GmbH
13 *  Dornierstr. 4
14 *  82178 Puchheim
15 *  Germany
16 *  <rtems@embedded-brains.de>
17 *
18 * Redistribution and use in source and binary forms, with or without
19 * modification, are permitted provided that the following conditions
20 * are met:
21 * 1. Redistributions of source code must retain the above copyright
22 *    notice, this list of conditions and the following disclaimer.
23 * 2. Redistributions in binary form must reproduce the above copyright
24 *    notice, this list of conditions and the following disclaimer in the
25 *    documentation and/or other materials provided with the distribution.
26 *
27 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
28 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
29 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
30 * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
31 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
32 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
33 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
34 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
35 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
36 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
37 * SUCH DAMAGE.
38 */
39
40#include <machine/rtems-bsd-kernel-space.h>
41#include <machine/rtems-bsd-thread.h>
42
43#include <rtems/bsd/sys/param.h>
44#include <sys/types.h>
45#include <sys/systm.h>
46#include <sys/kernel.h>
47#include <sys/sysctl.h>
48#include <rtems/bsd/sys/lock.h>
49#include <sys/mutex.h>
50#include <sys/proc.h>
51#include <sys/stat.h>
52
53#include <net80211/ieee80211_freebsd.h>
54
55#include <rtems/bsd/bsd.h>
56
57SYSINIT_REFERENCE(configure1);
58SYSINIT_REFERENCE(module);
59SYSINIT_REFERENCE(kobj);
60SYSINIT_REFERENCE(linker_kernel);
61SYSINIT_MODULE_REFERENCE(rootbus);
62SYSINIT_DRIVER_REFERENCE(nexus, root);
63
64RTEMS_BSD_DEFINE_SET(modmetadata_set, struct mod_metadata *);
65RTEMS_BSD_DEFINE_SET(ieee80211_ioctl_getset, ieee80211_ioctl_getfunc *);
66RTEMS_BSD_DEFINE_SET(ieee80211_ioctl_setset, ieee80211_ioctl_setfunc *);
67typedef void (*ratectl_modevent)(int);
68RTEMS_BSD_DEFINE_SET(ratectl_set, ratectl_modevent);
69typedef void (*scanner_modevent)(int);
70RTEMS_BSD_DEFINE_SET(scanner_set, scanner_modevent);
71RTEMS_BSD_DEFINE_SET(sysctl_set, struct sysctl_oid *);
72
73RTEMS_BSD_DEFINE_RWSET(sysinit_set, struct sysinit *);
74
75/* In FreeBSD this is a local function */
76void mi_startup(void);
77
78int hz;
79int tick;
80sbintime_t tick_sbt;
81struct bintime bt_timethreshold;
82struct bintime bt_tickthreshold;
83sbintime_t sbt_timethreshold;
84sbintime_t sbt_tickthreshold;
85struct bintime tc_tick_bt;
86sbintime_t tc_tick_sbt;
87int tc_precexp;
88int maxusers;     /* base tunable */
89
90static SYSCTL_NODE(_kern, OID_AUTO, smp, CTLFLAG_RD|CTLFLAG_CAPRD, NULL,
91    "Kernel SMP");
92
93static int maxid_maxcpus;
94
95SYSCTL_INT(_kern_smp, OID_AUTO, maxid, CTLFLAG_RD|CTLFLAG_CAPRD,
96    &maxid_maxcpus, 0, "Max CPU ID.");
97
98SYSCTL_INT(_kern_smp, OID_AUTO, maxcpus, CTLFLAG_RD|CTLFLAG_CAPRD,
99    &maxid_maxcpus, 0, "Max number of CPUs that the system was compiled for.");
100
101#undef _bsd_ticks
102
103RTEMS_STATIC_ASSERT(sizeof(int) == sizeof(int32_t), ticks);
104
105volatile uint32_t _Watchdog_Ticks_since_boot;
106
107extern volatile int32_t _bsd_ticks
108    __attribute__ ((__alias__("_Watchdog_Ticks_since_boot")));
109
110__attribute__((__weak__)) void _arc4random_getentropy_fail(void)
111{
112
113}
114
115__attribute__((__weak__)) int getentropy(void *buf, size_t n)
116{
117
118        memset(buf, 0, n);
119        return (0);
120}
121
122rtems_status_code
123rtems_bsd_initialize(void)
124{
125        static const char name[] = "TIME";
126        rtems_status_code sc;
127
128        hz = (int) rtems_clock_get_ticks_per_second();
129        tick = 1000000 / hz;
130        tick_sbt = SBT_1S / hz;
131        FREQ2BT(hz, &tc_tick_bt);
132        tc_tick_sbt = bttosbt(tc_tick_bt);
133        tc_precexp = 31;
134        bt_timethreshold.sec = INT_MAX;
135        bt_timethreshold.frac = ~(uint64_t)0;
136        bt_tickthreshold = bt_timethreshold;
137        sbt_timethreshold = bttosbt(bt_timethreshold);
138        sbt_tickthreshold = bttosbt(bt_tickthreshold);
139        maxusers = 1;
140        maxid_maxcpus = (int) rtems_get_processor_count();
141
142        mkdir("/etc", S_IRWXU | S_IRWXG | S_IRWXO);
143
144        sc =  rtems_timer_initiate_server(
145                rtems_bsd_get_task_priority(name),
146                rtems_bsd_get_task_stack_size(name),
147                RTEMS_DEFAULT_ATTRIBUTES
148        );
149        if (sc != RTEMS_SUCCESSFUL) {
150                return RTEMS_UNSATISFIED;
151        }
152
153        mutex_init();
154        mi_startup();
155
156        return RTEMS_SUCCESSFUL;
157}
Note: See TracBrowser for help on using the repository browser.