viafb: remove superfluous register unlocking/locking
authorFlorian Tobias Schandinat <FlorianSchandinat@gmx.de>
Sun, 22 May 2011 23:40:46 +0000 (23:40 +0000)
committerFlorian Tobias Schandinat <FlorianSchandinat@gmx.de>
Fri, 5 Aug 2011 12:47:06 +0000 (12:47 +0000)
The locking is done within the viafb_set_*_timing functions so there
is no need to do it here. Move a missing hardware reset into the
modesetting function.

Signed-off-by: Florian Tobias Schandinat <FlorianSchandinat@gmx.de>
drivers/video/via/hw.c
drivers/video/via/via_modesetting.c

index 52d41f0..8b4bdf5 100644 (file)
@@ -1507,18 +1507,11 @@ void viafb_fill_crtc_timing(struct crt_mode_table *crt_table,
        crt_reg.ver_sync_end += crt_reg.ver_sync_start;
        h_addr = crt_reg.hor_addr;
        v_addr = crt_reg.ver_addr;
-       if (set_iga == IGA1) {
-               viafb_unlock_crt();
-               viafb_write_reg_mask(CR17, VIACR, 0x00, BIT7);
-       }
-
        if (set_iga == IGA1)
                via_set_primary_timing(&crt_reg);
        else if (set_iga == IGA2)
                via_set_secondary_timing(&crt_reg);
 
-       viafb_lock_crt();
-       viafb_write_reg_mask(CR17, VIACR, 0x80, BIT7);
        viafb_load_fetch_count_reg(h_addr, bpp_byte, set_iga);
 
        /* load FIFO */
index 016d457..0e431ae 100644 (file)
@@ -82,6 +82,10 @@ void via_set_primary_timing(const struct display_timing *timing)
 
        /* lock timing registers */
        via_write_reg_mask(VIACR, 0x11, 0x80, 0x80);
+
+       /* reset timing control */
+       via_write_reg_mask(VIACR, 0x17, 0x00, 0x80);
+       via_write_reg_mask(VIACR, 0x17, 0x80, 0x80);
 }
 
 void via_set_secondary_timing(const struct display_timing *timing)