Path: blob/main/sys/arm/annapurna/alpine/alpine_serdes.h
39536 views
/*-1* Copyright (c) 2015,2016 Annapurna Labs Ltd. and affiliates2* All rights reserved.3*4* Developed by Semihalf.5*6* Redistribution and use in source and binary forms, with or without7* modification, are permitted provided that the following conditions8* are met:9* 1. Redistributions of source code must retain the above copyright10* notice, this list of conditions and the following disclaimer.11* 2. Redistributions in binary form must reproduce the above copyright12* notice, this list of conditions and the following disclaimer in the13* documentation and/or other materials provided with the distribution.14*15* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND16* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE17* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE18* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE19* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL20* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS21* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)22* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT23* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY24* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF25* SUCH DAMAGE.26*/2728#ifndef __ALPINE_SERDES_H__29#define __ALPINE_SERDES_H__3031/* SerDes ETH mode */32enum alpine_serdes_eth_mode {33ALPINE_SERDES_ETH_MODE_SGMII,34ALPINE_SERDES_ETH_MODE_KR,35};3637/*38* Get SerDes group regs base, to be used in relevant Alpine drivers.39* Valid group is 0..3.40* Returns virtual base address of the group regs base.41*/42void *alpine_serdes_resource_get(uint32_t group);4344/*45* Set SerDes ETH mode for an entire group, unless already set46* Valid group is 0..3.47* Returns 0 upon success.48*/49int alpine_serdes_eth_mode_set(uint32_t group,50enum alpine_serdes_eth_mode mode);5152/* Lock the all serdes group for using common registers */53void alpine_serdes_eth_group_lock(uint32_t group);5455/* Unlock the all serdes group for using common registers */56void alpine_serdes_eth_group_unlock(uint32_t group);5758#endif /* __ALPINE_SERDES_H__ */596061