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