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 #ifdef CONFIG_SYS_DPAA_PME 36 FSL_HW_PORTAL_PME, 37 #endif 38 #ifdef CONFIG_SYS_FSL_RAID_ENGINE 39 FSL_HW_PORTAL_RAID_ENGINE, 40 #endif 41 #ifdef CONFIG_SYS_DPAA_RMAN 42 FSL_HW_PORTAL_RMAN, 43 #endif 44 45 }; 46 47 struct qportal_info { 48 u16 dliodn; /* DQRR LIODN */ 49 u16 fliodn; /* frame data LIODN */ 50 u16 liodn_offset; 51 u8 sdest; 52 }; 53 54 #define SET_QP_INFO(dqrr, fdata, off, dest) \ 55 { .dliodn = dqrr, .fliodn = fdata, .liodn_offset = off, .sdest = dest } 56 57 extern int get_dpaa_liodn(enum fsl_dpaa_dev dpaa_dev, 58 u32 *liodns, int liodn_offset); 59 extern void setup_portals(void); 60 extern void fdt_fixup_qportals(void *blob); 61 extern void fdt_fixup_bportals(void *blob); 62 63 extern struct qportal_info qp_info[]; 64 extern void fdt_portal(void *blob, const char *compat, const char *container, 65 u64 addr, u32 size); 66 67 #endif 68