162306a36Sopenharmony_ci/***********************license start*************** 262306a36Sopenharmony_ci * Author: Cavium Networks 362306a36Sopenharmony_ci * 462306a36Sopenharmony_ci * Contact: support@caviumnetworks.com 562306a36Sopenharmony_ci * This file is part of the OCTEON SDK 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * Copyright (c) 2003-2012 Cavium Networks 862306a36Sopenharmony_ci * 962306a36Sopenharmony_ci * This file is free software; you can redistribute it and/or modify 1062306a36Sopenharmony_ci * it under the terms of the GNU General Public License, Version 2, as 1162306a36Sopenharmony_ci * published by the Free Software Foundation. 1262306a36Sopenharmony_ci * 1362306a36Sopenharmony_ci * This file is distributed in the hope that it will be useful, but 1462306a36Sopenharmony_ci * AS-IS and WITHOUT ANY WARRANTY; without even the implied warranty 1562306a36Sopenharmony_ci * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, TITLE, or 1662306a36Sopenharmony_ci * NONINFRINGEMENT. See the GNU General Public License for more 1762306a36Sopenharmony_ci * details. 1862306a36Sopenharmony_ci * 1962306a36Sopenharmony_ci * You should have received a copy of the GNU General Public License 2062306a36Sopenharmony_ci * along with this file; if not, write to the Free Software 2162306a36Sopenharmony_ci * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA 2262306a36Sopenharmony_ci * or visit http://www.gnu.org/licenses/. 2362306a36Sopenharmony_ci * 2462306a36Sopenharmony_ci * This file may also be available under a different license from Cavium. 2562306a36Sopenharmony_ci * Contact Cavium Networks for more information 2662306a36Sopenharmony_ci ***********************license end**************************************/ 2762306a36Sopenharmony_ci 2862306a36Sopenharmony_ci#ifndef __CVMX_LED_DEFS_H__ 2962306a36Sopenharmony_ci#define __CVMX_LED_DEFS_H__ 3062306a36Sopenharmony_ci 3162306a36Sopenharmony_ci#define CVMX_LED_BLINK (CVMX_ADD_IO_SEG(0x0001180000001A48ull)) 3262306a36Sopenharmony_ci#define CVMX_LED_CLK_PHASE (CVMX_ADD_IO_SEG(0x0001180000001A08ull)) 3362306a36Sopenharmony_ci#define CVMX_LED_CYLON (CVMX_ADD_IO_SEG(0x0001180000001AF8ull)) 3462306a36Sopenharmony_ci#define CVMX_LED_DBG (CVMX_ADD_IO_SEG(0x0001180000001A18ull)) 3562306a36Sopenharmony_ci#define CVMX_LED_EN (CVMX_ADD_IO_SEG(0x0001180000001A00ull)) 3662306a36Sopenharmony_ci#define CVMX_LED_POLARITY (CVMX_ADD_IO_SEG(0x0001180000001A50ull)) 3762306a36Sopenharmony_ci#define CVMX_LED_PRT (CVMX_ADD_IO_SEG(0x0001180000001A10ull)) 3862306a36Sopenharmony_ci#define CVMX_LED_PRT_FMT (CVMX_ADD_IO_SEG(0x0001180000001A30ull)) 3962306a36Sopenharmony_ci#define CVMX_LED_PRT_STATUSX(offset) (CVMX_ADD_IO_SEG(0x0001180000001A80ull) + ((offset) & 7) * 8) 4062306a36Sopenharmony_ci#define CVMX_LED_UDD_CNTX(offset) (CVMX_ADD_IO_SEG(0x0001180000001A20ull) + ((offset) & 1) * 8) 4162306a36Sopenharmony_ci#define CVMX_LED_UDD_DATX(offset) (CVMX_ADD_IO_SEG(0x0001180000001A38ull) + ((offset) & 1) * 8) 4262306a36Sopenharmony_ci#define CVMX_LED_UDD_DAT_CLRX(offset) (CVMX_ADD_IO_SEG(0x0001180000001AC8ull) + ((offset) & 1) * 16) 4362306a36Sopenharmony_ci#define CVMX_LED_UDD_DAT_SETX(offset) (CVMX_ADD_IO_SEG(0x0001180000001AC0ull) + ((offset) & 1) * 16) 4462306a36Sopenharmony_ci 4562306a36Sopenharmony_ciunion cvmx_led_blink { 4662306a36Sopenharmony_ci uint64_t u64; 4762306a36Sopenharmony_ci struct cvmx_led_blink_s { 4862306a36Sopenharmony_ci#ifdef __BIG_ENDIAN_BITFIELD 4962306a36Sopenharmony_ci uint64_t reserved_8_63:56; 5062306a36Sopenharmony_ci uint64_t rate:8; 5162306a36Sopenharmony_ci#else 5262306a36Sopenharmony_ci uint64_t rate:8; 5362306a36Sopenharmony_ci uint64_t reserved_8_63:56; 5462306a36Sopenharmony_ci#endif 5562306a36Sopenharmony_ci } s; 5662306a36Sopenharmony_ci}; 5762306a36Sopenharmony_ci 5862306a36Sopenharmony_ciunion cvmx_led_clk_phase { 5962306a36Sopenharmony_ci uint64_t u64; 6062306a36Sopenharmony_ci struct cvmx_led_clk_phase_s { 6162306a36Sopenharmony_ci#ifdef __BIG_ENDIAN_BITFIELD 6262306a36Sopenharmony_ci uint64_t reserved_7_63:57; 6362306a36Sopenharmony_ci uint64_t phase:7; 6462306a36Sopenharmony_ci#else 6562306a36Sopenharmony_ci uint64_t phase:7; 6662306a36Sopenharmony_ci uint64_t reserved_7_63:57; 6762306a36Sopenharmony_ci#endif 6862306a36Sopenharmony_ci } s; 6962306a36Sopenharmony_ci}; 7062306a36Sopenharmony_ci 7162306a36Sopenharmony_ciunion cvmx_led_cylon { 7262306a36Sopenharmony_ci uint64_t u64; 7362306a36Sopenharmony_ci struct cvmx_led_cylon_s { 7462306a36Sopenharmony_ci#ifdef __BIG_ENDIAN_BITFIELD 7562306a36Sopenharmony_ci uint64_t reserved_16_63:48; 7662306a36Sopenharmony_ci uint64_t rate:16; 7762306a36Sopenharmony_ci#else 7862306a36Sopenharmony_ci uint64_t rate:16; 7962306a36Sopenharmony_ci uint64_t reserved_16_63:48; 8062306a36Sopenharmony_ci#endif 8162306a36Sopenharmony_ci } s; 8262306a36Sopenharmony_ci}; 8362306a36Sopenharmony_ci 8462306a36Sopenharmony_ciunion cvmx_led_dbg { 8562306a36Sopenharmony_ci uint64_t u64; 8662306a36Sopenharmony_ci struct cvmx_led_dbg_s { 8762306a36Sopenharmony_ci#ifdef __BIG_ENDIAN_BITFIELD 8862306a36Sopenharmony_ci uint64_t reserved_1_63:63; 8962306a36Sopenharmony_ci uint64_t dbg_en:1; 9062306a36Sopenharmony_ci#else 9162306a36Sopenharmony_ci uint64_t dbg_en:1; 9262306a36Sopenharmony_ci uint64_t reserved_1_63:63; 9362306a36Sopenharmony_ci#endif 9462306a36Sopenharmony_ci } s; 9562306a36Sopenharmony_ci}; 9662306a36Sopenharmony_ci 9762306a36Sopenharmony_ciunion cvmx_led_en { 9862306a36Sopenharmony_ci uint64_t u64; 9962306a36Sopenharmony_ci struct cvmx_led_en_s { 10062306a36Sopenharmony_ci#ifdef __BIG_ENDIAN_BITFIELD 10162306a36Sopenharmony_ci uint64_t reserved_1_63:63; 10262306a36Sopenharmony_ci uint64_t en:1; 10362306a36Sopenharmony_ci#else 10462306a36Sopenharmony_ci uint64_t en:1; 10562306a36Sopenharmony_ci uint64_t reserved_1_63:63; 10662306a36Sopenharmony_ci#endif 10762306a36Sopenharmony_ci } s; 10862306a36Sopenharmony_ci}; 10962306a36Sopenharmony_ci 11062306a36Sopenharmony_ciunion cvmx_led_polarity { 11162306a36Sopenharmony_ci uint64_t u64; 11262306a36Sopenharmony_ci struct cvmx_led_polarity_s { 11362306a36Sopenharmony_ci#ifdef __BIG_ENDIAN_BITFIELD 11462306a36Sopenharmony_ci uint64_t reserved_1_63:63; 11562306a36Sopenharmony_ci uint64_t polarity:1; 11662306a36Sopenharmony_ci#else 11762306a36Sopenharmony_ci uint64_t polarity:1; 11862306a36Sopenharmony_ci uint64_t reserved_1_63:63; 11962306a36Sopenharmony_ci#endif 12062306a36Sopenharmony_ci } s; 12162306a36Sopenharmony_ci}; 12262306a36Sopenharmony_ci 12362306a36Sopenharmony_ciunion cvmx_led_prt { 12462306a36Sopenharmony_ci uint64_t u64; 12562306a36Sopenharmony_ci struct cvmx_led_prt_s { 12662306a36Sopenharmony_ci#ifdef __BIG_ENDIAN_BITFIELD 12762306a36Sopenharmony_ci uint64_t reserved_8_63:56; 12862306a36Sopenharmony_ci uint64_t prt_en:8; 12962306a36Sopenharmony_ci#else 13062306a36Sopenharmony_ci uint64_t prt_en:8; 13162306a36Sopenharmony_ci uint64_t reserved_8_63:56; 13262306a36Sopenharmony_ci#endif 13362306a36Sopenharmony_ci } s; 13462306a36Sopenharmony_ci}; 13562306a36Sopenharmony_ci 13662306a36Sopenharmony_ciunion cvmx_led_prt_fmt { 13762306a36Sopenharmony_ci uint64_t u64; 13862306a36Sopenharmony_ci struct cvmx_led_prt_fmt_s { 13962306a36Sopenharmony_ci#ifdef __BIG_ENDIAN_BITFIELD 14062306a36Sopenharmony_ci uint64_t reserved_4_63:60; 14162306a36Sopenharmony_ci uint64_t format:4; 14262306a36Sopenharmony_ci#else 14362306a36Sopenharmony_ci uint64_t format:4; 14462306a36Sopenharmony_ci uint64_t reserved_4_63:60; 14562306a36Sopenharmony_ci#endif 14662306a36Sopenharmony_ci } s; 14762306a36Sopenharmony_ci}; 14862306a36Sopenharmony_ci 14962306a36Sopenharmony_ciunion cvmx_led_prt_statusx { 15062306a36Sopenharmony_ci uint64_t u64; 15162306a36Sopenharmony_ci struct cvmx_led_prt_statusx_s { 15262306a36Sopenharmony_ci#ifdef __BIG_ENDIAN_BITFIELD 15362306a36Sopenharmony_ci uint64_t reserved_6_63:58; 15462306a36Sopenharmony_ci uint64_t status:6; 15562306a36Sopenharmony_ci#else 15662306a36Sopenharmony_ci uint64_t status:6; 15762306a36Sopenharmony_ci uint64_t reserved_6_63:58; 15862306a36Sopenharmony_ci#endif 15962306a36Sopenharmony_ci } s; 16062306a36Sopenharmony_ci}; 16162306a36Sopenharmony_ci 16262306a36Sopenharmony_ciunion cvmx_led_udd_cntx { 16362306a36Sopenharmony_ci uint64_t u64; 16462306a36Sopenharmony_ci struct cvmx_led_udd_cntx_s { 16562306a36Sopenharmony_ci#ifdef __BIG_ENDIAN_BITFIELD 16662306a36Sopenharmony_ci uint64_t reserved_6_63:58; 16762306a36Sopenharmony_ci uint64_t cnt:6; 16862306a36Sopenharmony_ci#else 16962306a36Sopenharmony_ci uint64_t cnt:6; 17062306a36Sopenharmony_ci uint64_t reserved_6_63:58; 17162306a36Sopenharmony_ci#endif 17262306a36Sopenharmony_ci } s; 17362306a36Sopenharmony_ci}; 17462306a36Sopenharmony_ci 17562306a36Sopenharmony_ciunion cvmx_led_udd_datx { 17662306a36Sopenharmony_ci uint64_t u64; 17762306a36Sopenharmony_ci struct cvmx_led_udd_datx_s { 17862306a36Sopenharmony_ci#ifdef __BIG_ENDIAN_BITFIELD 17962306a36Sopenharmony_ci uint64_t reserved_32_63:32; 18062306a36Sopenharmony_ci uint64_t dat:32; 18162306a36Sopenharmony_ci#else 18262306a36Sopenharmony_ci uint64_t dat:32; 18362306a36Sopenharmony_ci uint64_t reserved_32_63:32; 18462306a36Sopenharmony_ci#endif 18562306a36Sopenharmony_ci } s; 18662306a36Sopenharmony_ci}; 18762306a36Sopenharmony_ci 18862306a36Sopenharmony_ciunion cvmx_led_udd_dat_clrx { 18962306a36Sopenharmony_ci uint64_t u64; 19062306a36Sopenharmony_ci struct cvmx_led_udd_dat_clrx_s { 19162306a36Sopenharmony_ci#ifdef __BIG_ENDIAN_BITFIELD 19262306a36Sopenharmony_ci uint64_t reserved_32_63:32; 19362306a36Sopenharmony_ci uint64_t clr:32; 19462306a36Sopenharmony_ci#else 19562306a36Sopenharmony_ci uint64_t clr:32; 19662306a36Sopenharmony_ci uint64_t reserved_32_63:32; 19762306a36Sopenharmony_ci#endif 19862306a36Sopenharmony_ci } s; 19962306a36Sopenharmony_ci}; 20062306a36Sopenharmony_ci 20162306a36Sopenharmony_ciunion cvmx_led_udd_dat_setx { 20262306a36Sopenharmony_ci uint64_t u64; 20362306a36Sopenharmony_ci struct cvmx_led_udd_dat_setx_s { 20462306a36Sopenharmony_ci#ifdef __BIG_ENDIAN_BITFIELD 20562306a36Sopenharmony_ci uint64_t reserved_32_63:32; 20662306a36Sopenharmony_ci uint64_t set:32; 20762306a36Sopenharmony_ci#else 20862306a36Sopenharmony_ci uint64_t set:32; 20962306a36Sopenharmony_ci uint64_t reserved_32_63:32; 21062306a36Sopenharmony_ci#endif 21162306a36Sopenharmony_ci } s; 21262306a36Sopenharmony_ci}; 21362306a36Sopenharmony_ci 21462306a36Sopenharmony_ci#endif 215