NetBSD/sys/arch/powerpc/booke/genassym.cf
matt f82647e665 Make the 85xx get closer to spinning up the secondary CPUs.
Don't assume TLB1[0] has the mapping for VA/PA 0.
Make sure the TLB1 entries that map physical memory have the M (memory
coherent) bit set.
2012-11-27 19:24:45 +00:00

115 lines
4.6 KiB
CFEngine3

# $NetBSD: genassym.cf,v 1.10 2012/11/27 19:24:46 matt Exp $
#-
# Copyright (c) 2010, 2011 The NetBSD Foundation, Inc.
# All rights reserved.
#
# This code is derived from software contributed to The NetBSD Foundation
# by Raytheon BBN Technologies Corp and Defense Advanced Research Projects
# Agency and which was developed by Matt Thomas of 3am Software Foundry.
#
# This material is based upon work supported by the Defense Advanced Research
# Projects Agency and Space and Naval Warfare Systems Center, Pacific, under
# Contract No. N66001-09-C-2073.
# Approved for Public Release, Distribution Unlimited
#
# Copyright (c) 2010 The NetBSD Foundation, Inc.
# All rights reserved.
#
# This code is derived from software contributed to The NetBSD Foundation
# by Matt Thomas of 3am Software Foundry.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions
# are met:
# 1. Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
# 2. Redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in the
# documentation and/or other materials provided with the distribution.
#
# THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
# ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
# TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
# BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
# POSSIBILITY OF SUCH DAMAGE.
#+
include "opt_multiprocessor.h"
include <sys/param.h>
include <sys/bitops.h>
include <uvm/uvm_extern.h>
include <machine/frame.h>
include <machine/psl.h>
include <machine/pmap.h>
include <powerpc/booke/trap.h>
include <powerpc/booke/pte.h>
define FRAME_DEAR offsetof(struct ktrapframe, ktf_tf.tf_dear)
define FRAME_ESR offsetof(struct ktrapframe, ktf_tf.tf_esr)
define FRAME_MCSR offsetof(struct ktrapframe, ktf_tf.tf_mcsr)
define FRAME_MCAR offsetof(struct ktrapframe, ktf_tf.tf_mcar)
define FRAME_SPRG1 offsetof(struct ktrapframe, ktf_tf.tf_sprg1)
define FRAME_SPEFSCR offsetof(struct ktrapframe, ktf_tf.tf_spefscr)
define FRAME_CFRAME_LR offsetof(struct ktrapframe, ktf_cframe_lr)
define CI_SAVELIFO offsetof(struct cpu_info, ci_savearea[0])
define CI_PMAP_SEGTAB offsetof(struct cpu_info, ci_pmap_segtabs[0])
define CI_EV_TLBMISS_SOFT offsetof(struct cpu_info, ci_ev_tlbmiss_soft.ev_count)
define PAGE_SIZE PAGE_SIZE
define PAGE_MASK PAGE_MASK
define PAGE_SHIFT PAGE_SHIFT
define KERNEL_PID KERNEL_PID
define USPACE USPACE
define T_CRITIAL_INPUT T_CRITIAL_INPUT
define T_MACHINE_CHECK T_MACHINE_CHECK
define T_DSI T_DSI
define T_ISI T_ISI
define T_EXTERNAL_INPUT T_EXTERNAL_INPUT
define T_ALIGNMENT T_ALIGNMENT
define T_PROGRAM T_PROGRAM
define T_FP_UNAVAILABLE T_FP_UNAVAILABLE
define T_SYSTEM_CALL T_SYSTEM_CALL
define T_AP_UNAVAILABLE T_AP_UNAVAILABLE
define T_DECREMENTER T_DECREMENTER
define T_FIXED_INTERVAL T_FIXED_INTERVAL
define T_WATCHDOG T_WATCHDOG
define T_DATA_TLB_ERROR T_DATA_TLB_ERROR
define T_INSTRUCTION_TLB_ERROR T_INSTRUCTION_TLB_ERROR
define T_DEBUG T_DEBUG
define T_SPE_UNAVAILABLE T_SPE_UNAVAILABLE
define T_EMBEDDED_FP_DATA T_EMBEDDED_FP_DATA
define T_EMBEDDED_FP_ROUND T_EMBEDDED_FP_ROUND
define T_EMBEDDED_PERF_MONITOR T_EMBEDDED_PERF_MONITOR
define T_AST T_AST
define PTE_SCALESHIFT ilog2(sizeof(pt_entry_t))
define PTR_SCALESHIFT ilog2(sizeof(void *))
define NSEGPG_SCALESHIFT PAGE_SHIFT - ilog2(sizeof(void *))
define NPTEPG_SCALESHIFT PAGE_SHIFT - ilog2(sizeof(pt_entry_t))
define MSR_DS 31 - ilog2(PSL_DS)
define MSR_IS 31 - ilog2(PSL_IS)
ifdef MULTIPROCESSOR
define HATCH_CI offsetof(struct cpu_hatch_data, hatch_ci)
define HATCH_HID0 offsetof(struct cpu_hatch_data, hatch_hid0)
define HATCH_RUNNING offsetof(struct cpu_hatch_data, hatch_running)
define HATCH_SP offsetof(struct cpu_hatch_data, hatch_sp)
define HATCH_TBU offsetof(struct cpu_hatch_data, hatch_tbu)
define HATCH_TBL offsetof(struct cpu_hatch_data, hatch_tbl)
define HATCH_TLBIDX offsetof(struct cpu_hatch_data, hatch_tlbidx)
endif