368dd5acd1
Implement the Panasonic MN10300 AM34 CPU subarch and implement SMP support for MN10300. Also implement support for the MN2WS0060 processor and the ASB2364 evaluation board which are AM34 based. Signed-off-by: Akira Takeuchi <takeuchi.akr@jp.panasonic.com> Signed-off-by: Kiyoshi Owada <owada.kiyoshi@jp.panasonic.com> Signed-off-by: David Howells <dhowells@redhat.com>
99 lines
2.6 KiB
C
99 lines
2.6 KiB
C
/* leds.c: ASB2364 peripheral 7seg LEDs x4 support
|
|
*
|
|
* Copyright (C) 2002 Red Hat, Inc. All Rights Reserved.
|
|
* Written by David Howells (dhowells@redhat.com)
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; either version
|
|
* 2 of the License, or (at your option) any later version.
|
|
*/
|
|
|
|
#include <linux/kernel.h>
|
|
#include <linux/param.h>
|
|
#include <linux/init.h>
|
|
|
|
#include <asm/io.h>
|
|
#include <asm/processor.h>
|
|
#include <asm/intctl-regs.h>
|
|
#include <asm/rtc-regs.h>
|
|
#include <unit/leds.h>
|
|
|
|
#if MN10300_USE_7SEGLEDS
|
|
static const u8 asb2364_led_hex_tbl[16] = {
|
|
0x80, 0xf2, 0x48, 0x60, 0x32, 0x24, 0x04, 0xf0,
|
|
0x00, 0x20, 0x10, 0x06, 0x8c, 0x42, 0x0c, 0x1c
|
|
};
|
|
|
|
static const u32 asb2364_led_chase_tbl[6] = {
|
|
~0x02020202, /* top - segA */
|
|
~0x04040404, /* right top - segB */
|
|
~0x08080808, /* right bottom - segC */
|
|
~0x10101010, /* bottom - segD */
|
|
~0x20202020, /* left bottom - segE */
|
|
~0x40404040, /* left top - segF */
|
|
};
|
|
|
|
static unsigned asb2364_led_chase;
|
|
|
|
void peripheral_leds7x4_display_dec(unsigned int val, unsigned int points)
|
|
{
|
|
u32 leds;
|
|
|
|
leds = asb2364_led_hex_tbl[(val/1000) % 10];
|
|
leds <<= 8;
|
|
leds |= asb2364_led_hex_tbl[(val/100) % 10];
|
|
leds <<= 8;
|
|
leds |= asb2364_led_hex_tbl[(val/10) % 10];
|
|
leds <<= 8;
|
|
leds |= asb2364_led_hex_tbl[val % 10];
|
|
leds |= points^0x01010101;
|
|
|
|
ASB2364_7SEGLEDS = leds;
|
|
}
|
|
|
|
void peripheral_leds7x4_display_hex(unsigned int val, unsigned int points)
|
|
{
|
|
u32 leds;
|
|
|
|
leds = asb2364_led_hex_tbl[(val/1000) % 10];
|
|
leds <<= 8;
|
|
leds |= asb2364_led_hex_tbl[(val/100) % 10];
|
|
leds <<= 8;
|
|
leds |= asb2364_led_hex_tbl[(val/10) % 10];
|
|
leds <<= 8;
|
|
leds |= asb2364_led_hex_tbl[val % 10];
|
|
leds |= points^0x01010101;
|
|
|
|
ASB2364_7SEGLEDS = leds;
|
|
}
|
|
|
|
/* display triple horizontal bar and exception code */
|
|
void peripheral_leds_display_exception(enum exception_code code)
|
|
{
|
|
u32 leds;
|
|
|
|
leds = asb2364_led_hex_tbl[(code/0x100) % 0x10];
|
|
leds <<= 8;
|
|
leds |= asb2364_led_hex_tbl[(code/0x10) % 0x10];
|
|
leds <<= 8;
|
|
leds |= asb2364_led_hex_tbl[code % 0x10];
|
|
leds |= 0x6d010101;
|
|
|
|
ASB2364_7SEGLEDS = leds;
|
|
}
|
|
|
|
void peripheral_leds_led_chase(void)
|
|
{
|
|
ASB2364_7SEGLEDS = asb2364_led_chase_tbl[asb2364_led_chase];
|
|
asb2364_led_chase++;
|
|
if (asb2364_led_chase >= 6)
|
|
asb2364_led_chase = 0;
|
|
}
|
|
#else /* MN10300_USE_7SEGLEDS */
|
|
void peripheral_leds7x4_display_dec(unsigned int val, unsigned int points) { }
|
|
void peripheral_leds7x4_display_hex(unsigned int val, unsigned int points) { }
|
|
void peripheral_leds_display_exception(enum exception_code code) { }
|
|
void peripheral_leds_led_chase(void) { }
|
|
#endif /* MN10300_USE_7SEGLEDS */
|