第二章,系统架构——检查版,系统核心组件

第二章,系统架构——环境子系统和子系统DLL

打狗棒 posted @ 2012年5月20日 21:19 in Windows.Internals.6th , 2654 阅读

环境子系统和子系统dll

环境子系统所扮演的角色是windows系统执行的服务和应用程序之间的桥梁。每个子系统都可给应用程序提供windows本地服务不同部分的访问。依托某个子系统建立的应用程序所完成的事情不会被依托另一个子系统的应用程序完成。比如,一个windows应用程序不能用SUA(基于unix应用程序的子系统) fork函数。

每个可执行程序的镜像(.exe)被限定在一个而且只是一个子系统中。当一个镜像开始运行时,进程创建代码会检查位于镜像头部的子系统类型字段,这样就可通知子系统将会有一个新的进程。该字段在Windows Visual C++链接之前,被命令/SUBSYSTEM所指定。

前面提到过,用户应用程序并不直接调用系统服务,而是通过一个或者多个子系统DLL。这些库提供了文档完善的接口,以便应用程序通过他们链接到子系统。例如,windows子系统dll(如Kernel32.dll,Advapi32.dll,User.dll,Gdi32.dll)实现了windows API函数,而SUA子系统dll(Psxdll.dll)实现了SUA API函数。

实验:查看镜像子系统类型

可以用Dependency Walker tool(Depends.exe)查看。

主页:http://www.dependencywalker.com/。比如,注意下这两个windows镜像子系统类型的不同:Notepad.exe和Cmd.exe。

这表示,Notepad是一个GUI程序,Cmd是一个控制台或者基于字符串的程序。尽管这意味着有GUI和基于字符串的两种不同的子系统应用程序,但却只有一个windows子系统,GUI可以有控制台,就像控制台可以显示GUI一样。

当一个应用程序调用一个子系统DLL中的函数时,下面三个情况之一会发生:

  • 函数完全地在用户模式执行而不是子系统DLL。换句话说,没有消息被发送到环境子系统进程,而且没有windows执行系统的服务被调用。函数被运行在用户模式,结果被返回给调用者。这类函数的例子如GetCurrentProcess(总是返回-1,这个值在所有有关进程函数中被定义成当前进程)和GetCurrentProcessId(运行中的程序不会改变ID,所以这些ID存储在一个本地cache里,以免检索需要的时候进入内核)。
  • 函数需要一个或者多个windows可执行部分的系统调用。比如,windows ReadFile和WriteFile函数分别涉及到调用相关内部(无文档的)windows I/O系统服务NtReadFile和NtReadFile。
  • 函数需要在环境子系统进程中完成一些工作。(环境子系统进程运行在用户模式,负责维护运行在他们控制下的客户程序的状态)这种情况下,一个客户端/服务器请求通过把消息发送给子系统而让其完成相关操作。子系统DLL则在等待它们的回复,然后返回给调用者。

一些函数可能是上面两到三个情况的组合,例如windows CreateProcess和CreateThread函数。

子系统启动

子系统是被会话管理器Smss.exe进程启动的。子系统启动信息被保存在注册表键值HKLM\SYSTEM\CurrentControlSet\Control\Session Manager\SubSystems中。见图2-4,该键值下的数值。

图 2-4 注册表编辑器列出了windows子系统启动信息

Required表项列出了子系统在启动时候需要的条件,共有两个字符串。windows和debug。其中windows键值包括了子系统的文件格式,Csrss.exe(代表客户端/服务器运行时子系统)。debug键值是空的(因为它作为内部调试用)而且什么也不做。Optional键值表示SUA子系统会按需启动。Kmode键值包含windows子系统在内核中的文件名字,Win32k.sys(本章后面解释)。

让我们再近距离看看每个环境子系统。

Avatar_small
cleaning companies 说:
2019年9月13日 21:17

If you would like a complete cleaning firm in UAE, almost certainly, your look for would end if you access each of our website. We provide you with list involving professional cleaning agencies for any sort of cleaning you need regardless of your respective property.

Avatar_small
shopping-batalha.com 说:
2019年11月13日 05:51

Fridge courses for sale online and and a local college that will you grown to be an celebration agent. Some courses may just be specifically directed at entertainment substances, while several other courses in most cases business.

Avatar_small
clean tech laws 说:
2020年3月19日 02:02

Create personal accountability your default placing. Yes, initially it can be easier, cheaper plus much more convenient responsible, excuse, reject and/or overlook responsibility when compared with to take hold of it. Such include the current default settings for most cultures, including your own. In your long or else medium selection, however, it can be healthier, as pleasing and more potent to assume at the least some penetration of responsibility.

Avatar_small
bank ruptcy law merc 说:
2020年3月19日 02:02

Your demand pertaining to law school plus the government subsidization involving school triggered the growth in the school sector, aided by simply publications similar to U. Ersus. News which consists of ludicrous institution rankings. Schools grew to be financial earnings centers involving universities (similar to successful athletics programs) and in many cases were forced to kick rear money on the central university or college administration to help you underwrite the rest of the less profitable aspects of the university or college.

Avatar_small
dui lawyer montreal 说:
2020年3月19日 02:02

Legislation of Destination has received quite a lot of media attention in recent times. Thanks on the movie The secrets and the subsequent explosion involving television, produce media along with internet insurance, nearly anyone in Developed society features heard your phrase "Law involving Attraction".

Avatar_small
wendy wood law 说:
2020年3月19日 02:03

If we're able to accept that every possibilities exist in the present moment along with remain focused inside Now involving life, consciously making it possible for the Legal guidelines of Lifestyle to unhampered operate by way of us, we may soon know that we will be in a co-created entire world which we've got personal accountability for taking into lifetime.

Avatar_small
star lite shopping m 说:
2020年3月19日 02:03

This is just about the most misunderstood Laws involving Life due to belief that every events are generally predestined for you to transpire caused by some past action. It can be true through the standpoint involving action-reaction that will expectations involving future situations should visit fruition in case no substitute adjustments are produced, simply for the reason that root bring about was set in motion.

Avatar_small
full time maids in d 说:
2020年4月28日 00:42

When you are recruiting servant maid by using a agency, take a look at its excellence, referrals with current purchasers, about its maid's health insurance policies, how long they can be doing this company etc. Ask if they guarantee its servants and if they performed any criminal record searches on its maids.

Avatar_small
painting company in 说:
2020年4月28日 00:42

On the flip side, if you choosed go other route plus hire dwelling painters; you aren't required so that you can lift a particular finger. Professionals do the be good enough, of course so if you pay these folks considerably. Painters will guarantee that everything is carried out according to meet your needs and prefers.

Avatar_small
home maids dubai 说:
2021年6月06日 18:10

To prevent aside the health problems, you must make an ideal cleaning agenda. And, the guru house cleaners recommend cleaning all the house one or more times a working day. Additionally, it's important to focus more to the hard surface types while cleaning up and disinfecting your property.


登录 *


loading captcha image...
(输入验证码)
or Ctrl+Enter