and5.1PowerManagerService深入分析(二)PowerManager中各函数
Power Management-电源管理IC
Yuming电子知识系列Power ManagementPower Management电源管理ICYuming SunJul, 2011Jul2011yuming924@CONTENTS础知识¾基础知识¾LDO Regulator¾Switching Regulator (DC-DC)¾Charge Pump(电荷泵)Ch P¾W-LED Driver¾Voltage Reference (电压参考/基准源) Voltage Reference(¾Reset IC (Voltage Detector)¾MOSFET Driver¾PWM Controller基础知识Portable Device便携电子产品常用电源电力资源-电源管理IC-用电设备IC :5、3.3、2.5、1.8、1.2、0.9V 等;电力用电电源管马达:3、6、12V ;LED 灯背光;资源设备理IC LCD 屏:12、-5V ;AC Rectifier/PWM IC )AC :110、220VDC C t 升降压DC DC Ch P 等整流:PWM IC (3843或VIPER12)、开关电源DC 或电池DC Converter :LDO 、升降压DC-DC 、Charge Pump 等。
Reset IC 或电压检测:如808、809。
电池管理:保护IC 、充电管理(4054Fuel Gauge 等。
电池管理保护、充电管理)、g 等DC 或电池ACInverter/逆变:for CCFL …… (比喻:电荷-水、电流-水流、电容-水桶、电压-水压。
)便携产品电源系统设计要求便携产品电源设计需要系统级思维,在开发由电池供电的设备时,诸如便携产品电源设计需要系统级思维在开发由电池供电的设备时诸如手机、MP3、PDA、PMP、DSC等低功耗产品,如果电源系统设计不合理,则会影响到整个系统的架构、产品的特性组合、元件的选择、软件的设计和功率分配架构等同样在系统设计中也要从节省电池能量的角度出发多功率分配架构等。
Android7.0PowerManagerService之亮灭屏(一)
Android7.0PowerManagerService之亮灭屏(⼀)本篇从按下power按键后,按键事件从InputManagerService 传到PhoneWindowManager.java开始分析power 按键做屏幕亮灭过程的分析,关于power 按键的其他⾏为参考另⼀篇博⽂()(注:博客园显⽰的图⽚很模糊,上传的为⼤图,可以图⽚另存为查看)⾔归正传,本篇涉及的⼏个模块(⽂件)如下,先做个简单的介绍有个直观⼤概的了解,⽅便后⾯流程细节的理解。
Ø PowerManagerService.Java:(/frameworks/base/services/core/java/com/android/server/policy/PhoneWindowManager.java) PMS,是Android系统中的电源处理服务,主要负责电源相关的计算和决策,如是否应该灭屏或者让屏幕变暗,是否应该让系统休眠等等。
Ø DisplayPowerController.java:(/frameworks/base/services/core/java/com/android/server/display/DisplayPowerController.java) DPC,管理显⽰设备(这⾥指的显⽰设备是屏幕)状态,主要处理距离传感器(如打电话时候靠近则灭屏,离开时候屏幕亮起)以及亮灭屏动画(包括根据光感传感器计算屏幕⽬标亮度值)。
在DisplayManagerService.java(DMS)中实例化⼀个对象,以DMS为桥梁与PMS进⾏交互通过异步回调机制来通知PMS那些发⽣了改变。
同时也与WMS进⾏交互。
Ø DisplayPowerState.java:(/frameworks/base/services/core/java/com/android/server/display/DisplayPowerState.java) DPS,管理显⽰设备的状态仅在DPC中实例化⼀个对象,是DPC的⼀部分。
Power-Monitor 说明书
第二章 快速入门...........................................................................................................................10 一. 新建/打开一个配置 ........................................................................................................10 1. 新建/打开配置 ..........................................................................................................10 2. 设置串口 ...................................................................................................................10 3. 设置逆变器 ...............................................................................................................11 4. 设置 ADMA 传感器..................................................................................................12 5. 设置测量电表 ...........................................................................................................12 6. 设置合肥阳光、SMA 等传感器..............................................................................13 7. 系统设置 ...................................................................................................................14 二. 保存配置 .........................................................................................................................15 三. 运行数据采集..................................................................................................................15 四. 查看结果 .........................................................................................................................15 1. 设备网络图 ...............................................................................................................15 2. Logo 状态图 ..............................................................................................................16 3. 面板状态图 ...............................................................................................................17 4. 通用状态 ...................................................................................................................18 5. 设备运行状态 ...........................................................................................................19 6. 设备详细 ...................................................................................................................19 7. 输出功率 ...................................................................................................................20 8. 当天发电量 ...............................................................................................................20 9. 逆变器采集数据 .......................................................................................................21 10. 电表采集数据 .........................................................................................................21 11. 温度采集数据 .........................................................................................................22 12. PV 面板温度采集数据............................................................................................22 13. 光照采集数据 .........................................................................................................23 14. 风速采集数据 .........................................................................................................24 15. 风向采集数据 .........................................................................................................24 16. 报警信息 .................................................................................................................25 17. 网格 .........................................................................................................................25
深入解析android5.1healthd
深⼊解析android5.1healthdhealthd主要是读取电池节点的信息,传给BatteryService。
或者在关机充电等使⽤。
注意healthd中使⽤的是kernel的log。
下⾯先从main函数分析int main(int argc, char **argv) {int ch;int ret;klog_set_level(KLOG_LEVEL);healthd_mode_ops = &android_ops;if (!strcmp(basename(argv[0]), "charger")) {//解析输⼊参数如果是charger的使⽤charger_ops,这⾥就不做介绍healthd_mode_ops = &charger_ops;} else {while ((ch = getopt(argc, argv, "cr")) != -1) {//分析输⼊命令,各个命令对应不同的charger_opsswitch (ch) {case 'c':healthd_mode_ops = &charger_ops;break;case 'r':healthd_mode_ops = &recovery_ops;break;case '?':default:KLOG_ERROR(LOG_TAG, "Unrecognized healthd option: %c\n",optopt);exit(1);}}}ret = healthd_init();//healthd做初始化if (ret) {KLOG_ERROR("Initialization failed, exiting\n");exit(2);}healthd_mainloop();//主函数KLOG_ERROR("Main loop terminated, exiting\n");return 3;}如果是正常开机,不⾛关机充电等,healthd_mode_ops = &android_ops;⽽这⾥⾯具体的函数在后⾯进⾏详细的介绍。
Android BatteryStatsHelper深入理解(and5.1)
Android BatteryStatsHelper深入理解(and5.1)BatteryStatsHelper这个类主要是统计各个应用,多用户的每个用户,以及蓝牙,屏幕等耗电统计。
一般使用BatteryStatsHelper这个类,先要new一个实例,然后再调用create函数:下面我们就先从create分析,两种create方法,其中sStatsXfer是静态的[java] view plain copypublic void create(BatteryStats stats) {mPowerProfile = new PowerProfile(mContext);mStats = stats;}public void create(Bundle icicle) {if (icicle != null) {mStats = sStatsXfer;mBatteryBroadcast = sBatteryBroadcastXfer;}mBatteryInfo = IBatteryStats.Stub.asInterface(ServiceManager.getService(BatteryStats.SERVICE_NAME));mPowerProfile = new PowerProfile(mContext);}mPowerProfile是从power_profile.xml读取的各个器件的电源消耗参数,文件如下:[java] view plain copy<device name="Android"><!-- Most values are the incremental current used by a feature,in mA (measured at nominal voltage).The default values are deliberately incorrect dummy values.OEM's must measure and provide actual values beforeshipping a device.Example real-world values are given in comments, but theyare totally dependent on the platform and can varysignificantly, so should be measured on the shipping platformwith a power meter. --><item name="none">0</item><item name="screen.on">100</item> <!-- ~200mA --><item name="screen.full">200</item> <!-- ~300mA --><item name="bluetooth.active">90.5</item> <!-- Bluetooth data transfer, ~10mA --><item name="bluetooth.on">2.5</item> <!-- Bluetooth on & connectable, but not connected, ~0.1mA --><item name="wifi.on">1.25</item> <!-- ~3mA --><item name="wifi.active">130</item> <!-- WIFI data transfer, ~200mA --><item name="wifi.scan">100</item> <!-- WIFI network scanning, ~100mA --><item name="dsp.audio">30.5</item> <!-- ~10mA --><item name="dsp.video">72.5</item> <!-- ~50mA --><item name="radio.active">135</item> <!-- ~200mA --><item name="radio.scanning">5.3</item> <!-- cellular radio scanning for signal, ~10mA --> <item name="gps.on">30</item> <!-- ~50mA --><!-- Current consumed by the radio at different signal strengths, when paging --><array name="radio.on"> <!-- Strength 0 to BINS-1 --><value>3.5</value> <!-- ~2mA --><value>2.4</value> <!-- ~1mA --></array><!-- Different CPU speeds as reported in/sys/devices/system/cpu/cpu0/cpufreq/stats/time_in_state --><array name="cpu.speeds"><value>624000</value> <!-- 624 MHz CPU speed --><value>699563</value> <!-- 699 MHz CPU speed --><value>799500</value> <!-- 799 MHz CPU speed --><value>899438</value> <!-- 899 MHz CPU speed --><value>999375</value> <!-- 999 MHz CPU speed --><value>1099313</value> <!-- 1099 MHz CPU speed --><value>1199250</value> <!-- 1199 MHz CPU speed --><value>1299188</value> <!-- 1299 MHz CPU speed --><value>1399125</value> <!-- 1399 MHz CPU speed --><value>1499063</value> <!-- 1499 MHz CPU speed --><value>1599000</value> <!-- 1599 MHz CPU speed --></array><!-- Current when CPU is idle --><item name="cpu.idle">2.2</item><!-- Current at each CPU speed, as per 'cpu.speeds' --><array name="cpu.active">//各个cpu频段的功耗<value>54</value><value>63</value><value>72</value><value>80</value><value>90</value><value>100</value><value>109</value><value>115</value><value>121</value><value>127</value><value>135</value></array><!-- This is the battery capacity in mAh (measured at nominal voltage) --><item name="battery.capacity">2000</item></device>接下来说下refreshStats是用来更新电池最新状态的,statsType是指充电状态还是非充电状态,asUsers指的是userId(多用户)[java] view plain copypublic void refreshStats(int statsType, List<UserHandle> asUsers) {final int n = asUsers.size();SparseArray<UserHandle> users = new SparseArray<UserHandle>(n);for (int i = 0; i < n; ++i) {UserHandle userHandle = asUsers.get(i);users.put(userHandle.getIdentifier(), userHandle);}refreshStats(statsType, users);}/*** Refreshes the power usage list.*/public void refreshStats(int statsType, SparseArray<UserHandle> asUsers) {refreshStats(statsType, asUsers, SystemClock.elapsedRealtime() * 1000,SystemClock.uptimeMillis() * 1000);}接下来分析下refreshStats函数[java] view plain copypublic void refreshStats(int statsType, SparseArray<UserHandle> asUsers, long rawRealtimeUs, long rawUptimeUs) {// Initialize mStats if necessary.getStats();mMaxPower = 0;mMaxRealPower = 0;mComputedPower = 0;mTotalPower = 0;mWifiPower = 0;mBluetoothPower = 0;mAppMobileActive = 0;mAppWifiRunning = 0;mUsageList.clear();mWifiSippers.clear();mBluetoothSippers.clear();mUserSippers.clear();mUserPower.clear();mMobilemsppList.clear();if (mStats == null) {return;}mStatsType = statsType;mRawUptime = rawUptimeUs;mRawRealtime = rawRealtimeUs;mBatteryUptime = mStats.getBatteryUptime(rawUptimeUs);mBatteryRealtime = mStats.getBatteryRealtime(rawRealtimeUs);mTypeBatteryUptime = puteBatteryUptime(rawUptimeUs, mStatsType);mTypeBatteryRealtime = puteBatteryRealtime(rawRealtimeUs, mStatsType);mBatteryTimeRemaining = puteBatteryTimeRemaining(rawRealtimeUs);//获取电池剩余时间mChargeTimeRemaining = puteChargeTimeRemaining(rawRealtimeUs);//获取充电剩余时间if (DEBUG) {Log.d(TAG, "Raw time: realtime=" + (rawRealtimeUs/1000) + " uptime="+ (rawUptimeUs/1000));Log.d(TAG, "Battery time: realtime=" + (mBatteryRealtime/1000) + " uptime="+ (mBatteryUptime/1000));Log.d(TAG, "Battery type time: realtime=" + (mTypeBatteryRealtime/1000) + " uptime="+ (mTypeBatteryUptime/1000));}mMinDrainedPower = (mStats.getLowDischargeAmountSinceCharge()* mPowerProfile.getBatteryCapacity()) / 100;mMaxDrainedPower = (mStats.getHighDischargeAmountSinceCharge()* mPowerProfile.getBatteryCapacity()) / 100;processAppUsage(asUsers);//计算每个uid的耗电情况// Before aggregating apps in to users, collect all apps to sort by their ms per packet.for (int i=0; i<mUsageList.size(); i++) {BatterySipper bs = mUsageList.get(i);puteMobilemspp();if (bs.mobilemspp != 0) {mMobilemsppList.add(bs);}}for (int i=0; i<mUserSippers.size(); i++) {List<BatterySipper> user = mUserSippers.valueAt(i);for (int j=0; j<user.size(); j++) {BatterySipper bs = user.get(j);puteMobilemspp();if (bs.mobilemspp != 0) {mMobilemsppList.add(bs);}}}Collections.sort(mMobilemsppList, new Comparator<BatterySipper>() {@Overridepublic int compare(BatterySipper lhs, BatterySipper rhs) {if (lhs.mobilemspp < rhs.mobilemspp) {return 1;} else if (lhs.mobilemspp > rhs.mobilemspp) {return -1;}return 0;}});processMiscUsage();//计算比如屏幕、wifi、蓝牙等耗电if (DEBUG) {Log.d(TAG, "Accuracy: total computed=" + makemAh(mComputedPower) + ", min discharge="+ makemAh(mMinDrainedPower) + ", max discharge=" + makemAh(mMaxDrainedPower));}mTotalPower = mComputedPower;if (mStats.getLowDischargeAmountSinceCharge() > 1) {if (mMinDrainedPower > mComputedPower) {double amount = mMinDrainedPower - mComputedPower;mTotalPower = mMinDrainedPower;addEntryNoTotal(BatterySipper.DrainType.UNACCOUNTED, 0, amount);//加一个未统计电量} else if (mMaxDrainedPower < mComputedPower) {//double amount = mComputedPower - mMaxDrainedPower;addEntryNoTotal(BatterySipper.DrainType.OVERCOUNTED, 0, amount);//加一个over统计}}Collections.sort(mUsageList);}下面先看processAppUsage函数,这个函数是看uid的耗电信息。
android5.1 PowerManagerService和DisplayPowerControler、DisplayPowerState关系
android5.1 PowerManagerService和DisplayPowerControler、DisplayPowerState关系PowerManagerService在updateDisplayPowerStateLocked中与DisplayPowerControler交互,详细看代码:[java] view plain copyprivate boolean updateDisplayPowerStateLocked(int dirty) {final boolean oldDisplayReady = mDisplayReady;if ((dirty & (DIRTY_WAKE_LOCKS | DIRTY_USER_ACTIVITY | DIRTY_W AKEFULNESS| DIRTY_ACTUAL_DISPLAY_POWER_STA TE_UPDA TED | DIRTY_BOOT_COMPLETED| DIRTY_SETTINGS | DIRTY_SCREEN_BRIGHTNESS_BOOST)) != 0) { mDisplayPowerRequest.policy = getDesiredScreenPolicyLocked();// Determine appropriate screen brightness and auto-brightness adjustments.int screenBrightness = mScreenBrightnessSettingDefault;float screenAutoBrightnessAdjustment = 0.0f;boolean autoBrightness = (mScreenBrightnessModeSetting ==Settings.System.SCREEN_BRIGHTNESS_MODE_AUTOMATIC);if (isValidBrightness(mScreenBrightnessOverrideFromWindowManager)) {screenBrightness = mScreenBrightnessOverrideFromWindowManager;autoBrightness = false;} else if (isValidBrightness(mTemporaryScreenBrightnessSettingOverride)) {screenBrightness = mTemporaryScreenBrightnessSettingOverride;} else if (isValidBrightness(mScreenBrightnessSetting)) {screenBrightness = mScreenBrightnessSetting;}if (autoBrightness) {screenBrightness = mScreenBrightnessSettingDefault;if (isValidAutoBrightnessAdjustment(mTemporaryScreenAutoBrightnessAdjustmentSettingOverride)) {screenAutoBrightnessAdjustment =mTemporaryScreenAutoBrightnessAdjustmentSettingOverride;} else if (isValidAutoBrightnessAdjustment(mScreenAutoBrightnessAdjustmentSetting)) {screenAutoBrightnessAdjustment = mScreenAutoBrightnessAdjustmentSetting;}}screenBrightness = Math.max(Math.min(screenBrightness,mScreenBrightnessSettingMaximum), mScreenBrightnessSettingMinimum);screenAutoBrightnessAdjustment = Math.max(Math.min(screenAutoBrightnessAdjustment, 1.0f), -1.0f);// Update display power request.mDisplayPowerRequest.screenBrightness = screenBrightness;mDisplayPowerRequest.screenAutoBrightnessAdjustment =screenAutoBrightnessAdjustment;eAutoBrightness = autoBrightness;eProximitySensor = shouldUseProximitySensorLocked();mDisplayPowerRequest.lowPowerMode = mLowPowerModeEnabled;mDisplayPowerRequest.boostScreenBrightness = mScreenBrightnessBoostInProgress;if (mDisplayPowerRequest.policy == DisplayPowerRequest.POLICY_DOZE) { mDisplayPowerRequest.dozeScreenState = mDozeScreenStateOverrideFromDreamManager;mDisplayPowerRequest.dozeScreenBrightness =mDozeScreenBrightnessOverrideFromDreamManager;} else {mDisplayPowerRequest.dozeScreenState = Display.STATE_UNKNOWN;mDisplayPowerRequest.dozeScreenBrightness = PowerManager.BRIGHTNESS_DEFAULT;}mDisplayReady = mDisplayManagerInternal.requestPowerState(mDisplayPowerRequest,//调用DisplayPowerControler的requestPowerstate接口mRequestWaitForNegativeProximity);mRequestWaitForNegativeProximity = false;}return mDisplayReady && !oldDisplayReady;}接下来我们再看看mDisplayManagerInternal这个成员变量:在systemready中[java] view plain copymDisplayManagerInternal = getLocalService(DisplayManagerInternal.class);。
packagemanagerservice详解
packagemanagerservice详解一、PackageManagerService简介PackageManagerService是Android系统中负责管理应用安装、卸载、包管理、权限管理、更新等操作的核心服务。
它对应用的生命周期进行管理,为开发者提供一套完整的应用管理方案。
二、PackageManagerService的核心功能1.安装和卸载应用PackageManagerService支持通过Intent、Apk安装器等途径安装应用,同时也支持根据用户需求卸载应用。
2.应用权限管理PackageManagerService可以为应用分配权限,确保应用在运行过程中能够访问所需的资源。
此外,它还能监控应用的权限使用情况,保障用户隐私安全。
3.应用包管理PackageManagerService提供对应用包的管理功能,包括安装、更新、卸载等操作。
它还能对应用包进行权限检查、签名验证等,确保应用包的安全性。
4.应用更新和升级PackageManagerService负责检测应用的更新和升级,可以向用户推送更新通知,并根据用户的选择执行更新操作。
5.应用动态加载PackageManagerService支持动态加载应用,使得应用在运行时可以动态地加载和卸载模块,提高应用的灵活性和可扩展性。
三、PackageManagerService在Android系统中的作用PackageManagerService在Android系统中扮演着至关重要的角色。
它负责管理应用的安装、卸载、运行等操作,确保应用在合规的前提下运行。
同时,它还为开发者提供了一套便捷的应用管理方案,使得开发者能够更加专注于应用功能的开发。
四、PackageManagerService的使用方法1.获取PackageManagerService实例在Android项目中,可以通过以下代码获取PackageManagerService实例:```javaPackageManager packageManager = getPackageManager();```2.使用PackageManagerService安装/卸载应用```javaIntent intent = new Intent(Intent.ACTION_VIEW);PackageManager.InstallPackage(intent, packageManager);```3.使用PackageManagerService管理应用权限```javaPackageManager.grantPermission(packageName, permission);```4.使用PackageManagerService管理应用包```javaPackageManager.movePackage(sourcePackageName, targetPackageName);```5.使用PackageManagerService更新/升级应用```javaPackageManager.updatePackage(packageName, updatePath);```五、PackageManagerService的局限性与优化PackageManagerService在管理应用过程中,可能会受到系统资源、应用本身等因素的影响,导致部分功能无法正常使用。
Android结合源码分析Power按键处理流程
Android结合源码分析Power按键处理流程 这是之前团队进⾏技术交流时,我选择的⼀个主题,那段时间解决power锁屏按键的bug,搞得头⼤,所以借此机会结合Android8.0源码去分析Power键的处理流程,也将此分享出来,希望对⼤家有所帮助,本⽂为博主原创⽂章,有不对的地⽅,欢迎⼤家指正!作者:版权声明:本⽂为博主原创⽂章,转载请注明出处,谢谢! Android系统中,⼀般的按键都可以在应⽤中处理,但是,对于系统级别的按键上层应⽤是⽆法收到消息的,也就是说,你的APP是⽆法直接处理的。
针对这种系统级的按键事件,都是在Event事件分发前处理。
Event事件分发后,只有包含有Activity的APP才能处理事件;若APP⽆法处理,则需要在PhoneWindowManager中处理。
本⽂所讲的Power键则属于该种情况。
即⽤户触发Power键,底层收到按键会回调InputMonitor的函数dispatchUnhandledKey()。
⼀、为何最终处理者是PhoneWindowManager? 通过上⽂可知最终事件的处理是由PhoneWindowManager完成的;那么,按键后,系统是如何传递到PhoneWindowManager?下⾯就从源码的⾓度分析⼀下该过程。
WindowManagerService:Framework 最核⼼的服务之⼀,负责窗⼝管理。
InputManagerService:输⼊管理服务。
上述两个服务与Power按键相关,但是两者是如何关联的,就要从它们的创建说起.我们都知道,Android系统中的核⼼进程是system_server,对应SystemServer类,在其run()⽅法中会启动⼀堆的service,当然包括上述两个服务。
具体源码分析如下: 1、先创建inputManager,再创建WindowManagerService对象时,可发现作为参数引⽤了上述inputManager,且创建了PhoneWindowManager实例:源码路径:frameworks/base/services/java/com/android/server/SystemServer.javaprivate void startOtherServices() {......inputManager = new InputManagerService(context); //输⼊系统服务【step_SystemServer_1】...... //【step_SystemServer_2】wm = WindowManagerService.main(context, inputManager,mFactoryTestMode != FactoryTest.FACTORY_TEST_LOW_LEVEL,!mFirstBoot, mOnlyCore, new PhoneWindowManager()); //PhoneWindowManager实例ServiceManager.addService(Context.WINDOW_SERVICE, wm);ServiceManager.addService(Context.INPUT_SERVICE, inputManager);} 源码路径:frameworks/base/services/core/java/com/android/server/wm/WindowManagerService.javaprivate WindowManagerService(Context context, InputManagerService inputManager,boolean haveInputMethods, boolean showBootMsgs, boolean onlyCore,WindowManagerPolicy policy) {......mPolicy = policy; //实例: PhoneWindowManager对象【step_InputMonitor_2】 ......} 2、启动inputManager之前,设置了⼀个回调接⼝: //消息分发之前回调--->查看InputManagerService inputManager.setWindowManagerCallbacks(wm.getInputMonitor()); inputManager.start(); 3、InputMonitor.java:【底层是C/C++相关的,博主对C也不太了解,此处就不作分析了】 底层收到按键会回调InputManagerService的dispatchUnhandledKey()--->InputMonitor的函数dispatchUnhandledKey()。
pmbus从机处理逻辑
pmbus从机处理逻辑PMBus(Power Management Bus)从机是一种基于串行通信协议的电源管理设备,用于连接电源管理器和各种电源设备。
PMBus从机处理逻辑是指在该设备中负责解析、执行和响应主机发送的命令和数据的一系列操作。
PMBus从机的处理逻辑主要包括接收和解析命令、执行命令和发送响应。
具体来说,PMBus从机的处理逻辑可以分为以下几个步骤:1.接收和解析命令:PMBus从机首先需要接收主机发送的命令。
这些命令是通过串行通信线路传输的,PMBus从机需要解析通信协议,提取出有效的命令和数据。
PMBus从机通常会进行校验,确保接收到的命令和数据的完整性和正确性。
2.执行命令:一旦PMBus从机解析并确认了接收到的命令和数据,它就会根据命令的要求执行相应的操作。
这些操作可能包括设置电源输出电压、电流和频率,查询电源工作状态,以及对电源进行故障检测和保护等。
PMBus从机会根据命令和数据的要求,控制内部电路和模块进行相应的操作。
3.发送响应:在执行完命令后,PMBus从机需要向主机发送响应。
这些响应包括执行结果、状态信息和所需的数据等。
PMBus从机会将响应打包成符合通信协议的数据包,通过串行线路发送给主机。
主机可以根据从机的响应进行进一步的处理和控制。
PMBus从机处理逻辑的核心是命令解析和执行。
解析命令是将串行通信协议中的二进制数据转换为可理解的命令和数据。
这需要根据PMBus协议规范进行解析,包括识别命令字节、数据格式和校验等。
执行命令需要根据命令字节和数据的要求,将其映射到相应的操作和配置参数上。
这可能涉及到调节电源的输出电压和电流、设置保护机制、调整工作模式等。
PMBus从机处理逻辑的设计需要考虑多个因素。
首先,从机的处理速度和响应时间要求与主机的通信协议和数据传输速率相匹配。
其次,从机需要支持PMBus协议规范中定义的各种命令和数据类型,以满足主机的控制和监测需求。
此外,PMBus从机还需要具备稳定的电源供电和抗干扰能力,以保证正常的工作和通信。
activitymanagerservice详解
activitymanagerservice详解ActivityManagerService详解ActivityManagerService是Android系统中非常重要的一个系统服务,它主要负责管理Activity的生命周期、任务栈、进程、服务等,是Android系统中一个极为重要的服务。
本文将分步骤对ActivityManagerService进行详细解析,帮助读者更好地理解Android系统中的Activity管理机制。
一、ActivityManagerService的作用ActivityManagerService主要负责以下4个方面:1、管理Activity的生命周期:ActivityManagerService负责启动和管理Activity的生命周期,包括调用Activity的onCreate, onStart, onResume等生命周期方法。
2、管理Activity的任务栈:ActivityManagerService负责管理Activity的任务栈,将不同的Activity分配到不同的任务栈中,并且可以调整任务栈的顺序。
3、管理进程:ActivityManagerService负责管理进程,将多个Activity分配到同一个进程中。
4、管理服务:ActivityManagerService也负责管理服务,保证服务的正常运行。
二、ActivityManagerService的基本工作流程ActivityManagerService的基本工作流程如下:1、接收Activity的请求:ActivityManagerService接收来自Activity的请求,并将其放入待执行队列中。
2、创建Activity:当Activity可见时,ActivityManagerService会回调Activity的生命周期方法,创建Activity实例并显示。
3、管理Activity任务栈:ActivityManagerService将不同的Activity分配到不同的任务栈中,并且可以调整任务栈的顺序。
Intel_CPU_Power_Management培训
PWR plug in & AFTERG3_EN=0
G3(Mech. Off) System is unplugged RTC battery continues to supply power to RTC
PWR plug in & AFTERG3_EN=1
Page 6
Global system state
Agenda
• Introduction • Overview of all power states Global States Device States CPU States PCIe Link PM States Sleep States • Reset • Backup
Page 7
Device States : General
Hibernate
Wake event
OS initiate Power off
G1(Sleeping State) No System Traffic MCH, ICH and CPU off G2(Soft Off) - No System Traffic - System is off - Small part of ICH remains on to accept wake up event.
Bus Masters Allowed
All
Notes
Break
C5/C6
o CPU flushes cache prior to entry, so snoops aren’t necessary. CPU will be [almost] fully powered down. o ICH asserts STPCLK#, DPSLP#, STP_CPU#, DPRSTP#, DPRSLPVR, #PMSYNC o MCH or ICH asserts SLP# o Most CPU I/F signals are latched o Same pins as C4, but different timings and abbreviated messaging
Android Framework------之PowerManagerService的功能
Android Framework------之PowerManagerService的功能自从接触Android系统已经一年多了,这段时间内对于Android系统的Framework 层的各个模块都有过接触,有时也做过分析,但是一直没能形成一个总结性的东西。
这次下定决心,好好整理整理对于Android系统的学习梳理一下自己的思路。
本文一方面是为了自己梳理下知识,文中涉及的内容,基本是拾人牙慧,很少有自己的东西,最多也就算是自己的总结;除此作用之外,如果能为后来者引玉,也算是一点功德吧。
这次首先是对Android 系统中的PowerManagerService进行下整理。
之所以先选择PowerManagerService,是因为这个模块相对于Android系统中其他的模块而言,与系统其他的模块之间的交互较少,而且Framework中的PowerManagerService模块是由Google开发并维护的,虽然以Linux Kernel的Power为基础,但是它们之间的耦合度低,完全可以把两者分开,单独进行分析也不会造成困惑。
接下来,我会从不同的角度,分别介绍下PowerManagerService的功能。
还是先来看看PowerManagerService在Framework中的目录结构吧。
PowerManagerService在Android4.2源码中的位置是:/frameworks/base/services/Java/com/android/server/power/,在这个目录下有以下文件:DisplayBlanker.javaDisplayPowerController.javaDisplayPowerRequest.javaDisplayPowerState.javaElectronBeam.javaNotifier.javaPowerManagerService.javaRampAnimator.javaScreenOnBlocker.javaShutdownThread.javaSuspendBlocker.javaWirelessChargerDetector.java这些文件中,个人认为对于PoweManagerService而言除了本身的代码,较为重要的有DisplayPowerController.java,DisPlayPowerState.java,Notifier.java.而DisplayPowerRequest相当于一个辅助类,用来存储一些统一的属性和变量,让PowerManagerService和DisplayPoerController, DisplayPowerState交互时能够使用统一的变量。
Android5.1 PowerManagerService深入分析
Android5.1 PowerManagerService深入分析PowerManagerService提供Android系统的电源管理服务,主要功能是控制系统的待机状态,控制显示屏的开关和亮度调节等。
PowerManagerService在systemserver中创建,加入到serviceManager中:[java] view plain copymPowerManagerService = mSystemServiceManager.startService(PowerManagerService.class);先从构造函数分析,代码如下:[java] view plain copypublic PowerManagerService(Context context) {super(context);mContext = context;//创建处理消息的线程mHandlerThread = new ServiceThread(TAG,Process.THREAD_PRIORITY_DISPLAY, false /*allowIo*/);mHandlerThread.start();//创建Handler,注意mHandlerThread.getLooper(),每一个线程都只有一个looper,这样消息的处理会放在这个线程中mHandler = new PowerManagerHandler(mHandlerThread.getLooper());synchronized (mLock) {mWakeLockSuspendBlocker = createSuspendBlockerLocked("PowerManagerService.WakeLocks");mDisplaySuspendBlocker = createSuspendBlockerLocked("PowerManagerService.Display");//防止cpu进入睡眠状态mDisplaySuspendBlocker.acquire();mHoldingDisplaySuspendBlocker = true;mHalAutoSuspendModeEnabled = false;mHalInteractiveModeEnabled = true;//当前系统状态正常运行状态mWakefulness = WAKEFULNESS_AW AKE;nativeInit();nativeSetAutoSuspend(false);nativeSetInteractive(true);}}构造函数比较简单,创建了一个接受消息处理的线程,cpu持锁不让手机睡眠,以及一些变量的初始化。
Android电源管理框架
客户端创建了WakeLock,需要调用acquire()
核心服务之PoweManagerService
客户端创建了WakeLock,PM需要调用 acquire()函数,而该函数又调用了服务端PMS 的 acquireWakeLock函数与PMS交互以保证 电力的供应正常。
核心服务之PoweManagerService
Android电源框架的简介
1.2 电源管理框架的结构组织
Android的电源管理主要是通过锁和定时器来切 换系统的状态,使系统的功耗降至最低,整个系 统的电源管理架结构分为四大部分:应用层,框 架层,HAL层和Kernel层。
Android电源框架的简介
Android电源框架的简介
HAL层:该层只有一个Power.c文件,该文件通过sysfs的 方式与kernel进行通信。主要功能有申请wake_lock,释 放wake_lock,设置屏幕状态等。用户空间的native 库绝 不能直接调用Android电源管理(见上图)。绕过 Android运行时的电源管理政策,将破坏该系统。所有对 电源管理的调用应通过Android的PowerManager API来 完成。
核心服务之PoweManagerService
3、Power类以及LightService类的介绍 PowerManagerService有时需要进行点亮屏幕,打 开键盘灯等操作,为此Android提供了Power类以及 LightService满足PowerManagerService的要求,这 两个类比较简单,但是背后的kernel层相对复杂:
核心服务之PoweManagerService 2.2 PowerManagerService继承结构
核心服务之PoweManagerService
PowerManagementFeatures电源管理模式设定
Power Management Features(电源管理模式设定)ACPI Suspend Type(选择暂停模式的种类):1.[s1(poweron-suspend)]:开启power on suspend功能。
2.[s3(suspend-to-ram)]:开启suspend to ram功能。
Power button function(是用来选择您系统的电源关闭方式):1.[delay 4 sec.]:持续地按住电源按钮不放超过四秒钟即可将系统的电源关闭,这可以防止当您不小心地撞到或是按下电源按钮时不致将系统的电源关闭。
2.[instant-off]:按下然后松开电源按钮一次,这将会立刻地关闭系统的电源。
Run VGABIOS if s3 Resume:此项目共有三个选项可供选择:A uto→Y es→No,系统的默认值为Auto。
此项目可让您选择当系统自S3状态唤醒时,需不需要去执行vga bios的初始化动作。
Restore on ac power loss:此选项可选择当交流电源失效之后的系统动作。
[power off]: 当交流电源失效并回复以后,系统的电源仍维持在关闭的状态。
您必需按下电源开关以开启系统电源。
[power on]: 当交流电源失效并回复以后,系统的电源会自动地开启。
[last state]: 当交流电源失效并回复以后,系统将会回复到电源失效发生之前的状态。
如果系统在电源失效发生之前的状态是电源关闭的状态,当电源恢复时它将会维持在电源关闭的状态。
如果系统在电源失效发生之前的状态是电源开启的状态,当电源恢复时它将会维持在电源开启的状态。
Irq/event activity detect:按[enter] 键来进入其子画面:Power on function:此项目选择开启系统电源的途径。
[button only]: 只能按电源按钮开启系统电源。
[password]: 键入最高八个字符的密码来开启系统电源。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
and5.1PowerManagerService深入分析(二)PowerManager中各函数今天主要从PowerManager中的接口入手去分析PowerManagerService.先分析PowerManager中的一个内部类WakeLock,可以使用这个类持睡眠锁。
下面是PowerManager中WakeLock内部类来里面的代码:[java] view plain copypublic void acquire() {synchronized (mToken) {acquireLocked();}}/*** Acquires the wake lock with a timeout.* <p>* Ensures that the device is on at the level requested when* the wake lock was created. The lock will be released after the given timeout* expires.* </p>** @param timeout The timeout after which to release the wake lock, in milliseconds.*/public void acquire(long timeout) {synchronized (mToken) {acquireLocked();mHandler.postDelayed(mReleaser, timeout);//利用消息机制做一个timeout的持锁,mReleaser中是对该锁释放了}}private void acquireLocked() {if (!mRefCounted || mCount++ == 0) {// Do this even if the wake lock is already thought to be held (mHeld == true)// because non-reference counted wake locks are not always properly released.// For example, the keyguard's wake lock might be forcibly released by the// power manager without the keyguard knowing. A subsequent call to acquire// should immediately acquire the wake lock once again despite never having// been explicitly released by the keyguard.mHandler.removeCallbacks(mReleaser);Trace.asyncTraceBegin(Trace.TRACE_TAG_POWER, mTraceName, 0);try {mService.acquireWakeLock(mToken, mFlags, mTag, mPackageName,mWorkSource,//调用PMS的acquireWakeLockmHistoryTag);} catch (RemoteException e) {}mHeld = true;}}先看PMS里的acquireWakeLock函数,先做一些权限的检查,然后就调用acquireWakeLockInternal函数。
[java] view plain copy@Override // Binder callpublic void acquireWakeLock(IBinder lock, int flags, String tag, String packageName, WorkSource ws, String historyTag) {if (lock == null) {throw new IllegalArgumentException("lock must not be null");}if (packageName == null) {throw new IllegalArgumentException("packageName must not be null");}PowerManager.validateWakeLockParameters(flags, tag);mContext.enforceCallingOrSelfPermission(android.Manifest.permission.WAKE_LOCK, null);if ((flags & PowerManager.DOZE_W AKE_LOCK) != 0) {mContext.enforceCallingOrSelfPermission(android.Manifest.permission.DEVICE_POWER, null);}if (ws != null && ws.size() != 0) {mContext.enforceCallingOrSelfPermission(android.Manifest.permission.UPDATE_DEVICE_STATS, null);} else {ws = null;}final int uid = Binder.getCallingUid();final int pid = Binder.getCallingPid();final long ident = Binder.clearCallingIdentity();try {acquireWakeLockInternal(lock, flags, tag, packageName, ws, historyTag, uid, pid);} finally {Binder.restoreCallingIdentity(ident);}}acquireWakeLockInternal函数[java] view plain copyprivate void acquireWakeLockInternal(IBinder lock, int flags, String tag, String packageName, WorkSource ws, String historyTag, int uid, int pid) {synchronized (mLock) {if (DEBUG_SPEW) {Slog.d(TAG, "acquireWakeLockInternal: lock=" + Objects.hashCode(lock)+ ", flags=0x" + Integer.toHexString(flags)+ ", tag=\"" + tag + "\", ws=" + ws + ", uid=" + uid + ", pid=" + pid);}WakeLock wakeLock;int index = findWakeLockIndexLocked(lock);//查找这个IBinder的锁。
因为每个应用都是一个进程,通过binder通信与PMS交互。
IBinder是唯一的boolean notifyAcquire;if (index >= 0) {//找到wakeLock = mWakeLocks.get(index);if (!wakeLock.hasSameProperties(flags, tag, ws, uid, pid)) {//如果属性不一样就更新// Update existing wake lock. This shouldn't happen but is harmless.notifyWakeLockChangingLocked(wakeLock, flags, tag, packageName,//通知电池统计uid, pid, ws, historyTag);wakeLock.updateProperties(flags, tag, packageName, ws, historyTag, uid, pid);}notifyAcquire = false;} else {//没找到wakeLock = new WakeLock(lock, flags, tag, packageName, ws, historyTag, uid, pid);//新建一个WakeLock加入列表try {lock.linkToDeath(wakeLock, 0);} catch (RemoteException ex) {throw new IllegalArgumentException("Wake lock is already dead.");}mWakeLocks.add(wakeLock);notifyAcquire = true;}applyWakeLockFlagsOnAcquireLocked(wakeLock, uid);//下面详细分析mDirty |= DIRTY_WAKE_LOCKS;//mDirty 标志位置位updatePowerStateLocked();//更新power状态if (notifyAcquire) {// This needs to be done last so we are sure we have acquired the// kernel wake lock. Otherwise we have a race where the system may// go to sleep between the time we start the accounting in battery// stats and when we actually get around to telling the kernel to// stay awake.notifyWakeLockAcquiredLocked(wakeLock);//通知电池统计那块}}}findWakeLockIndexLocked函数[java] view plain copyprivate int findWakeLockIndexLocked(IBinder lock) {final int count = mWakeLocks.size();for (int i = 0; i < count; i++) {if (mWakeLocks.get(i).mLock == lock) {return i;}}return -1;}applyWakeLockFlagsOnAcquireLocked函数[java] view plain copyprivate void applyWakeLockFlagsOnAcquireLocked(WakeLock wakeLock, int uid) { if ((wakeLock.mFlags & PowerManager.ACQUIRE_CAUSES_WAKEUP) != 0//如果持的锁有ACQUIRE_CAUSES_WAKEUP,还有屏幕锁的话,会wakeup设备&& isScreenLock(wakeLock)) {wakeUpNoUpdateLocked(SystemClock.uptimeMillis(), uid);}}[java] view plain copy@SuppressWarnings("deprecation")private static boolean isScreenLock(final WakeLock wakeLock) {switch (wakeLock.mFlags & PowerManager.W AKE_LOCK_LEVEL_MASK) { case PowerManager.FULL_WAKE_LOCK:case PowerManager.SCREEN_BRIGHT_W AKE_LOCK:case PowerManager.SCREEN_DIM_WAKE_LOCK:return true;}return false;}updatePowerStateLocked这个函数是所有的地方都会调用,因此我们最后分析。