Subversion Repositories HelenOS

Rev

Rev 4296 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 4296 Rev 4420
Line 33... Line 33...
33
 *  @brief ARM32 architecture specific functions.
33
 *  @brief ARM32 architecture specific functions.
34
 */
34
 */
35
 
35
 
36
#include <arch.h>
36
#include <arch.h>
37
#include <config.h>
37
#include <config.h>
38
#include <arch/console.h>
-
 
39
#include <genarch/fb/fb.h>
38
#include <genarch/fb/fb.h>
40
#include <genarch/fb/visuals.h>
39
#include <genarch/fb/visuals.h>
41
#include <genarch/drivers/dsrln/dsrlnin.h>
40
#include <genarch/drivers/dsrln/dsrlnin.h>
42
#include <genarch/drivers/dsrln/dsrlnout.h>
41
#include <genarch/drivers/dsrln/dsrlnout.h>
43
#include <genarch/srln/srln.h>
42
#include <genarch/srln/srln.h>
44
#include <sysinfo/sysinfo.h>
43
#include <sysinfo/sysinfo.h>
-
 
44
#include <console/console.h>
45
#include <ddi/irq.h>
45
#include <ddi/irq.h>
46
#include <arch/drivers/gxemul.h>
46
#include <arch/drivers/gxemul.h>
47
#include <print.h>
47
#include <print.h>
48
#include <config.h>
48
#include <config.h>
49
#include <interrupt.h>
49
#include <interrupt.h>
Line 127... Line 127...
127
void arch_post_smp_init(void)
127
void arch_post_smp_init(void)
128
{
128
{
129
#ifdef CONFIG_ARM_KBD
129
#ifdef CONFIG_ARM_KBD
130
    /*
130
    /*
131
     * Initialize the GXemul keyboard port. Then initialize the serial line
131
     * Initialize the GXemul keyboard port. Then initialize the serial line
132
     * module and connect it to the GXemul keyboard. Enable keyboard interrupts.
132
     * module and connect it to the GXemul keyboard.
133
     */
133
     */
-
 
134
    dsrlnin_instance_t *dsrlnin_instance
134
    indev_t *kbrdin = dsrlnin_init((dsrlnin_t *) gxemul_kbd, GXEMUL_KBD_IRQ);
135
        = dsrlnin_init((dsrlnin_t *) gxemul_kbd, GXEMUL_KBD_IRQ);
135
    if (kbrdin)
136
    if (dsrlnin_instance) {
-
 
137
        srln_instance_t *srln_instance = srln_init();
136
        srln_init(kbrdin);
138
        if (srln_instance) {
-
 
139
            indev_t *sink = stdin_wire();
-
 
140
            indev_t *srln = srln_wire(srln_instance, sink);
-
 
141
            dsrlnin_wire(dsrlnin_instance, srln);
-
 
142
        }
-
 
143
    }
137
   
144
   
138
    /*
145
    /*
139
     * This is the necessary evil until the userspace driver is entirely
146
     * This is the necessary evil until the userspace driver is entirely
140
     * self-sufficient.
147
     * self-sufficient.
141
     */
148
     */
Line 199... Line 206...
199
void *arch_construct_function(fncptr_t *fptr, void *addr, void *caller)
206
void *arch_construct_function(fncptr_t *fptr, void *addr, void *caller)
200
{
207
{
201
    return addr;
208
    return addr;
202
}
209
}
203
 
210
 
-
 
211
/** Acquire console back for kernel. */
-
 
212
void arch_grab_console(void)
-
 
213
{
-
 
214
#ifdef CONFIG_FB
-
 
215
    fb_redraw();
-
 
216
#endif
-
 
217
}
-
 
218
 
-
 
219
/** Return console to userspace. */
-
 
220
void arch_release_console(void)
-
 
221
{
-
 
222
}
-
 
223
 
204
/** @}
224
/** @}
205
 */
225
 */