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

55-freebsd-126-freebsd-12
Last change on this file since 34ff390 was 097ccba, checked in by Sichen Zhao <1473996754@…>, on 08/01/17 at 07:21:32

Enable the WEP encrypted WiFi?.

Now rtems can connnect WiFi? via WEP on rtl8188eu chip.

  • Property mode set to 100644
File size: 4.7 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 <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 <sys/lock.h>
49#include <sys/mutex.h>
50#include <sys/proc.h>
51#include <sys/stat.h>
52#include <sys/kbio.h>
53
54#include <dev/kbd/kbdreg.h>
55
56#include <net80211/ieee80211_freebsd.h>
57
58#include <rtems/bsd/bsd.h>
59
60SYSINIT_REFERENCE(configure1);
61SYSINIT_REFERENCE(module);
62SYSINIT_REFERENCE(kobj);
63SYSINIT_REFERENCE(linker_kernel);
64SYSINIT_MODULE_REFERENCE(rootbus);
65SYSINIT_DRIVER_REFERENCE(nexus, root);
66
67RTEMS_BSD_DEFINE_SET(kbddriver_set, const keyboard_driver_t *);
68RTEMS_BSD_DEFINE_SET(modmetadata_set, struct mod_metadata *);
69RTEMS_BSD_DEFINE_SET(ieee80211_ioctl_getset, ieee80211_ioctl_getfunc *);
70RTEMS_BSD_DEFINE_SET(ieee80211_ioctl_setset, ieee80211_ioctl_setfunc *);
71typedef void (*ratectl_modevent)(int);
72RTEMS_BSD_DEFINE_SET(ratectl_set, ratectl_modevent);
73typedef void (*scanner_modevent)(int);
74RTEMS_BSD_DEFINE_SET(scanner_set, scanner_modevent);
75typedef void (*crypto_modevent)(int);
76RTEMS_BSD_DEFINE_SET(crypto_set, crypto_modevent);
77RTEMS_BSD_DEFINE_SET(sysctl_set, struct sysctl_oid *);
78
79RTEMS_BSD_DEFINE_RWSET(sysinit_set, struct sysinit *);
80
81/* In FreeBSD this is a local function */
82void mi_startup(void);
83
84int hz;
85int tick;
86sbintime_t tick_sbt;
87struct bintime bt_timethreshold;
88struct bintime bt_tickthreshold;
89sbintime_t sbt_timethreshold;
90sbintime_t sbt_tickthreshold;
91struct bintime tc_tick_bt;
92sbintime_t tc_tick_sbt;
93int tc_precexp;
94int maxusers;     /* base tunable */
95
96static SYSCTL_NODE(_kern, OID_AUTO, smp, CTLFLAG_RD|CTLFLAG_CAPRD, NULL,
97    "Kernel SMP");
98
99static int maxid_maxcpus;
100
101SYSCTL_INT(_kern_smp, OID_AUTO, maxid, CTLFLAG_RD|CTLFLAG_CAPRD,
102    &maxid_maxcpus, 0, "Max CPU ID.");
103
104SYSCTL_INT(_kern_smp, OID_AUTO, maxcpus, CTLFLAG_RD|CTLFLAG_CAPRD,
105    &maxid_maxcpus, 0, "Max number of CPUs that the system was compiled for.");
106
107#undef _bsd_ticks
108
109RTEMS_STATIC_ASSERT(sizeof(int) == sizeof(int32_t), ticks);
110
111volatile uint32_t _Watchdog_Ticks_since_boot;
112
113extern volatile int32_t _bsd_ticks
114    __attribute__ ((__alias__("_Watchdog_Ticks_since_boot")));
115
116__attribute__((__weak__)) void _arc4random_getentropy_fail(void)
117{
118
119}
120
121__attribute__((__weak__)) int getentropy(void *buf, size_t n)
122{
123
124        memset(buf, 0, n);
125        return (0);
126}
127
128rtems_status_code
129rtems_bsd_initialize(void)
130{
131        static const char name[] = "TIME";
132        rtems_status_code sc;
133
134        hz = (int) rtems_clock_get_ticks_per_second();
135        tick = 1000000 / hz;
136        tick_sbt = SBT_1S / hz;
137        FREQ2BT(hz, &tc_tick_bt);
138        tc_tick_sbt = bttosbt(tc_tick_bt);
139        tc_precexp = 31;
140        bt_timethreshold.sec = INT_MAX;
141        bt_timethreshold.frac = ~(uint64_t)0;
142        bt_tickthreshold = bt_timethreshold;
143        sbt_timethreshold = bttosbt(bt_timethreshold);
144        sbt_tickthreshold = bttosbt(bt_tickthreshold);
145        maxusers = 1;
146        maxid_maxcpus = (int) rtems_get_processor_count();
147
148        mkdir("/etc", S_IRWXU | S_IRWXG | S_IRWXO);
149
150        sc =  rtems_timer_initiate_server(
151                rtems_bsd_get_task_priority(name),
152                rtems_bsd_get_task_stack_size(name),
153                RTEMS_DEFAULT_ATTRIBUTES
154        );
155        if (sc != RTEMS_SUCCESSFUL) {
156                return RTEMS_UNSATISFIED;
157        }
158
159        mutex_init();
160        mi_startup();
161
162        return RTEMS_SUCCESSFUL;
163}
Note: See TracBrowser for help on using the repository browser.