Click here to learn
about this Sponsor:
Home  |  News  |  Articles  |  Forum

  Home arrow Windows For Devices Articles arrow What is HORM and how can you use it?

What is HORM and how can you use it?
By Doug

Rate This Article: Add This Article To:

Foreword: HORM is an acronym for "Hibernate Once Resume Many," a valuable feature for quickly booting a Windows XP Embedded system. In this whitepaper, Mike Moini, a developer on the Windows XP Embedded team, reviews the basics of HORM and describes some new APIs added in Feature Pack 2007.





What is HORM and how can you use it?

by Mike Moini

The HORM feature allows a rapid reboot and return to the same hibernated image over and over again. Much different from the way you typically use hibernate mode on shut down with your desktop. With your desktop non-XP embedded operating system, you can only restore the image you hibernated last and hibernated images do not persist across reboots. If you want to return to the same image after a rapid reboot on your device, your choice is HORM.

HORM works with EWF (Enhanced Write Filter). This feature is not new to the XP Embedded operating system and was introduced in SP2. We did not change the functionality of HORM in FP2007. We changed the way HORM is activated and enabled. Previously, for HORM to work, you had to manually create a file in the root directory. To disable HORM, you had to disable EWF, reboot (for EWF disable to take effect), delete the file, reboot (for resume from hibernation to get clear), enable EWF and reboot again (for EWF enable to take effect).

Not any more. Now the interface to HORM has become more user friendly and more importantly, it requires fewer reboots when you need to deactivate HORM. "Why would you need to deactivate such a marvelous feature," you ask? When you want to service your device: upgrade the software, install a new application, apply a security patch, etc.

HORM process
(Click image to enlarge)
First of all, lets cover the basics together. You must first enable HORM in your configuration before being able to activate or deactivate it at run time. If HORM is not enabled during configuration (that is before building an embedded image), the run time commands and APIs to activate or deactivate HORM will return an error. Something like "HORM is not supported on this image." So, you have to plan ahead if you want to use HORM on a system. The process for using HORM looks like the block diagram pictured at right.

Once you have enabled HORM for your image, it defaults to being active. All subsequent activation/deactivation of HORM takes effect immediately and does not require a reboot. There are two ways to activate/deactivate HORM; one is using the EWF API and the other one is using the EWF command line interface (EWFMGR).

There 3 new APIs added to EWF; two for activation/deactivation and one for returning the state of HORM. These are: EwfMgrActivateHORM (HANDLE hDevice),EwfMgrDeactivateHORM (HANDLE hDevice), and EwfMgIsHORMActivated( HANDLE hDevice)). Sample code to use these APIs is provided at the end of this article.

There are only two new command options added to EWFMGR (-activatehorm and -deactivatehorm). The current state of HORM is added to generic command responses. This is the response that gets printed to the screen when you type "ewfmgr" with no command option.


Sample code illustrating use of HORM APIs
// EWFTestAPI.cpp : Defines the entry point for the console application.
//
#include "stdafx.h"
#include windows.h
#include windef.h
#include winbase.h
#include winioctl.h
#include stdio.h
#include stdlib.h
#include string.h

#define EWFIMP
#include "ewfapi.h"
#include "ewfapip.h"

// main body
int _tmain(int argc, _TCHAR* argv[])
{
HANDLE hSrcDevice = INVALID_HANDLE_VALUE;
char szSource[255];
char * psz;
int i;
BOOL ret_status;

*szSource = '\0';
strcpy_s(szSource, "\\\\.\\c:");
hSrcDevice = CreateFile((LPCWSTR)szSource, GENERIC_WRITE | GENERIC_READ,
FILE_SHARE_READ | FILE_SHARE_WRITE, NULL, OPEN_EXISTING,
FILE_FLAG_NO_BUFFERING, NULL);

if (hSrcDevice == INVALID_HANDLE_VALUE)
{
printf("Failed opening the target device %s with error %ld\n",
szSource, GetLastError());
return 0;
}
for (i = 1; i argc; i++)
{
psz = (char *)argv[i];
if (*psz == '?')
{
goto usage;
}
else if (*psz == 'A')
{
printf("Activation...");
ret_status = EwfMgrActivateHORM(hSrcDevice);
if (ret_status)
printf("PASSED\n");
else
printf ("FAILED\n");
}
else if (*psz == 'D')
{
printf("Deactivating...");
ret_status = EwfMgrDeactivateHORM(hSrcDevice);
if (ret_status)
printf("PASSED\n");
else
printf ("FAILED\n");
}
else if (*psz == 'G')
{
printf("Geting the state...");
ret_status = EwfMgIsHORMActivated(hSrcDevice);
if (ret_status)
printf("Activated\n");
else
printf ("Deactivated\n");
}
else
goto usage;
}
return 0;
usage:
printf ("USAGE: EWFTestAPI A: Activates HORM \n");
printf (" EWFTestAPI D: Deactivates HORM\n");
printf (" EWFTestAPI G: Returns the state of HORM (NotSupported,
Active, or Deactive)\n");
return 0;
}


Copyright (c) 2006 Microsoft Corp. All rights reserved. Reproduced by WindowsForDevices.com with permission. This article was originally published on the Windows XP Embedded Team Blog, here.



About the author: Mike Moini is a software developer who joined Microsoft's Windows XP Embedded product team last summer. For the Windows XP Embedded Feature Pack 2007 product, he was part of the Embedded Enabling Features team, and was specifically responsible for EWF enhancements and HORM enhancements. Moini, who was born in Tehran, holds BS and MS degrees in Electrical Engineering and has developed embedded and real-time software, mostly for wired and wireless communication equipment.



Related stories:


Discuss What is HORM and how can you use it?
 
>>> Be the FIRST to comment on this article!
 
 
 
>>> More Windows For Devices Articles Articles          >>> More By Doug
 



Windows XP for Embedded Applications
This white paper describes the benefits of using Windows XP when developing embedded applications.

A Manager's Guide to Selecting a Mobile Device Operating System
This white paper offers a comparative review of Microsoft Windows CE and Windows Mobile.

Visual Basic 6.0 to .NET Migration
This paper focuses on the methodology and techniques which Infosys (Microsoft Technology Center) has developed for migrating VB 6.0 Applications to .NET. Our approach ensures a smooth, cost effective, and efficient migration.

Mobile Device Security: Securing the Handheld, Securing the Enterprise
This whitepaper identifies security threats to corporate data on mobile devices and details how mobile devices can become a "backdoor" to the enterprise.

Mobile Device Security: The Eight Areas of Risk
It's common knowledge that adding mobile devices to your network increases security risks. There are multiple facets to mobile security, all of which should be paid close attention to. This E-Guide presents a more in depth look into the eight key areas of securing wireless devices.

Quality Assurance and .NET
This paper discusses best practices for functional, regression and load testing of .NET applications.

SCADA Security in Integrated Networks
As businesses leverage their SCADA systems by integrating them into the business networks, they must also assure the security of the SCADA system.

The Advantages of Small Form Factor HMI
HMIs have mutated and changed with new requirements, and they have become more flexible and capable. And while they've been doing that, they've become smaller and more useful.

9 Critical Requirements for Web Application Security
Learn why your Web applications expose dangerous security breaches and what’s required to effectively protect your Web applications and the sensitive information behind them.

Got a HOT tip?   please tell us!
Free weekly newsletter
Enter your email...
Click here for a profile of each sponsor:
PLATINUM SPONSORS
(Become a sponsor)

ADVERTISEMENT
(Advertise here)

Updated! The latest Windows-powered...

mobile phones!

other cool
gadgets

HOT TOPICS
Microsoft targets PNDs with new embedded OS
Microsoft tips .NET MF 3.0 highlights
Microsoft previews Windows Embedded Standard
Microsoft offers free Windows CE 6.0 textbook
Microsoft renames embedded operating systems
Microsoft unveils Windows Mobile 6.1
New Atom models target low-cost PCs
REFERENCE GUIDES
Windows Device Showcase
Intro to Windows Embedded
Intro to Shared Source
Real-time Windows Embedded
Windows Embedded books
Join our Windows Embedded discussion forums:
Windows XP Embedded
Windows CE
Windows Mobile


Windows Embedded developer newsgroups
Windows CE
XP Embedded
PocketPC
Smartphone

Microsoft's Windows Embedded resources
Embedded dev center
Mobile dev center
Windows CE tutorials
XP Embedded tutorials
Windows Embedded seminars
Windows Embedded application categories
3rd-party partners


BREAKING NEWS

• Pico-ITX PC takes to the road and the skies
• Thin client offers legacy ports
• Boards add watchdog functionality to PC/104-Plus systems
• 11.6-inch netbook has AMD processor
• Microsoft planning riposte to Google's "Chrome OS"?
• Embedded student competition winner is buggy (on purpose)
• Asus preps convertible netbooks
• Media-savvy reference design sports touchscreen, DVB-H
• Sony joins the netbook fray
• 2010 Census kicks off with Windows Mobile
• Sprint offers 99-cent netbook
• SODIMM module has industrial focus
• Microsoft picks finalists in Embedded Development competition
• Cortex-A8 SBCs target signage and kiosks
• Student competition offers a different kind of fireworks


MOST POPULAR (last 90 days)
• "Netbook" uses Intel's Atom N270
• Windows CE takes on Linux in low-end netbooks
• HTC ups Touch resolution
• Microsoft unleashes new embedded OS
• Windows Mobile phone gets 800 x 480 display
• HTC spins WiMAX phone?
• Smart camera sports Atom
• Dual-core AMD netbook gets rave review
• Windows Mobile 7 "delayed"
• GPS phone uses new Marvell "Tavor" chip
MOST POPULAR (Classics from the vault)
Windows XP Embedded USB boot
Troubleshooting Windows XPe's blue screen "Stop 0x0000007B" error
Asus reveals $190 mini notebook
Windows Mobile 6 SDKs available for download
Windows Mobile VPN client plays with Cisco
HTC adds GPS to Windows Mobile Touch line
Microsoft unveils Windows Mobile 6.1
Guide to HTC's Windows Mobile smartphone platforms
• HTC releases Touch Diamond ROM upgrade
Customizing Windows XP Embedded thin clients

Also visit our sister sites:

Sign up for WindowsForDevices.com's...


Or, follow us on Twitter...