Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/arm/allwinner Turn off more bits when turning off t...
details: https://anonhg.NetBSD.org/src/rev/0c75d06d69cd
branches: trunk
changeset: 811880:0c75d06d69cd
user: bouyer <bouyer%NetBSD.org@localhost>
date: Fri Nov 20 18:32:13 2015 +0000
description:
Turn off more bits when turning off the display. Saves about 50ma on the
5V supply.
diffstat:
sys/arch/arm/allwinner/awin_tcon.c | 40 ++++++++++++++++++++++++++++++-------
1 files changed, 32 insertions(+), 8 deletions(-)
diffs (78 lines):
diff -r aa0418733bd1 -r 0c75d06d69cd sys/arch/arm/allwinner/awin_tcon.c
--- a/sys/arch/arm/allwinner/awin_tcon.c Fri Nov 20 17:02:58 2015 +0000
+++ b/sys/arch/arm/allwinner/awin_tcon.c Fri Nov 20 18:32:13 2015 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: awin_tcon.c,v 1.10 2015/11/19 18:48:22 bouyer Exp $ */
+/* $NetBSD: awin_tcon.c,v 1.11 2015/11/20 18:32:13 bouyer Exp $ */
/*-
* Copyright (c) 2014 Jared D. McNeill <jmcneill%invisible.ca@localhost>
@@ -29,7 +29,7 @@
#include "opt_allwinner.h"
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: awin_tcon.c,v 1.10 2015/11/19 18:48:22 bouyer Exp $");
+__KERNEL_RCSID(0, "$NetBSD: awin_tcon.c,v 1.11 2015/11/20 18:32:13 bouyer Exp $");
#include <sys/param.h>
#include <sys/bus.h>
@@ -555,13 +555,29 @@
awin_debe_enable(device_unit(sc->sc_dev), enable);
delay(20000);
- val = TCON_READ(sc, AWIN_TCON_GCTL_REG);
if (enable) {
+ val = TCON_READ(sc, AWIN_TCON_GCTL_REG);
val |= AWIN_TCON_GCTL_EN;
+ TCON_WRITE(sc, AWIN_TCON_GCTL_REG, val);
+ val = TCON_READ(sc, AWIN_TCON0_CTL_REG);
+ val |= AWIN_TCONx_CTL_EN;
+ TCON_WRITE(sc, AWIN_TCON0_CTL_REG, val);
+ val = TCON_READ(sc, AWIN_TCON0_LVDS_IF_REG);
+ val |= AWIN_TCON0_LVDS_IF_EN;
+ TCON_WRITE(sc, AWIN_TCON0_LVDS_IF_REG, val);
+ TCON_WRITE(sc, AWIN_TCON0_IO_TRI_REG, 0);
} else {
+ TCON_WRITE(sc, AWIN_TCON0_IO_TRI_REG, 0xffffffff);
+ val = TCON_READ(sc, AWIN_TCON0_LVDS_IF_REG);
+ val &= ~AWIN_TCON0_LVDS_IF_EN;
+ TCON_WRITE(sc, AWIN_TCON0_LVDS_IF_REG, val);
+ val = TCON_READ(sc, AWIN_TCON0_CTL_REG);
+ val &= ~AWIN_TCONx_CTL_EN;
+ TCON_WRITE(sc, AWIN_TCON0_CTL_REG, val);
+ val = TCON_READ(sc, AWIN_TCON_GCTL_REG);
val &= ~AWIN_TCON_GCTL_EN;
+ TCON_WRITE(sc, AWIN_TCON_GCTL_REG, val);
}
- TCON_WRITE(sc, AWIN_TCON_GCTL_REG, val);
}
void
@@ -581,15 +597,23 @@
awin_debe_enable(device_unit(sc->sc_dev), enable);
delay(20000);
- val = TCON_READ(sc, AWIN_TCON_GCTL_REG);
if (enable) {
+ val = TCON_READ(sc, AWIN_TCON_GCTL_REG);
val |= AWIN_TCON_GCTL_EN;
+ TCON_WRITE(sc, AWIN_TCON_GCTL_REG, val);
+ val = TCON_READ(sc, AWIN_TCON1_CTL_REG);
+ val |= AWIN_TCONx_CTL_EN;
+ TCON_WRITE(sc, AWIN_TCON1_CTL_REG, val);
+ TCON_WRITE(sc, AWIN_TCON1_IO_TRI_REG, 0);
} else {
+ TCON_WRITE(sc, AWIN_TCON1_IO_TRI_REG, 0xffffffff);
+ val = TCON_READ(sc, AWIN_TCON1_CTL_REG);
+ val &= ~AWIN_TCONx_CTL_EN;
+ TCON_WRITE(sc, AWIN_TCON1_CTL_REG, val);
+ val = TCON_READ(sc, AWIN_TCON_GCTL_REG);
val &= ~AWIN_TCON_GCTL_EN;
+ TCON_WRITE(sc, AWIN_TCON_GCTL_REG, val);
}
- TCON_WRITE(sc, AWIN_TCON_GCTL_REG, val);
-
- TCON_WRITE(sc, AWIN_TCON1_IO_TRI_REG, 0);
KASSERT(tcon_mux_inited);
val = bus_space_read_4(sc->sc_bst, tcon_mux_bsh, 0);
Home |
Main Index |
Thread Index |
Old Index