/* * Support for Medifield PNW Camera Imaging ISP subsystem. * * Copyright (c) 2010 Intel Corporation. All Rights Reserved. * * Copyright (c) 2010 Silicon Hive www.siliconhive.com. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License version * 2 as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA * 02110-1301, USA. * */ #ifndef SH_MMU_H_ #define SH_MMU_H_ #include #include "mmu/isp_mmu.h" /* * include SH header file here */ /* * set page directory base address (physical address). * * must be provided. */ static int sh_set_pd_base(struct isp_mmu *mmu, unsigned int phys) { sh_css_mmu_set_page_table_base_address((void *)phys); return 0; } /* * callback to flush tlb. * * tlb_flush_range will at least flush TLBs containing * address mapping from addr to addr + size. * * tlb_flush_all will flush all TLBs. * * tlb_flush_all is must be provided. if tlb_flush_range is * not valid, it will set to tlb_flush_all by default. */ static void sh_tlb_flush(struct isp_mmu *mmu) { sh_css_mmu_invalidate_cache(); } static struct isp_mmu_driver sh_mmu_driver = { .name = "Silicon Hive ISP3000 MMU", .pte_valid_mask = 0x1, .set_pd_base = sh_set_pd_base, .tlb_flush_all = sh_tlb_flush, }; #define ISP_VM_START 0x0 #define ISP_VM_SIZE (1 << 30) /* 1G address space */ #define ISP_PTR_NULL NULL #endif /* SH_MMU_H_ */