cregit-Linux how code gets into the kernel

Release 4.11 drivers/video/fbdev/via/via_clock.c

/*
 * Copyright 1998-2008 VIA Technologies, Inc. All Rights Reserved.
 * Copyright 2001-2008 S3 Graphics, Inc. All Rights Reserved.
 * Copyright 2011 Florian Tobias Schandinat <FlorianSchandinat@gmx.de>
 *
 * 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, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTIES OR REPRESENTATIONS; without even
 * the implied warranty of MERCHANTABILITY or FITNESS FOR
 * A PARTICULAR PURPOSE.See the GNU General Public License
 * for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc.,
 * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
 */
/*
 * clock and PLL management functions
 */

#include <linux/kernel.h>
#include <linux/via-core.h>
#include <asm/olpc.h>
#include "via_clock.h"
#include "global.h"
#include "debug.h"


static const char *via_slap = "Please slap VIA Technologies to motivate them "
	"releasing full documentation for your platform!\n";


static inline u32 cle266_encode_pll(struct via_pll_config pll) { return (pll.multiplier << 8) | (pll.rshift << 6) | pll.divisor; }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat32100.00%1100.00%
Total32100.00%1100.00%


static inline u32 k800_encode_pll(struct via_pll_config pll) { return ((pll.divisor - 2) << 16) | (pll.rshift << 10) | (pll.multiplier - 2); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat40100.00%1100.00%
Total40100.00%1100.00%


static inline u32 vx855_encode_pll(struct via_pll_config pll) { return (pll.divisor << 16) | (pll.rshift << 10) | pll.multiplier; }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat32100.00%1100.00%
Total32100.00%1100.00%


static inline void cle266_set_primary_pll_encoded(u32 data) { via_write_reg_mask(VIASR, 0x40, 0x02, 0x02); /* enable reset */ via_write_reg(VIASR, 0x46, data & 0xFF); via_write_reg(VIASR, 0x47, (data >> 8) & 0xFF); via_write_reg_mask(VIASR, 0x40, 0x00, 0x02); /* disable reset */ }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat60100.00%1100.00%
Total60100.00%1100.00%


static inline void k800_set_primary_pll_encoded(u32 data) { via_write_reg_mask(VIASR, 0x40, 0x02, 0x02); /* enable reset */ via_write_reg(VIASR, 0x44, data & 0xFF); via_write_reg(VIASR, 0x45, (data >> 8) & 0xFF); via_write_reg(VIASR, 0x46, (data >> 16) & 0xFF); via_write_reg_mask(VIASR, 0x40, 0x00, 0x02); /* disable reset */ }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat75100.00%1100.00%
Total75100.00%1100.00%


static inline void cle266_set_secondary_pll_encoded(u32 data) { via_write_reg_mask(VIASR, 0x40, 0x04, 0x04); /* enable reset */ via_write_reg(VIASR, 0x44, data & 0xFF); via_write_reg(VIASR, 0x45, (data >> 8) & 0xFF); via_write_reg_mask(VIASR, 0x40, 0x00, 0x04); /* disable reset */ }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat60100.00%1100.00%
Total60100.00%1100.00%


static inline void k800_set_secondary_pll_encoded(u32 data) { via_write_reg_mask(VIASR, 0x40, 0x04, 0x04); /* enable reset */ via_write_reg(VIASR, 0x4A, data & 0xFF); via_write_reg(VIASR, 0x4B, (data >> 8) & 0xFF); via_write_reg(VIASR, 0x4C, (data >> 16) & 0xFF); via_write_reg_mask(VIASR, 0x40, 0x00, 0x04); /* disable reset */ }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat75100.00%1100.00%
Total75100.00%1100.00%


static inline void set_engine_pll_encoded(u32 data) { via_write_reg_mask(VIASR, 0x40, 0x01, 0x01); /* enable reset */ via_write_reg(VIASR, 0x47, data & 0xFF); via_write_reg(VIASR, 0x48, (data >> 8) & 0xFF); via_write_reg(VIASR, 0x49, (data >> 16) & 0xFF); via_write_reg_mask(VIASR, 0x40, 0x00, 0x01); /* disable reset */ }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat75100.00%1100.00%
Total75100.00%1100.00%


static void cle266_set_primary_pll(struct via_pll_config config) { cle266_set_primary_pll_encoded(cle266_encode_pll(config)); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat18100.00%1100.00%
Total18100.00%1100.00%


static void k800_set_primary_pll(struct via_pll_config config) { k800_set_primary_pll_encoded(k800_encode_pll(config)); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat18100.00%1100.00%
Total18100.00%1100.00%


static void vx855_set_primary_pll(struct via_pll_config config) { k800_set_primary_pll_encoded(vx855_encode_pll(config)); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat18100.00%1100.00%
Total18100.00%1100.00%


static void cle266_set_secondary_pll(struct via_pll_config config) { cle266_set_secondary_pll_encoded(cle266_encode_pll(config)); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat18100.00%1100.00%
Total18100.00%1100.00%


static void k800_set_secondary_pll(struct via_pll_config config) { k800_set_secondary_pll_encoded(k800_encode_pll(config)); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat18100.00%1100.00%
Total18100.00%1100.00%


static void vx855_set_secondary_pll(struct via_pll_config config) { k800_set_secondary_pll_encoded(vx855_encode_pll(config)); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat18100.00%1100.00%
Total18100.00%1100.00%


static void k800_set_engine_pll(struct via_pll_config config) { set_engine_pll_encoded(k800_encode_pll(config)); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat18100.00%1100.00%
Total18100.00%1100.00%


static void vx855_set_engine_pll(struct via_pll_config config) { set_engine_pll_encoded(vx855_encode_pll(config)); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat18100.00%1100.00%
Total18100.00%1100.00%


static void set_primary_pll_state(u8 state) { u8 value; switch (state) { case VIA_STATE_ON: value = 0x20; break; case VIA_STATE_OFF: value = 0x00; break; default: return; } via_write_reg_mask(VIASR, 0x2D, value, 0x30); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat47100.00%1100.00%
Total47100.00%1100.00%


static void set_secondary_pll_state(u8 state) { u8 value; switch (state) { case VIA_STATE_ON: value = 0x08; break; case VIA_STATE_OFF: value = 0x00; break; default: return; } via_write_reg_mask(VIASR, 0x2D, value, 0x0C); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat47100.00%1100.00%
Total47100.00%1100.00%


static void set_engine_pll_state(u8 state) { u8 value; switch (state) { case VIA_STATE_ON: value = 0x02; break; case VIA_STATE_OFF: value = 0x00; break; default: return; } via_write_reg_mask(VIASR, 0x2D, value, 0x03); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat47100.00%1100.00%
Total47100.00%1100.00%


static void set_primary_clock_state(u8 state) { u8 value; switch (state) { case VIA_STATE_ON: value = 0x20; break; case VIA_STATE_OFF: value = 0x00; break; default: return; } via_write_reg_mask(VIASR, 0x1B, value, 0x30); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat47100.00%1100.00%
Total47100.00%1100.00%


static void set_secondary_clock_state(u8 state) { u8 value; switch (state) { case VIA_STATE_ON: value = 0x80; break; case VIA_STATE_OFF: value = 0x00; break; default: return; } via_write_reg_mask(VIASR, 0x1B, value, 0xC0); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat47100.00%1100.00%
Total47100.00%1100.00%


static inline u8 set_clock_source_common(enum via_clksrc source, bool use_pll) { u8 data = 0; switch (source) { case VIA_CLKSRC_X1: data = 0x00; break; case VIA_CLKSRC_TVX1: data = 0x02; break; case VIA_CLKSRC_TVPLL: data = 0x04; /* 0x06 should be the same */ break; case VIA_CLKSRC_DVP1TVCLKR: data = 0x0A; break; case VIA_CLKSRC_CAP0: data = 0xC; break; case VIA_CLKSRC_CAP1: data = 0x0E; break; } if (!use_pll) data |= 1; return data; }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat86100.00%1100.00%
Total86100.00%1100.00%


static void set_primary_clock_source(enum via_clksrc source, bool use_pll) { u8 data = set_clock_source_common(source, use_pll) << 4; via_write_reg_mask(VIACR, 0x6C, data, 0xF0); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat36100.00%1100.00%
Total36100.00%1100.00%


static void set_secondary_clock_source(enum via_clksrc source, bool use_pll) { u8 data = set_clock_source_common(source, use_pll); via_write_reg_mask(VIACR, 0x6C, data, 0x0F); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat34100.00%1100.00%
Total34100.00%1100.00%


static void dummy_set_clock_state(u8 state) { printk(KERN_INFO "Using undocumented set clock state.\n%s", via_slap); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat17100.00%1100.00%
Total17100.00%1100.00%


static void dummy_set_clock_source(enum via_clksrc source, bool use_pll) { printk(KERN_INFO "Using undocumented set clock source.\n%s", via_slap); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat21100.00%1100.00%
Total21100.00%1100.00%


static void dummy_set_pll_state(u8 state) { printk(KERN_INFO "Using undocumented set PLL state.\n%s", via_slap); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat17100.00%1100.00%
Total17100.00%1100.00%


static void dummy_set_pll(struct via_pll_config config) { printk(KERN_INFO "Using undocumented set PLL.\n%s", via_slap); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat18100.00%1100.00%
Total18100.00%1100.00%


static void noop_set_clock_state(u8 state) { }

Contributors

PersonTokensPropCommitsCommitProp
Daniel Drake8100.00%1100.00%
Total8100.00%1100.00%


void via_clock_init(struct via_clock *clock, int gfx_chip) { switch (gfx_chip) { case UNICHROME_CLE266: case UNICHROME_K400: clock->set_primary_clock_state = dummy_set_clock_state; clock->set_primary_clock_source = dummy_set_clock_source; clock->set_primary_pll_state = dummy_set_pll_state; clock->set_primary_pll = cle266_set_primary_pll; clock->set_secondary_clock_state = dummy_set_clock_state; clock->set_secondary_clock_source = dummy_set_clock_source; clock->set_secondary_pll_state = dummy_set_pll_state; clock->set_secondary_pll = cle266_set_secondary_pll; clock->set_engine_pll_state = dummy_set_pll_state; clock->set_engine_pll = dummy_set_pll; break; case UNICHROME_K800: case UNICHROME_PM800: case UNICHROME_CN700: case UNICHROME_CX700: case UNICHROME_CN750: case UNICHROME_K8M890: case UNICHROME_P4M890: case UNICHROME_P4M900: case UNICHROME_VX800: clock->set_primary_clock_state = set_primary_clock_state; clock->set_primary_clock_source = set_primary_clock_source; clock->set_primary_pll_state = set_primary_pll_state; clock->set_primary_pll = k800_set_primary_pll; clock->set_secondary_clock_state = set_secondary_clock_state; clock->set_secondary_clock_source = set_secondary_clock_source; clock->set_secondary_pll_state = set_secondary_pll_state; clock->set_secondary_pll = k800_set_secondary_pll; clock->set_engine_pll_state = set_engine_pll_state; clock->set_engine_pll = k800_set_engine_pll; break; case UNICHROME_VX855: case UNICHROME_VX900: clock->set_primary_clock_state = set_primary_clock_state; clock->set_primary_clock_source = set_primary_clock_source; clock->set_primary_pll_state = set_primary_pll_state; clock->set_primary_pll = vx855_set_primary_pll; clock->set_secondary_clock_state = set_secondary_clock_state; clock->set_secondary_clock_source = set_secondary_clock_source; clock->set_secondary_pll_state = set_secondary_pll_state; clock->set_secondary_pll = vx855_set_secondary_pll; clock->set_engine_pll_state = set_engine_pll_state; clock->set_engine_pll = vx855_set_engine_pll; break; } if (machine_is_olpc()) { /* The OLPC XO-1.5 cannot suspend/resume reliably if the * IGA1/IGA2 clocks are set as on or off (memory rot * occasionally happens during suspend under such * configurations). * * The only known stable scenario is to leave this bits as-is, * which in their default states are documented to enable the * clock only when it is needed. */ clock->set_primary_clock_state = noop_set_clock_state; clock->set_secondary_clock_state = noop_set_clock_state; } }

Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat24192.34%375.00%
Daniel Drake207.66%125.00%
Total261100.00%4100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
Florian Tobias Schandinat132397.64%360.00%
Daniel Drake312.29%120.00%
Lad Prabhakar10.07%120.00%
Total1355100.00%5100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.