Path: blob/master/arch/arm/mach-omap2/clockdomains81xx_data.c
26295 views
// SPDX-License-Identifier: GPL-2.0-only1/*2* TI81XX Clock Domain data.3*4* Copyright (C) 2010 Texas Instruments, Inc. - https://www.ti.com/5* Copyright (C) 2013 SKTB SKiT, http://www.skitlab.ru/6*/78#ifndef __ARCH_ARM_MACH_OMAP2_CLOCKDOMAINS_81XX_H9#define __ARCH_ARM_MACH_OMAP2_CLOCKDOMAINS_81XX_H1011#include <linux/kernel.h>12#include <linux/io.h>1314#include "clockdomain.h"15#include "cm81xx.h"1617/*18* Note that 814x seems to have HWSUP_SWSUP for many clockdomains19* while 816x does not. According to the TRM, 816x only has HWSUP20* for ALWON_L3_FAST. Also note that the TI tree clockdomains81xx.h21* seems to have the related ifdef the wrong way around claiming22* 816x supports HWSUP while 814x does not. For now, we only set23* HWSUP for ALWON_L3_FAST as that seems to be supported for both24* dm814x and dm816x.25*/2627/* Common for 81xx */2829static struct clockdomain alwon_l3_slow_81xx_clkdm = {30.name = "alwon_l3s_clkdm",31.pwrdm = { .name = "alwon_pwrdm" },32.cm_inst = TI81XX_CM_ALWON_MOD,33.clkdm_offs = TI81XX_CM_ALWON_L3_SLOW_CLKDM,34.flags = CLKDM_CAN_SWSUP,35};3637static struct clockdomain alwon_l3_med_81xx_clkdm = {38.name = "alwon_l3_med_clkdm",39.pwrdm = { .name = "alwon_pwrdm" },40.cm_inst = TI81XX_CM_ALWON_MOD,41.clkdm_offs = TI81XX_CM_ALWON_L3_MED_CLKDM,42.flags = CLKDM_CAN_SWSUP,43};4445static struct clockdomain alwon_l3_fast_81xx_clkdm = {46.name = "alwon_l3_fast_clkdm",47.pwrdm = { .name = "alwon_pwrdm" },48.cm_inst = TI81XX_CM_ALWON_MOD,49.clkdm_offs = TI81XX_CM_ALWON_L3_FAST_CLKDM,50.flags = CLKDM_CAN_HWSUP_SWSUP,51};5253static struct clockdomain alwon_ethernet_81xx_clkdm = {54.name = "alwon_ethernet_clkdm",55.pwrdm = { .name = "alwon_pwrdm" },56.cm_inst = TI81XX_CM_ALWON_MOD,57.clkdm_offs = TI81XX_CM_ETHERNET_CLKDM,58.flags = CLKDM_CAN_SWSUP,59};6061static struct clockdomain mmu_81xx_clkdm = {62.name = "mmu_clkdm",63.pwrdm = { .name = "alwon_pwrdm" },64.cm_inst = TI81XX_CM_ALWON_MOD,65.clkdm_offs = TI81XX_CM_MMU_CLKDM,66.flags = CLKDM_CAN_SWSUP,67};6869static struct clockdomain mmu_cfg_81xx_clkdm = {70.name = "mmu_cfg_clkdm",71.pwrdm = { .name = "alwon_pwrdm" },72.cm_inst = TI81XX_CM_ALWON_MOD,73.clkdm_offs = TI81XX_CM_MMUCFG_CLKDM,74.flags = CLKDM_CAN_SWSUP,75};7677static struct clockdomain default_l3_slow_81xx_clkdm = {78.name = "default_l3_slow_clkdm",79.pwrdm = { .name = "default_pwrdm" },80.cm_inst = TI81XX_CM_DEFAULT_MOD,81.clkdm_offs = TI816X_CM_DEFAULT_L3_SLOW_CLKDM,82.flags = CLKDM_CAN_SWSUP,83};8485static struct clockdomain default_sata_81xx_clkdm = {86.name = "default_clkdm",87.pwrdm = { .name = "default_pwrdm" },88.cm_inst = TI81XX_CM_DEFAULT_MOD,89.clkdm_offs = TI816X_CM_DEFAULT_SATA_CLKDM,90.flags = CLKDM_CAN_SWSUP,91};9293/* 816x only */9495static struct clockdomain alwon_mpu_816x_clkdm = {96.name = "alwon_mpu_clkdm",97.pwrdm = { .name = "alwon_pwrdm" },98.cm_inst = TI81XX_CM_ALWON_MOD,99.clkdm_offs = TI81XX_CM_ALWON_MPU_CLKDM,100.flags = CLKDM_CAN_SWSUP,101};102103static struct clockdomain active_gem_816x_clkdm = {104.name = "active_gem_clkdm",105.pwrdm = { .name = "active_pwrdm" },106.cm_inst = TI81XX_CM_ACTIVE_MOD,107.clkdm_offs = TI816X_CM_ACTIVE_GEM_CLKDM,108.flags = CLKDM_CAN_SWSUP,109};110111static struct clockdomain ivahd0_816x_clkdm = {112.name = "ivahd0_clkdm",113.pwrdm = { .name = "ivahd0_pwrdm" },114.cm_inst = TI816X_CM_IVAHD0_MOD,115.clkdm_offs = TI816X_CM_IVAHD0_CLKDM,116.flags = CLKDM_CAN_SWSUP,117};118119static struct clockdomain ivahd1_816x_clkdm = {120.name = "ivahd1_clkdm",121.pwrdm = { .name = "ivahd1_pwrdm" },122.cm_inst = TI816X_CM_IVAHD1_MOD,123.clkdm_offs = TI816X_CM_IVAHD1_CLKDM,124.flags = CLKDM_CAN_SWSUP,125};126127static struct clockdomain ivahd2_816x_clkdm = {128.name = "ivahd2_clkdm",129.pwrdm = { .name = "ivahd2_pwrdm" },130.cm_inst = TI816X_CM_IVAHD2_MOD,131.clkdm_offs = TI816X_CM_IVAHD2_CLKDM,132.flags = CLKDM_CAN_SWSUP,133};134135static struct clockdomain sgx_816x_clkdm = {136.name = "sgx_clkdm",137.pwrdm = { .name = "sgx_pwrdm" },138.cm_inst = TI81XX_CM_SGX_MOD,139.clkdm_offs = TI816X_CM_SGX_CLKDM,140.flags = CLKDM_CAN_SWSUP,141};142143static struct clockdomain default_l3_med_816x_clkdm = {144.name = "default_l3_med_clkdm",145.pwrdm = { .name = "default_pwrdm" },146.cm_inst = TI81XX_CM_DEFAULT_MOD,147.clkdm_offs = TI816X_CM_DEFAULT_L3_MED_CLKDM,148.flags = CLKDM_CAN_SWSUP,149};150151static struct clockdomain default_ducati_816x_clkdm = {152.name = "default_ducati_clkdm",153.pwrdm = { .name = "default_pwrdm" },154.cm_inst = TI81XX_CM_DEFAULT_MOD,155.clkdm_offs = TI816X_CM_DEFAULT_DUCATI_CLKDM,156.flags = CLKDM_CAN_SWSUP,157};158159static struct clockdomain default_pci_816x_clkdm = {160.name = "default_pci_clkdm",161.pwrdm = { .name = "default_pwrdm" },162.cm_inst = TI81XX_CM_DEFAULT_MOD,163.clkdm_offs = TI816X_CM_DEFAULT_PCI_CLKDM,164.flags = CLKDM_CAN_SWSUP,165};166167static struct clockdomain *clockdomains_ti814x[] __initdata = {168&alwon_l3_slow_81xx_clkdm,169&alwon_l3_med_81xx_clkdm,170&alwon_l3_fast_81xx_clkdm,171&alwon_ethernet_81xx_clkdm,172&mmu_81xx_clkdm,173&mmu_cfg_81xx_clkdm,174&default_l3_slow_81xx_clkdm,175&default_sata_81xx_clkdm,176NULL,177};178179void __init ti814x_clockdomains_init(void)180{181clkdm_register_platform_funcs(&am33xx_clkdm_operations);182clkdm_register_clkdms(clockdomains_ti814x);183clkdm_complete_init();184}185186static struct clockdomain *clockdomains_ti816x[] __initdata = {187&alwon_mpu_816x_clkdm,188&alwon_l3_slow_81xx_clkdm,189&alwon_l3_med_81xx_clkdm,190&alwon_l3_fast_81xx_clkdm,191&alwon_ethernet_81xx_clkdm,192&mmu_81xx_clkdm,193&mmu_cfg_81xx_clkdm,194&active_gem_816x_clkdm,195&ivahd0_816x_clkdm,196&ivahd1_816x_clkdm,197&ivahd2_816x_clkdm,198&sgx_816x_clkdm,199&default_l3_med_816x_clkdm,200&default_ducati_816x_clkdm,201&default_pci_816x_clkdm,202&default_l3_slow_81xx_clkdm,203&default_sata_81xx_clkdm,204NULL,205};206207void __init ti816x_clockdomains_init(void)208{209clkdm_register_platform_funcs(&am33xx_clkdm_operations);210clkdm_register_clkdms(clockdomains_ti816x);211clkdm_complete_init();212}213#endif214215216