1 /* 2 * Copyright 2009-2011 Freescale Semiconductor, Inc. 3 * 4 * See file CREDITS for list of people who contributed to this 5 * project. 6 * 7 * This program is free software; you can redistribute it and/or 8 * modify it under the terms of the GNU General Public License as 9 * published by the Free Software Foundation; either version 2 of 10 * the License, or (at your option) any later version. 11 * 12 * This program is distributed in the hope that it will be useful, 13 * but WITHOUT ANY WARRANTY; without even the implied warranty of 14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 15 * GNU General Public License for more details. 16 * 17 * You should have received a copy of the GNU General Public License 18 * along with this program; if not, write to the Free Software 19 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, 20 * MA 02111-1307 USA 21 */ 22 23 #ifndef _FSL_PORTALS_H_ 24 #define _FSL_PORTALS_H_ 25 26 /* entries must be in order and contiguous */ 27 enum fsl_dpaa_dev { 28 FSL_HW_PORTAL_SEC, 29 #ifdef CONFIG_SYS_DPAA_FMAN 30 FSL_HW_PORTAL_FMAN1, 31 #if (CONFIG_SYS_NUM_FMAN == 2) 32 FSL_HW_PORTAL_FMAN2, 33 #endif 34 #endif 35 FSL_HW_PORTAL_PME, 36 #ifdef CONFIG_SYS_FSL_RAID_ENGINE 37 FSL_HW_PORTAL_RAID_ENGINE, 38 #endif 39 #ifdef CONFIG_SYS_DPAA_RMAN 40 FSL_HW_PORTAL_RMAN, 41 #endif 42 #ifdef CONFIG_SYS_DPAA_DCE 43 FSL_HW_PORTAL_DCE, 44 #endif 45 46 }; 47 48 struct qportal_info { 49 u16 dliodn; /* DQRR LIODN */ 50 u16 fliodn; /* frame data LIODN */ 51 u16 liodn_offset; 52 u8 sdest; 53 }; 54 55 #define SET_QP_INFO(dqrr, fdata, off, dest) \ 56 { .dliodn = dqrr, .fliodn = fdata, .liodn_offset = off, .sdest = dest } 57 58 extern int get_dpaa_liodn(enum fsl_dpaa_dev dpaa_dev, 59 u32 *liodns, int liodn_offset); 60 extern void setup_portals(void); 61 extern void fdt_fixup_qportals(void *blob); 62 extern void fdt_fixup_bportals(void *blob); 63 64 extern struct qportal_info qp_info[]; 65 extern void fdt_portal(void *blob, const char *compat, const char *container, 66 u64 addr, u32 size); 67 68 #endif 69