blob: 6129244d91daa873cbf2c25ff96edf359d33ff5b [file] [log] [blame]
/*
* Copyright (C) 2017 Amlogic, Inc. All rights reserved.
*
* 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.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; 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.
*
* Description:
*/
#ifndef DECODER_CPU_VER_INFO_H
#define DECODER_CPU_VER_INFO_H
#include <linux/amlogic/media/registers/cpu_version.h>
/* majoy chip id define */
#define MAJOY_ID_MASK (0x000000ff)
enum AM_MESON_CPU_MAJOR_ID {
AM_MESON_CPU_MAJOR_ID_M6 = 0x16,
AM_MESON_CPU_MAJOR_ID_M6TV = 0x17,
AM_MESON_CPU_MAJOR_ID_M6TVL = 0x18,
AM_MESON_CPU_MAJOR_ID_M8 = 0x19,
AM_MESON_CPU_MAJOR_ID_MTVD = 0x1A,
AM_MESON_CPU_MAJOR_ID_M8B = 0x1B,
AM_MESON_CPU_MAJOR_ID_MG9TV = 0x1C,
AM_MESON_CPU_MAJOR_ID_M8M2 = 0x1D,
AM_MESON_CPU_MAJOR_ID_UNUSE = 0x1E,
AM_MESON_CPU_MAJOR_ID_GXBB = 0x1F,
AM_MESON_CPU_MAJOR_ID_GXTVBB = 0x20,
AM_MESON_CPU_MAJOR_ID_GXL = 0x21,
AM_MESON_CPU_MAJOR_ID_GXM = 0x22,
AM_MESON_CPU_MAJOR_ID_TXL = 0x23,
AM_MESON_CPU_MAJOR_ID_TXLX = 0x24,
AM_MESON_CPU_MAJOR_ID_AXG = 0x25,
AM_MESON_CPU_MAJOR_ID_GXLX = 0x26,
AM_MESON_CPU_MAJOR_ID_TXHD = 0x27,
AM_MESON_CPU_MAJOR_ID_G12A = 0x28,
AM_MESON_CPU_MAJOR_ID_G12B = 0x29,
AM_MESON_CPU_MAJOR_ID_GXLX2 = 0x2a,
AM_MESON_CPU_MAJOR_ID_SM1 = 0x2b,
AM_MESON_CPU_MAJOR_ID_A1 = 0x2c,
AM_MESON_CPU_MAJOR_ID_RES_0x2d,
AM_MESON_CPU_MAJOR_ID_TL1 = 0x2e,
AM_MESON_CPU_MAJOR_ID_TM2 = 0x2f,
AM_MESON_CPU_MAJOR_ID_C1 = 0x30,
AM_MESON_CPU_MAJOR_ID_RES_0x31,
AM_MESON_CPU_MAJOR_ID_SC2 = 0x32,
AM_MESON_CPU_MAJOR_ID_C2 = 0x33,
AM_MESON_CPU_MAJOR_ID_T5 = 0x34,
AM_MESON_CPU_MAJOR_ID_T5D = 0x35,
AM_MESON_CPU_MAJOR_ID_T7 = 0x36,
AM_MESON_CPU_MAJOR_ID_S4 = 0x37,
AM_MESON_CPU_MAJOR_ID_T3 = 0x38,
AM_MESON_CPU_MAJOR_ID_P1 = 0x39,
AM_MESON_CPU_MAJOR_ID_S4D = 0x3a,
AM_MESON_CPU_MAJOR_ID_T5W = 0x3b,
AM_MESON_CPU_MAJOR_ID_MAX,
};
/* chips sub id define */
#define CHIP_REVA 0x0
#define CHIP_REVB 0x1
#define CHIP_REVC 0x2
#define CHIP_REVX 0x10
#define REVB_MASK (CHIP_REVB << 8)
#define REVC_MASK (CHIP_REVC << 8)
#define REVX_MASK (CHIP_REVX << 8)
#define SUB_ID_MASK (REVB_MASK | REVC_MASK | REVX_MASK)
#define AM_MESON_CPU_MINOR_ID_REVB_G12B (REVB_MASK | AM_MESON_CPU_MAJOR_ID_G12B)
#define AM_MESON_CPU_MINOR_ID_REVB_TM2 (REVB_MASK | AM_MESON_CPU_MAJOR_ID_TM2)
#define AM_MESON_CPU_MINOR_ID_S4_S805X2 (REVX_MASK | AM_MESON_CPU_MAJOR_ID_S4)
/* export functions */
enum AM_MESON_CPU_MAJOR_ID get_cpu_major_id(void);
bool is_cpu_meson_revb(void);
bool is_cpu_tm2_revb(void);
int get_cpu_sub_id(void);
bool is_cpu_s4_s805x2(void);
#endif