Date: Tue, 5 Dec 2006 05:43:25 GMT From: John Birrell <jb@FreeBSD.org> To: Perforce Change Reviews <perforce@freebsd.org> Subject: PERFORCE change 111115 for review Message-ID: <200612050543.kB55hPm3068989@repoman.freebsd.org>
next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=111115 Change 111115 by jb@jb_freebsd8 on 2006/12/05 05:43:09 IFC Affected files ... .. //depot/projects/dtrace/doc/zh_CN.GB2312/books/handbook/boot/chapter.sgml#4 integrate .. //depot/projects/dtrace/doc/zh_CN.GB2312/books/handbook/config/chapter.sgml#9 integrate .. //depot/projects/dtrace/doc/zh_CN.GB2312/books/handbook/desktop/chapter.sgml#6 integrate .. //depot/projects/dtrace/doc/zh_CN.GB2312/books/handbook/install/chapter.sgml#12 integrate .. //depot/projects/dtrace/doc/zh_CN.GB2312/books/handbook/mirrors/chapter.sgml#8 integrate .. //depot/projects/dtrace/doc/zh_CN.GB2312/books/handbook/x11/chapter.sgml#11 integrate .. //depot/projects/dtrace/doc/zh_CN.GB2312/books/porters-handbook/book.sgml#14 integrate .. //depot/projects/dtrace/src/sys/boot/sparc64/loader/hcall.S#4 delete .. //depot/projects/dtrace/src/sys/powerpc/include/pmap.h#4 integrate .. //depot/projects/dtrace/src/sys/powerpc/powerpc/mmu_if.m#6 integrate .. //depot/projects/dtrace/src/sys/powerpc/powerpc/mmu_oea.c#9 integrate .. //depot/projects/dtrace/src/sys/powerpc/powerpc/pmap_dispatch.c#7 integrate .. //depot/projects/dtrace/src/sys/powerpc/powerpc/uio_machdep.c#4 integrate .. //depot/projects/dtrace/src/sys/sun4v/sun4v/hcall.S#9 integrate .. //depot/projects/dtrace/www/share/sgml/news.xml#13 integrate .. //depot/projects/dtrace/www/share/sgml/press.xml#10 integrate Differences ... ==== //depot/projects/dtrace/doc/zh_CN.GB2312/books/handbook/boot/chapter.sgml#4 (text+ko) ==== @@ -3,7 +3,7 @@ The FreeBSD Chinese (Simplified) Project Original Revision: 1.65 - $FreeBSD: doc/zh_CN.GB2312/books/handbook/boot/chapter.sgml,v 1.4 2006/06/03 15:34:22 delphij Exp $ + $FreeBSD: doc/zh_CN.GB2312/books/handbook/boot/chapter.sgml,v 1.5 2006/12/05 02:36:13 delphij Exp $ --> <chapter id="boot"> <title>FreeBSD 引导过程</title> @@ -614,12 +614,12 @@ 这个变量是在 <command>loader</command> 里面设置的。</para> <sect2 id="boot-autoreboot"> - <title>自动重启队列</title> + <title>自动重启过程</title> - <para>自动重启队列保证了可用的文件系统是稳定的。 - 如果不是,且 &man.fsck.8; 不能修复这些错误, - &man.init.8; 会进入<link linkend="boot-singleuser">单用户模式</link> - 以便系统管理员直接解决问题。</para> + <para>自动重启过程会确认系统中可用的文件系统处于健康的状态。 + 如果不是, 而且使用 &man.fsck.8; 也无法修复这些问题, + &man.init.8; 会进入 <link linkend="boot-singleuser">单用户模式</link> + 以便系统管理员直接修正这些问题。</para> </sect2> <sect2 id="boot-singleuser"> @@ -628,12 +628,12 @@ <indexterm><primary>控制台</primary></indexterm> <para>此模式可以通过 - <link linkend="boot-autoreboot"> 自动重启队列</link>或者通过带有 + <link linkend="boot-autoreboot">自动重启过程</link> 或者通过带有 <option>-s</option> 选项的用户引导或通过在 <command>loader</command> 里设置 <envar>boot_single</envar> 变量等多种方式来达到。</para> - <para>也可以在多用户模式下调动无 reboot(<option>-r</option>)选项和 - halt (<option>-h</option>) 选项的 &man.shutdown.8; + <para>也可以在多用户模式下调动无重启 (<option>-r</option>) 选项和停机 + (<option>-h</option>) 选项的 &man.shutdown.8; 命令来进入单用户模式。</para> <para>如果系统 <literal>控制台</literal> 在文件 @@ -683,19 +683,19 @@ </sect1> <sect1 id="boot-shutdown"> - <title>shutdown 队列</title> + <title>关机 (shutdown) 过程</title> <indexterm> <primary><command>shutdown</command></primary> </indexterm> - <para>由命令 &man.shutdown.8; 的控制, + <para>由命令 &man.shutdown.8; 的发起的关机过程中, &man.init.8; 会试着运行 <filename>/etc/rc.shutdown</filename> 脚本, - 给所有进程发送 <literal>TERM</literal> 信号,然后给不按时停止的进程发送 - <literal>KILL</literal>信号。</para> + 给所有进程发送 <literal>TERM</literal> 信号, 最后给不按时停止的进程发送 + <literal>KILL</literal> 信号。</para> - <para>在支持电源管理的体系上关闭 FreeBSD 系统的电源,只要简单的使用命令 - <command>shutdown -p now</command> 立即关闭电源。使用命令 - <command>shutdown -r now</command> 重启 FreeBSD。要执行 &man.shutdown.8; + <para>在支持电源管理的平台上关闭 FreeBSD 系统的电源, 只要简单地使用命令 + <command>shutdown -p now</command> 即可。 此外, 可以用命令 + <command>shutdown -r now</command> 来重启 FreeBSD。 要执行 &man.shutdown.8; 您必须是 <username>root</username> 用户或 <groupname>operator</groupname> 组的成员。 也可以使用 &man.halt.8; 和 &man.reboot.8; 命令来关闭系统, 请参看它们的联机手册以获得更多的信息。</para> ==== //depot/projects/dtrace/doc/zh_CN.GB2312/books/handbook/config/chapter.sgml#9 (text+ko) ==== @@ -2,8 +2,8 @@ The FreeBSD Documentation Project The FreeBSD Chinese Documentation Project - Original Revision: 1.223 - $FreeBSD: doc/zh_CN.GB2312/books/handbook/config/chapter.sgml,v 1.11 2006/10/27 06:37:47 delphij Exp $ + Original Revision: 1.225 + $FreeBSD: doc/zh_CN.GB2312/books/handbook/config/chapter.sgml,v 1.12 2006/12/05 02:36:13 delphij Exp $ --> <chapter id="config-tuning"> @@ -1499,18 +1499,21 @@ <indexterm><primary>sysctl.conf</primary></indexterm> <indexterm><primary>sysctl</primary></indexterm> - <para><filename>sysctl.conf</filename> 看起来很像 - <filename>rc.conf</filename>。它用 <literal>variable=value</literal> - 的形式来设定值。指定的值在系统进入多用户模式之后被设定。 - 并不是所有的变量都可以在这个模式下设定。</para> + <para><filename>sysctl.conf</filename> 和 + <filename>rc.conf</filename> 这两个文件的风格很接近。 其中的配置均为 + <literal>变量=值</literal> + 这样的形式。 在这个文件中配置的值, 均会在系统进入多用户模式之后进行实际的修改操作。 + 需要注意的是, 并不是所有的变量都能够在多用户模式下修改。</para> + + <para>如果希望关闭对收到致命的信号退出的进程进行记录, + 并阻止普通用户看到其他用户的进程, 可以在 <filename>sysctl.conf</filename> + 中进行下列配置:</para> - <para> 一个简单的例子举明了在 <filename>sysctl.conf</filename> - 中关闭了重要的退出信号的日志并且让 Linux 程序知道他们其实运行在 - &os; 下面:</para> + <programlisting># 不记录由于致命信号导致的进程退出 (例如信号 11,访问越界) +kern.logsigexit=0 - <programlisting>kern.logsigexit=0 # Do not log fatal signal exits (e.g. sig 11) -compat.linux.osname=&os; -compat.linux.osrelease=4.3-STABLE</programlisting> +# 阻止用户看到以其他用户 UID 身份执行的进程。 +security.bsd.see_other_uids=0</programlisting> </sect2> </sect1> @@ -1873,10 +1876,10 @@ 在大型生产服务器上, 可能会轻易地用掉数千个文件描述符, 具体用量取决于服务的类型和并行启动的服务数量。</para> - <para>在早期版本的 &os; 中, <varname>kern.maxfile</varname> 的默认值, + <para>在早期版本的 &os; 中, <varname>kern.maxfiles</varname> 的默认值, 是根据您内核配置文件中的 <option>maxusers</option> 选项计算的。 <varname>kern.maxfiles</varname> 这个数值, - 会与 <option>maxusers</option> 成比例增减。 + 会随 <option>maxusers</option> 成比例地增减。 当编译定制的内核时, 按照您系统的用途来修改这个值是个好主意。 这个数字同时还决定内核的许多预设的限制值。 有时, 尽管并不会真的有 256 个用户同时连接一台生产服务器, ==== //depot/projects/dtrace/doc/zh_CN.GB2312/books/handbook/desktop/chapter.sgml#6 (text+ko) ==== @@ -2,8 +2,8 @@ The FreeBSD Documentation Project The FreeBSD Chinese Project - Original Revision: 1.66 - $FreeBSD: doc/zh_CN.GB2312/books/handbook/desktop/chapter.sgml,v 1.7 2006/09/15 05:41:06 delphij Exp $ + Original Revision: 1.67 + $FreeBSD: doc/zh_CN.GB2312/books/handbook/desktop/chapter.sgml,v 1.8 2006/12/05 02:36:13 delphij Exp $ --> <chapter id="desktop"> @@ -557,7 +557,7 @@ <para>安装 <application>OpenOffice.org</application> 方法如下:</para> - <screen>&prompt.root; <userinput>pkg_add -r openoffice</userinput></screen> + <screen>&prompt.root; <userinput>pkg_add -r openoffice.org</userinput></screen> <note> <para>如果您正在使用 &os; 的 -RELEASE 版本, 一般来说这样做是没问题的。 @@ -581,7 +581,7 @@ package,您仍旧可以选择编译 port。然而, 您必须记住它的要求以及大量的磁盘空间和相当长的时间编译。</para> - <screen>&prompt.root; <userinput>cd /usr/ports/editors/openoffice.org-2.0</userinput> + <screen>&prompt.root; <userinput>cd /usr/ports/editors/openoffice.org-2</userinput> &prompt.root; <userinput>make install clean</userinput></screen> <note> ==== //depot/projects/dtrace/doc/zh_CN.GB2312/books/handbook/install/chapter.sgml#12 (text+ko) ==== @@ -2,8 +2,8 @@ The FreeBSD Documentation Project The FreeBSD Simplified Chinese Project - Original Revision: 1.337 - $FreeBSD: doc/zh_CN.GB2312/books/handbook/install/chapter.sgml,v 1.14 2006/11/17 14:51:01 delphij Exp $ + Original Revision: 1.338 + $FreeBSD: doc/zh_CN.GB2312/books/handbook/install/chapter.sgml,v 1.15 2006/12/05 02:36:13 delphij Exp $ --> <chapter id="install"> @@ -2016,7 +2016,7 @@ <listitem> <para>本范例中的IP地址属于一个C类地址 (<hostid role="ipaddr">192.168.0.0</hostid> - - <hostid role="ipaddr">192.168.255.255</hostid>)。默认的子网掩码为 + <hostid role="ipaddr">192.168.0.255</hostid>)。默认的子网掩码为 (<hostid role="netmask">255.255.255.0</hostid>)。</para> </listitem> </varlistentry> ==== //depot/projects/dtrace/doc/zh_CN.GB2312/books/handbook/mirrors/chapter.sgml#8 (text+ko) ==== @@ -2,8 +2,8 @@ The FreeBSD Documentation Project The FreeBSD Chinese Documentation Project - Original Revision: 1.420 - $FreeBSD: doc/zh_CN.GB2312/books/handbook/mirrors/chapter.sgml,v 1.10 2006/08/26 13:45:54 delphij Exp $ + Original Revision: 1.421 + $FreeBSD: doc/zh_CN.GB2312/books/handbook/mirrors/chapter.sgml,v 1.11 2006/12/05 02:36:13 delphij Exp $ --> <appendix id="mirrors"> @@ -2624,6 +2624,14 @@ <variablelist> <varlistentry> + <term>RELENG_6_2_0_RELEASE</term> + + <listitem> + <para>FreeBSD 6.2</para> + </listitem> + </varlistentry> + + <varlistentry> <term>RELENG_6_1_0_RELEASE</term> <listitem> ==== //depot/projects/dtrace/doc/zh_CN.GB2312/books/handbook/x11/chapter.sgml#11 (text+ko) ==== @@ -2,8 +2,8 @@ The FreeBSD Documentation Project The FreeBSD Simplified Chinese Project - Original Revision: 1.177 - $FreeBSD: doc/zh_CN.GB2312/books/handbook/x11/chapter.sgml,v 1.16 2006/11/17 14:59:43 delphij Exp $ + Original Revision: 1.178 + $FreeBSD: doc/zh_CN.GB2312/books/handbook/x11/chapter.sgml,v 1.17 2006/12/05 02:36:13 delphij Exp $ --> <chapter id="x11"> @@ -663,7 +663,7 @@ <filename role="package">x11-fonts/ttmkfdir</filename> 中找到。</para> <screen>&prompt.root; <userinput>cd /usr/X11R6/lib/X11/fonts/TrueType</userinput> -&prompt.root; <userinput>ttmkfdir > fonts.dir</userinput></screen> +&prompt.root; <userinput>ttmkfdir -o fonts.dir</userinput></screen> <para>现在把 &truetype; 字体目录添加到字体路径中。 这和上面 <link linkend="type1">Type1</link> 字体的步骤是一样的, ==== //depot/projects/dtrace/doc/zh_CN.GB2312/books/porters-handbook/book.sgml#14 (text+ko) ==== @@ -2,8 +2,8 @@ The FreeBSD Documentation Project The FreeBSD Simplified Chinese Project - Original Revision: 1.769 - $FreeBSD: doc/zh_CN.GB2312/books/porters-handbook/book.sgml,v 1.19 2006/11/17 15:01:43 delphij Exp $ + Original Revision: 1.772 + $FreeBSD: doc/zh_CN.GB2312/books/porters-handbook/book.sgml,v 1.20 2006/12/05 02:36:13 delphij Exp $ --> <!DOCTYPE BOOK PUBLIC "-//FreeBSD//DTD DocBook V4.1-Based Extension//EN" [ @@ -3674,6 +3674,42 @@ </sect2> + <sect2> + <title>自动激活的特性</title> + + <para>在使用 GNU configure 脚本时, 一定要小心有些特性会由其自动检测而激活。 + 您应通过明确地指定相应的 + <literal>--without-xxx</literal> 或 <literal>--disable-xxx</literal> + 参数到 <makevar>CONFIGURE_ARGS</makevar> 来禁用不希望的特性。</para> + + <example> + <title>处理选项时的错误做法</title> + <programlisting>.if defined(WITH_FOO) +LIB_DEPENDS+= foo.0:${PORTSDIR}/devel/foo +CONFIGURE_ARGS+= --enable-foo +.endif</programlisting> + </example> + + <para>在前面的例子中, 假设系统中已经安装了 libfoo 库。 用户可能并不希望应用程序使用 libfoo, + 因此他在 <literal>make config</literal> 对话框中关掉了这个选项。 + 但是, 应用程序的 configure 脚本检测到了系统中存在这个库, + 并将其加入到了最终可执行文件支持的功能中。 现在, 如果用户决定从系统中卸载 libfoo 时, + ports 系统就无法保护这个应用程序免遭破坏了 (因为没有记录 libfoo 的依赖关系)。</para> + + <example> + <title>处理选项时的正确做法</title> + <programlisting>.if defined(WITH_FOO) +LIB_DEPENDS+= foo.0:${PORTSDIR}/devel/foo +CONFIGURE_ARGS+= --enable-foo +.else +CONFIGURE_ARGS+= --disable-foo +.endif</programlisting> + </example> + + <para>在第二个例子中, libfoo 库被明确禁用。 即使系统中已经安装了这个库, + configure 脚本也不会启用相应的功能了。</para> + </sect2> + </sect1> <sect1 id="makefile-wrkdir"> @@ -6436,6 +6472,44 @@ 而无需 <makevar>WX_PREMK</makevar> 的参与。</para> </note> </sect2> + + <sect2 id="wx-additional-config-args"> + <title>额外的 <command>configure</command> 参数</title> + + <para>某些 GNU <command>configure</command> 脚本在只设置了 + <literal>WX_CONFIG</literal> 环境变量时, 无法自动找到 + <application>wxWidgets</application>, 而需要使用额外的参数来加以指定。 + 您可以使用 <makevar>WX_CONF_ARGS</makevar> 变量来给出这些参数。</para> + + <table frame="none"> + <title>可用于 <makevar>WX_CONF_ARGS</makevar> 的值</title> + + <tgroup cols="2"> + <thead> + <row> + <entry>可用值</entry> + + <entry>结果</entry> + </row> + </thead> + + <tbody> + <row> + <entry><literal>absolute</literal></entry> + + <entry><literal>--with-wx-config=${WX_CONFIG}</literal></entry> + </row> + + <row> + <entry><literal>relative</literal></entry> + + <entry><literal>--with-wx=${X11BASE} + --with-wx-config=${WX_CONFIG:T}</literal></entry> + </row> + </tbody> + </tgroup> + </table> + </sect2> </sect1> <sect1 id="using-lua"> @@ -9962,6 +10036,10 @@ <entry>加入了 libelf 之后的 7.0-CURRENT。</entry> <entry>700025</entry> </row> + <row> + <entry>对音效相关的 sysctl 进行大幅调整之后的 7.0-CURRENT。</entry> + <entry>700026</entry> + </row> </tbody> </tgroup> </table> ==== //depot/projects/dtrace/src/sys/powerpc/include/pmap.h#4 (text+ko) ==== @@ -29,7 +29,7 @@ * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * $NetBSD: pmap.h,v 1.17 2000/03/30 16:18:24 jdolecek Exp $ - * $FreeBSD: src/sys/powerpc/include/pmap.h,v 1.19 2005/12/06 21:09:01 jhb Exp $ + * $FreeBSD: src/sys/powerpc/include/pmap.h,v 1.20 2006/12/05 04:01:52 grehan Exp $ */ #ifndef _MACHINE_PMAP_H_ @@ -95,7 +95,7 @@ void pmap_deactivate(struct thread *); vm_offset_t pmap_kextract(vm_offset_t); int pmap_dev_direct_mapped(vm_offset_t, vm_size_t); - +boolean_t pmap_page_executable(vm_page_t); boolean_t pmap_mmu_install(char *name, int prio); #define vtophys(va) pmap_kextract((vm_offset_t)(va)) ==== //depot/projects/dtrace/src/sys/powerpc/powerpc/mmu_if.m#6 (text+ko) ==== @@ -23,7 +23,7 @@ # OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF # SUCH DAMAGE. # -# $FreeBSD: src/sys/powerpc/powerpc/mmu_if.m,v 1.6 2006/08/01 19:06:05 alc Exp $ +# $FreeBSD: src/sys/powerpc/powerpc/mmu_if.m,v 1.7 2006/12/05 04:01:52 grehan Exp $ # #include <sys/param.h> @@ -752,3 +752,17 @@ vm_offset_t _pa; vm_size_t _size; }; + + +/** + * @brief Evaluate if a physical page has an executable mapping + * + * @param _pg physical page + * + * @retval bool TRUE if a physical mapping exists for the given page. + */ +METHOD boolean_t page_executable { + mmu_t _mmu; + vm_page_t _pg; +}; + ==== //depot/projects/dtrace/src/sys/powerpc/powerpc/mmu_oea.c#9 (text+ko) ==== @@ -91,7 +91,7 @@ */ #include <sys/cdefs.h> -__FBSDID("$FreeBSD: src/sys/powerpc/powerpc/mmu_oea.c,v 1.113 2006/11/30 08:13:06 grehan Exp $"); +__FBSDID("$FreeBSD: src/sys/powerpc/powerpc/mmu_oea.c,v 1.114 2006/12/05 04:01:52 grehan Exp $"); /* * Manages physical address maps. @@ -342,6 +342,7 @@ vm_offset_t moea_kextract(mmu_t, vm_offset_t); void moea_kenter(mmu_t, vm_offset_t, vm_offset_t); boolean_t moea_dev_direct_mapped(mmu_t, vm_offset_t, vm_size_t); +boolean_t moea_page_executable(mmu_t, vm_page_t); static mmu_method_t moea_methods[] = { MMUMETHOD(mmu_change_wiring, moea_change_wiring), @@ -380,6 +381,7 @@ MMUMETHOD(mmu_kextract, moea_kextract), MMUMETHOD(mmu_kenter, moea_kenter), MMUMETHOD(mmu_dev_direct_mapped,moea_dev_direct_mapped), + MMUMETHOD(mmu_page_executable, moea_page_executable), { 0, 0 } }; @@ -2453,6 +2455,12 @@ return (EFAULT); } +boolean_t +moea_page_executable(mmu_t mmu, vm_page_t pg) +{ + return ((moea_attr_fetch(pg) & PTE_EXEC) == PTE_EXEC); +} + /* * Map a set of physical memory pages into the kernel virtual * address space. Return a pointer to where it is mapped. This ==== //depot/projects/dtrace/src/sys/powerpc/powerpc/pmap_dispatch.c#7 (text+ko) ==== @@ -26,7 +26,7 @@ */ #include <sys/cdefs.h> -__FBSDID("$FreeBSD: src/sys/powerpc/powerpc/pmap_dispatch.c,v 1.8 2006/11/11 20:57:52 alc Exp $"); +__FBSDID("$FreeBSD: src/sys/powerpc/powerpc/pmap_dispatch.c,v 1.9 2006/12/05 04:01:52 grehan Exp $"); /* * Dispatch MI pmap calls to the appropriate MMU implementation @@ -345,6 +345,11 @@ return (MMU_DEV_DIRECT_MAPPED(mmu_obj, pa, size)); } +boolean_t +pmap_page_executable(vm_page_t pg) +{ + return (MMU_PAGE_EXECUTABLE(mmu_obj, pg)); +} /* * MMU install routines. Highest priority wins, equal priority also ==== //depot/projects/dtrace/src/sys/powerpc/powerpc/uio_machdep.c#4 (text+ko) ==== @@ -36,7 +36,7 @@ */ #include <sys/cdefs.h> -__FBSDID("$FreeBSD: src/sys/powerpc/powerpc/uio_machdep.c,v 1.5 2005/01/07 02:29:20 imp Exp $"); +__FBSDID("$FreeBSD: src/sys/powerpc/powerpc/uio_machdep.c,v 1.6 2006/12/05 04:01:52 grehan Exp $"); #include <sys/param.h> #include <sys/kernel.h> @@ -49,6 +49,7 @@ #include <vm/vm.h> #include <vm/vm_page.h> +#include <machine/cpu.h> #include <machine/vmparam.h> /* @@ -92,10 +93,13 @@ uio_yield(); if (uio->uio_rw == UIO_READ) error = copyout(cp, iov->iov_base, cnt); - else + else error = copyin(iov->iov_base, cp, cnt); if (error) goto out; + if (uio->uio_rw == UIO_WRITE && + pmap_page_executable(ma[offset >> PAGE_SHIFT])) + __syncicache(cp, cnt); break; case UIO_SYSSPACE: if (uio->uio_rw == UIO_READ) ==== //depot/projects/dtrace/src/sys/sun4v/sun4v/hcall.S#9 (text+ko) ==== @@ -1,1433 +1,1850 @@ -/* - * CDDL HEADER START +/*- + * Copyright (c) 2006 Kip Macy <kmacy@FreeBSD.org> + * All rights reserved. * - * The contents of this file are subject to the terms of the - * Common Development and Distribution License, Version 1.0 only - * (the "License"). You may not use this file except in compliance - * with the License. + * 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. * - * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE - * or http://www.opensolaris.org/os/licensing. - * See the License for the specific language governing permissions - * and limitations under the License. + * THIS SOFTWARE IS PROVIDED BY THE AUTHOR 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 AUTHOR 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. * - * When distributing Covered Code, include this CDDL HEADER in each - * file and include the License file at usr/src/OPENSOLARIS.LICENSE. - * If applicable, add the following below this CDDL HEADER, with the - * fields enclosed by brackets "[]" replaced with your own identifying - * information: Portions Copyright [yyyy] [name of copyright owner] - * - * CDDL HEADER END + * $FreeBSD: src/sys/sun4v/sun4v/hcall.S,v 1.17 2006/11/26 04:37:49 kmacy Exp $ */ -/* - * Copyright 2005 Sun Microsystems, Inc. All rights reserved. - * Use is subject to license terms. - */ -#pragma ident "@(#)hcall.s 1.10 05/09/28 SMI" - -/* - * Hypervisor calls - */ -#define _ASM - +#include <sys/cdefs.h> + #include <machine/asm.h> -__FBSDID("$FreeBSD: src/sys/sun4v/sun4v/hcall.S,v 1.3 2006/11/08 22:16:05 kmacy Exp $") - #include <machine/asi.h> #include <machine/asmacros.h> -#include <machine/hypervisor_api.h> +#include <machine/hypervisorvar.h> #include <machine/pstate.h> #include "assym.s" +/* + * Section 9 API Versioning + * + */ -#if defined(lint) -#error lint -#endif -#if defined(__lint) -#error __lint -#endif -#if defined(lint) || defined(__lint) +/* + * request and check for a version of the hypervisor apis + * which may be compatible + * + * arg0 api_group (%o0) + * arg1 major_number (%o1) + * arg2 req_minor_number (%o2) + * + * ret0 status (%o0) + * ret1 act_minor_number (%o1) + * + */ +ENTRY(api_set_version) + mov API_SET_VERSION, %o5 + ta CORE_TRAP + retl + stx %o1, [%o3] +END(api_set_version) -/*ARGSUSED*/ -int64_t -hv_cnputchar(uint8_t ch) -{ return (0); } +/* + * retrieve the major and minor number of the most recently + * successfully negotiated API + * + * arg0 api_group (%o0) + * + * ret0 status (%o0) + * ret1 major_number (%o1) + * ret2 major_number (%o2) + * + */ +ENTRY(api_get_version) + mov %o2, %o4 + mov %o1, %o3 + mov API_GET_VERSION, %o5 + ta CORE_TRAP + retl + stx %o1, [%o4] + +END(api_get_version) + +/* + * Section 10 Domain Services + * + */ -/*ARGSUSED*/ -int64_t -hv_cngetchar(uint8_t *ch) -{ return (0); } +/* + * stop all CPUs in the virtual machine domain and place them + * in the stopped state + * + * arg0 exit_code (%o0) + * + */ +ENTRY(hv_mach_exit) + mov MACH_EXIT, %o5 + ta FAST_TRAP + retl + nop +END(hv_mach_exit) + +/* + * copy the most current machine description into buffer + * upon success or EINVAL the service returns the actual + * size of the machine description + * + * arg0 buffer (%o0) + * arg1 length (%o1) + * + * ret0 status (%o0) + * ret1 length (%o1) + * + */ +ENTRY(hv_mach_desc) + mov %o1, %o2 + ldx [%o1], %o1 + mov MACH_DESC, %o5 + ta FAST_TRAP + retl + stx %o1, [%o2] +END(hv_mach_desc) -/*ARGSUSED*/ -uint64_t -hv_tod_get(uint64_t *seconds) -{ return (0); } +/* + * execute a software initiated reset of a virtual machine domain + * + */ +ENTRY(hv_mach_sir) + mov MACH_SIR, %o5 + ta FAST_TRAP + retl + nop +END(hv_mach_sir) + +/* + * report the guests soft state to the hypervisor + * + * arg0 soft_state (%o0) + * arg1 soft_state_desc_ptr (%o1) + * + * ret0 status (%o0) + * + */ +ENTRY(hv_mach_set_soft_state) + mov MACH_SET_SOFT_STATE, %o5 + ta FAST_TRAP + retl + nop +END(hv_mach_set_soft_state) + +/* + * retrieve the current value of the guest's software state + * + * arg0 soft_desc_ptr (%o0) + * + * ret0 status (%o0) + * arg1 soft_state (%o1) + * + */ +ENTRY(hv_mach_get_soft_state) + mov %o1, %o2 + mov MACH_SET_SOFT_STATE, %o5 + ta FAST_TRAP + retl + stx %o1, [%o2] +END(hv_mach_get_soft_state) + +/* + * set a watchdog timer, 0 disables, upon success + * time_remaining contains the time previously remaining + * + * arg0 timeout (%o0) + * + * ret0 status (%o0) + * ret1 time_remaining (%o1) + * + */ +ENTRY(hv_mach_watchdog) + mov %o1, %o2 + mov MACH_WATCHDOG, %o5 + ta FAST_TRAP + brnz,pn %o0, 1f + nop + stx %o1, [%o2] +1: retl + nop +END(hv_mach_watchdog) + +/* + * Section 11 CPU Services + * + */ -/*ARGSUSED*/ -uint64_t -hv_tod_set(uint64_t seconds) -{ return (0);} +/* + * start CPU with id cpuid with pc in %pc and real trap base address + * of rtba + * + * arg0 cpuid (%o0) + * arg1 pc (%o1) + * arg2 rtba (%o2) + * arg3 target_arg0 (%o3) + * + * ret0 status (%o0) + * + */ +ENTRY(hv_cpu_start) + mov CPU_START, %o5 + ta FAST_TRAP + retl + nop +END(hv_cpu_start) -/*ARGSUSED*/ -uint64_t -hv_mmu_map_perm_addr(void *vaddr, int ctx, uint64_t tte, int flags) -{ return (0); } +/* + * stop CPU with id cpuid + * + * arg0 cpuid (%o0) + * + * ret0 status (%o0) + * + */ +ENTRY(hv_cpu_stop) + mov CPU_STOP, %o5 + ta FAST_TRAP + retl + nop +END(hv_cpu_stop) -/*ARGSUSED*/ -uint64_t -hv_mmu_unmap_perm_addr(void *vaddr, int ctx, int flags) -{ return (0); } +/* + * set the real trap base address of the local cpu to rtba + * upon success the previous_rtba contains the address of the + * old rtba + * + * arg0 rtba (%o0) + * + * ret0 status (%o0) + * ret1 previous_rtba(%o1) + * + */ +ENTRY(hv_cpu_set_rtba) + mov %o1, %o2 + mov CPU_SET_RTBA, %o5 + ta FAST_TRAP + retl + stx %o1, [%o2] + +END(hv_cpu_set_rtba) -/*ARGSUSED*/ -uint64_t -hv_set_ctx0(uint64_t ntsb_descriptor, uint64_t desc_ra) -{ return (0); } +/* + * return the current real trap base address + * + * ret0 status (%o0) + * ret1 rtba (%o1) + * + */ +ENTRY(hv_cpu_get_rtba) + mov CPU_GET_RTBA, %o5 + ta FAST_TRAP + retl + nop +END(hv_cpu_get_rtba) + +/* + * suspend execution on current cpu + * + * ret0 status (%o0) + * + */ +ENTRY(hv_cpu_yield) + mov CPU_YIELD, %o5 + ta FAST_TRAP + retl + nop +END(hv_cpu_yield) -/*ARGSUSED*/ -uint64_t -hv_set_ctxnon0(uint64_t ntsb_descriptor, uint64_t desc_ra) -{ return (0); } +/* + * configure queue of size nentries to be placed at base raddr + * + * arg0 queue (%o0) + * arg1 base raddr (%o1) + * arg2 nentries (%o2) + * + * ret0 status (%o0) + * + */ +ENTRY(hv_cpu_qconf) + mov CPU_QCONF, %o5 + ta FAST_TRAP + retl + nop +END(hv_cpu_qconf) + +/* + * return configuration of queue queue + * + * arg0 queue (%o0) + * + * ret0 status (%o0) + * ret1 base raddr (%o1) + * ret2 nentries (%o2) + * + */ +ENTRY(hv_cpu_qinfo) +END(hv_cpu_qinfo) + +/* + * send cpu mondo interrupt to cpulist + * + * arg0 ncpus (%o0) + * arg1 cpu list ra (%o1) + * arg2 mondo data ra(%o2) + * + * ret0 status (%o0) + * + */ +ENTRY(hv_cpu_mondo_send) + ldx [PCPU(MONDO_DATA_RA)], %o2 + mov CPU_MONDO_SEND, %o5 + ta FAST_TRAP + retl + membar #Sync +END(hv_cpu_mondo_send) -#ifdef SET_MMU_STATS -/*ARGSUSED*/ -uint64_t -hv_mmu_set_stat_area(uint64_t rstatarea, uint64_t size) -{ return (0); } -#endif /* SET_MMU_STATS */ +/* + * return the hypervisor id for the current cpu + * + * ret0 status (%o0) + * ret1 cpuid (%o1) + * + */ +ENTRY(hv_cpu_myid) + mov %o0, %o2 + mov CPU_MYID, %o5 + ta FAST_TRAP + stx %o1, [%o2] + retl + nop +END(hv_cpu_myid) -/*ARGSUSED*/ -uint64_t -hv_cpu_qconf(int queue, uint64_t paddr, int size) -{ return (0); } +/* + * retrieve the current state of cpu cpuid + * + * arg0 cpuid (%o0) + * + * ret0 status (%o0) + * ret1 state (%o1) + * + */ +ENTRY(hv_cpu_state) + mov %o1, %o2 + mov CPU_STATE, %o5 + ta FAST_TRAP + stx %o1, [%o2] + retl + nop +END(hv_cpu_state) + +/* + * Section 12 MMU Services + * + */ + +/* + * set the tsb(s) for the current cpu for context 0 + * + * arg0 ntsb (%o0) + * arg1 tsbdptr (%o1) + * + * ret0 status (%o0) + * + */ +ENTRY(hv_mmu_tsb_ctx0) + mov MMU_TSB_CTX0, %o5 + ta FAST_TRAP + retl + nop +END(hv_mmu_tsb_ctx0) -/*ARGSUSED*/ -uint64_t -hvio_config_get(devhandle_t dev_hdl, pci_device_t bdf, - pci_config_offset_t off, pci_config_size_t size, pci_cfg_data_t *data_p) -{ return (0); } +/* + * set the tsb(s) for the current cpu for non-zero contexts + * + * arg0 ntsb (%o0) + * arg1 tsbptr (%o1) + * + * ret0 status (%o0) + * >>> TRUNCATED FOR MAIL (1000 lines) <<<
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200612050543.kB55hPm3068989>