Subversion Repositories HelenOS

Compare Revisions

Ignore whitespace Rev 3745 → Rev 4073

/branches/sparc/uspace/srv/fb/niagara.c
0,0 → 1,114
/*
* Copyright (c) 2006 Ondrej Palkovsky
* Copyright (c) 2008 Martin Decky
* Copyright (c) 2008 Pavel Rimsky
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* - Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* - Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* - The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
 
/** @defgroup niagarafb SGCN
* @brief userland driver of the Niagara console output
* @{
*/
/** @file
*/
 
#include <async.h>
#include <sysinfo.h>
#include <as.h>
#include <errno.h>
#include <stdio.h>
#include <ddi.h>
 
#include "serial_console.h"
#include "niagara.h"
 
#define WIDTH 80
#define HEIGHT 24
 
/**
* Virtual address mapped to the buffer shared with the kernel counterpart.
*/
static uintptr_t output_buffer_addr;
 
/*
* Kernel counterpart of the driver reads characters to be printed from here.
* Keep in sync with the definition from
* kernel/arch/sparc64/src/drivers/niagara.c.
*/
#define OUTPUT_BUFFER_SIZE ((PAGE_SIZE) - 2 * 8)
typedef volatile struct {
uint64_t read_ptr;
uint64_t write_ptr;
char data[OUTPUT_BUFFER_SIZE];
}
__attribute__ ((packed))
__attribute__ ((aligned(PAGE_SIZE)))
*output_buffer_t;
 
output_buffer_t output_buffer;
 
/**
* Pushes the character to the Niagara serial.
* @param c character to be pushed
*/
static void niagara_putc(char c)
{
while (output_buffer->write_ptr ==
(output_buffer->read_ptr + OUTPUT_BUFFER_SIZE - 1)
% OUTPUT_BUFFER_SIZE)
;
output_buffer->data[output_buffer->write_ptr] = (uint64_t) c;
output_buffer->write_ptr =
((output_buffer->write_ptr) + 1) % OUTPUT_BUFFER_SIZE;
}
 
/**
* Initializes the Niagara serial driver.
*/
int niagara_init(void)
{
output_buffer_addr = (uintptr_t) as_get_mappable_page(PAGE_SIZE);
int result = physmem_map(
(void *) sysinfo_value("niagara.outbuf.address"),
(void *) output_buffer_addr,
1, AS_AREA_READ | AS_AREA_WRITE);
 
if (result != 0) {
printf("Niagara: uspace driver couldn't map physical memory: %d\n",
result);
}
 
output_buffer = (output_buffer_t) output_buffer_addr;
 
serial_console_init(niagara_putc, WIDTH, HEIGHT);
async_set_client_connection(serial_client_connection);
return 0;
}
 
/**
* @}
*/
/branches/sparc/uspace/srv/fb/niagara.h
0,0 → 1,46
/*
* Copyright (c) 2008 Pavel Rimsky
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* - Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* - Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* - The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
 
/** @defgroup sgcnfb SGCN
* @brief userland driver of the Serengeti console output
* @{
*/
/** @file
*/
 
#ifndef FB_NIAGARA_H_
#define FB_NIAGARA_H_
 
int niagara_init(void);
 
#endif
 
/**
* @}
*/
/branches/sparc/uspace/srv/fb/main.c
40,6 → 40,7
#include "msim.h"
#include "ski.h"
#include "sgcn.h"
#include "niagara.h"
#include "main.h"
 
#define NAME "fb"
87,6 → 88,10
initialized = true;
}
#endif
if ((!initialized) && (sysinfo_value("fb.kind") == 5)) {
if (niagara_init() == 0)
initialized = true;
}
#ifdef SKI_ENABLED
if ((!initialized) && (sysinfo_value("fb") != true)) {
if (ski_init() == 0)
/branches/sparc/uspace/srv/fb/Makefile
74,6 → 74,7
endif
ifeq ($(ARCH), sparc64)
SOURCES += sgcn.c \
niagara.c \
serial_console.c
CFLAGS += -DSGCN_ENABLED
endif