US20050257215A1 - Automated software upgrade utility - Google Patents

Automated software upgrade utility Download PDF

Info

Publication number
US20050257215A1
US20050257215A1 US11/051,118 US5111805A US2005257215A1 US 20050257215 A1 US20050257215 A1 US 20050257215A1 US 5111805 A US5111805 A US 5111805A US 2005257215 A1 US2005257215 A1 US 2005257215A1
Authority
US
United States
Prior art keywords
upgrade
client device
client
instructions
server
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US11/051,118
Inventor
Philip Denby
Douglas Hughes
Jonathan Fletcher
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Intermec IP Corp
Original Assignee
Intermec IP Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Intermec IP Corp filed Critical Intermec IP Corp
Priority to US11/051,118 priority Critical patent/US20050257215A1/en
Publication of US20050257215A1 publication Critical patent/US20050257215A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/34Network arrangements or protocols for supporting network services or applications involving the movement of software or configuration parameters 
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/60Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
    • H04L67/62Establishing a time schedule for servicing the requests

Definitions

  • Embodiments of this invention relate to automatically upgrading software.
  • the automated software upgrade utility allows a customer, product supplier or software vendor to upgrade the operating system, firmware, applications and data files on any product regardless of the product type and characteristics. This upgrade process can be invoked from a remote location or via interaction directly with the target device.
  • the automated upgrade process is independent of the device hardware platform, operating system, the network transport utilized by the device, and the target device itself.
  • the automated software upgrade process also allows for modification of the hardware configuration of the target device, e.g., change and reformat a hard drive partition.
  • the automated upgrade utility may reside at remote sites, such as the user's place of business, and periodically query the product supplier for firmware upgrades.
  • the upgrade utility may reside with the product supplier and periodically locate remote products and perform the upgrade process.
  • the software upgrade utility retains the ability to identify all pertinent product characteristics, freeing the developer of the firmware upgrade from concerns regarding installing the upgrade across a wide range of product characteristics and nearly endless possible configurations.
  • FIG. 1 is a block diagram illustrating a suitable environment for aspects of the invention.
  • FIG. 2 is an example screen display of an example System Maintenance Menu.
  • FIG. 3 is an example screen display of a source inquiry dialog box.
  • FIG. 4 is an example screen display of a minor upgrade confirmation dialog box.
  • FIG. 5 is an example screen display of a major D upgrade confirmation dialog box.
  • FIG. 6 is an example screen display of a major C upgrade confirmation dialog box.
  • FIG. 7 is an example screen display of a severe upgrade confirmation dialog box.
  • the automated software upgrade utility enables a product supplier or software vendor to remotely upgrade the firmware on any of its products, such as automatic data collection (“ADC”) device platforms, regardless of product type or product characteristics.
  • the upgrade utility may reside at remote sites, such as the product owner's place of business, and periodically query the product provider for firmware upgrades.
  • the upgrade utility may reside with the product provider and periodically locate products at a product owner's facility and perform the upgrade process.
  • the software upgrade utility retains the ability to identify all pertinent product characteristics, freeing the developer of the firmware upgrade from concerns regarding installing the upgrade across a wide range of products, each having nearly endless possible configurations.
  • the invention is applicable for both ADC device platforms, ADC servers, and associated devices such as printers and radios.
  • Upgrades may be classified from minor to severe.
  • the minor upgrades are typically small software patches that have been determined not to pose a serious problem to other functionality.
  • severe upgrades constitute functionality that must be carefully provided to the product so as not disrupt the product or its functionality.
  • the Product Supplier or Software Vendor publishes a software update, i.e., patch, upgrade or new release.
  • the published releases can either be pushed down to the software upgrade server or they can be pulled from the published location.
  • the software upgrade utility can be distributed in one of four methods. The first being, the software upgrade utility can act as a publishing location for other software upgrade servers, i.e., push the software release to other software upgrade servers or allow them to pull the latest software releases from the master software upgrade server.
  • the second method is to schedule jobs within the software upgrade utility to push the software release to the target device(s), data collection devices registered in IDRS, at the requested time.
  • the third method involves when devices initially register with IDRS for the first time. If IDRS is configured such that a specific configuration must exist on the device, and software is a component of that standard configuration, then the designated files are automatically transmitted to the target device.
  • the fourth method involves a device that has an outdated version of the software resident. Upon startup of the device a check is done to ensure that the correct version(s) of the applicable software is resident, if not the device initiates the request for the upgrade to be initiated.
  • FIG. 1 illustrates a server 100 having a firmware upgrade utility 101 .
  • the server 100 may be operated by the producer of ADC device platform, for example.
  • the firmware upgrade utility 101 utilizes a transportation network 102 to reach a host 103 .
  • the firmware upgrade utility 101 may perform its operations using any transportation network 102 .
  • the host 103 may comprise a centralized computing facility for a purchaser of the ADC device platforms products, for example.
  • the host 103 in turn communicates with one or more controllers 104 over a transportation network 107 that in turn communicate with one or more ADC device platforms 105 over a transportation network 108 .
  • Each controller 104 typically communicates with one or more ADC device platforms 105 .
  • the firmware upgrade utility 101 may also perform its operations using any transportation network 107 and any transportation network 108 .
  • the upgrade utility 101 determines whether the upgrade concerns the controllers 104 and/or the ADC device platforms 105 .
  • the upgrade utility 101 locates the communications procedure for communicating with the host 103 , the controllers 104 , and if necessary with the ADC device platforms 105 .
  • the upgrade utility 101 then contacts the host 103 and uses resources on the host 103 to communicate with the controllers 104 .
  • the host 103 may identify the type of the transportation network 107 to the upgrade utility 101 .
  • the upgrade utility 101 examines the controller 104 for its characteristics pertinent to the upgrade. Alternatively, the upgrade utility 101 may consult a database 106 that contains the characteristics of the controllers 104 and the ADC device platforms 105 .
  • the upgrade utility 101 locates the appropriate upgrade, determines how to proceed with the upgrade given the controller's characteristics, and provides the controller 104 with the necessary upgrade. If the upgrade also applies to the ADC device platforms 105 , then the upgrade utility 101 examines the ADC device platform 105 for its characteristics pertinent to the upgrade. Alternatively, the upgrade utility 101 may consult the database 106 for pertinent ADC device platform characteristics. The upgrade utility 101 then locates the appropriate upgrade, determines how to proceed with the upgrade given the ADC device platform's characteristics, and provides the ADC device platform 105 with the necessary upgrade. Finally, the upgrade utility 101 ensures that the controllers 104 and the ADC device platforms are returned to the same state they were in prior to the upgrade.
  • the DCS Upgrade Utility is a tool to manage the distribution of upgrade files placed on the Data Collection Server 300 (DCS 300 ).
  • the DCS upgrade utility will allow the upgrade process to be started from the DCS 300 , or from the ESD tool.
  • the ESD tool can be at a remote site (remotely) or on the target DCS 300 (locally).
  • the DCS upgrade utility will eliminate diskette swapping and prompting.
  • BIOS BIOS upgrades will continue to be accomplished by diskette.
  • a minor upgrade does not require rebooting or shutting processes down.
  • a major C upgrade requires the DCS 300 to reboot.
  • a major D upgrade requires some processes like data collection to shutdown. When the upgrade is finished, the stopped processes will be restarted.
  • a severe upgrade is an upgrade that requires changing partition sizes and/or changing operating systems. This also requires the DCS 300 to reboot. If a severe upgrade is necessary, it will require an upgrade CD-ROM in the CD-ROM drive.
  • DCS Upgrade Utility in conjunction with the ESD tool, a DCS 300 software upgrade can be scheduled for an inactive time and doesn't require that an operator be present when the upgrade is being accomplished. The amount of time an upgrade takes to perform is also reduced. Initiating an upgrade, from the System Maintenance Menu at the DCS 300 , by selecting DCS Upgrade Utility, also requires little attention. Just start the upgrade and walk away.
  • the upgrade can be started remotely or at a DCS 300 using the ESD tool.
  • a start time can be chosen so the upgrade doesn't interfere with data collection.
  • the upgrade can also be started from the System Maintenance Menu at the DCS 300 by selecting DCS Upgrade Utility.
  • the DCS software must be at 300 ver 1.0 or greater.
  • the controller must be at 0200 ver 3.0 and have the DCS Upgrade Utility installed. In this case, if the upgrade is started from the controller, “g: ⁇ upgrade ⁇ upgrade” must be entered at the command line.
  • the DCS Upgrade Utility can be installed from ESD or from a diskette.
  • the upgrade files can be transferred over to the DCS 300 by ESD, or FTP without the use of a CD-ROM.
  • the upgrade files can be transferred from an Intermec Web page to a DCS 300 with ESD.
  • the upgrade files can be transferred from an Intermec Web page to a PC.
  • ESD or FTP in the binary mode can transfer the files to the DCS 300 . If the upgrade files are to reside on the DCS 300 , up to 120 MegaBytes must be available on drive d: of the hard drive depending on the size of the upgrade files.
  • a CD-ROM is used in the upgrade of an 0200 controller, the user will need to enable the parallel port in the BIOS at the beginning of the upgrade and disable the parallel port in the BIOS at the end of the upgrade.
  • the DCS 0300 comes with a CD-ROM drive installed and no BIOS changes are necessary.
  • the user When using the ESD tool remotely, the user will download a file (e.g. 300V1 — 0.zip) from an Intermec Web page to a PC.
  • the ESD tool will unzip the file in a directory.
  • the ESD tool will copy the upgrade files to the d: ⁇ upgrade directory on the target DCS 300 .
  • the user will then schedule the upgrade using the ESD tool.
  • ESD will initiate the upgrade remotely at the appropriate time.
  • the target DCS 300 must have a LAN card installed with IP enabled.
  • the user can put an upgrade CD-ROM in the CD-ROM drive at the target DCS 300 and schedule the upgrade from ESD (locally or remotely).
  • the user When using FTP, the user will download a file (e.g. 300V1 — 0.zip) from an Intermec Web page to a PC. The user will unzip the file in a directory. The user will login into the DCS 300 using FTP and set the binary mode. The user will change directories to d: ⁇ upgrade. Then, the user will copy all the files to the DCS 300 . To use this method, the target DCS 300 must have a LAN card installed with IP enabled.
  • a file e.g. 300V1 — 0.zip
  • the upgrade can then be started at the DCS 300 , from the System Maintenance Menu, or by ESD (remotely or locally).
  • An upgrade can be initiated from ESD remotely or locally or the upgrade can be started from the DCS 300 System maintenance menu.
  • DCS Upgrade Utility from the System Maintenance Menu.
  • FIG. 3 is an example screen display of a source inquiry dialog box. Referring to FIG. 3 , after the source of the upgrade files has been entered a menu will come up and ask if the user wants to start the upgrade or cancel. Pressing start will initiate the upgrade. Pressing cancel with end the upgrade.
  • FIGS. 4-7 illustrate different dialog boxes that the DCS Upgrade Utility displays dependent upon the severity of the upgrade. Once a Start button has been pressed on any of the dialogs of FIGS. 4-7 , the upgrade cannot be stopped.
  • a file, upgrade.ini is extracted from the zipped up files.
  • This file contains the parameters of the upgrade, the software version of the upgrade, and a version controller.
  • the version controller is a list of versions of DCS 300 software that can be upgraded to its upgrade software version.
  • the DCS 300 's software version is compared to the version controller. If the DCS 300 's software version is in the list, then the upgrade will proceed.
  • a readme.doc can be found in the same directory as the upgrade files (d: ⁇ upgrade or CD-ROM).
  • the readme.doc file contains information on what versions of DCS 300 software the upgrade files can upgrade.
  • the parameter list in the upgrade.ini file controls the upgrade behavior. It controls if the DCS 300 needs to reboot, shut down various DCS 300 processes, or proceed as is. The rebooting and process control is done automatically and requires no user input.
  • a user at the DCS 300 during an upgrade will see various messages at a command prompt window on the DCS 300 screen depending on the size of the upgrade.
  • the DCS 300 will reboot to an alternate operating system. These are the messages that can show on the screen based on additional upgrade.ini parameters:
  • the DCS 300 will reboot to an alternate operating system. These are the messages that can show on the screen based on additional upgrade.ini parameters:
  • the ESD tool can also inquire the version of the upgrade software on the DCS 300 and the version of the DCS 300 software to make sure the upgrade will proceed normally.
  • the DCS upgrade Utility will behave the same when the operating system is ported to Windows NT in a future release of the DCS 300 .
  • zip file for each drive will be needed.
  • the zip file will be made with the use of a batch file.
  • the batch file will contain all the names and directories of the files that need to be updated.
  • a typical command in the batch file to zip a single file is “zip-a os_drive.zip c: ⁇ ibmcom ⁇ 1e100t.rsp”. This line adds (-a) c: ⁇ ibmcom ⁇ 1e100t.rsp to the zip file os_drive.zip.
  • To zip the entire ibmcom directory use this command: “zip -a -r -S os_drive.zip c: ⁇ ibmcom”. Because the files that need updated are different for each upgrade, new zip files will be needed for each
  • volume Serial Number is D0AD-8D81 Directory of D:(OR G:) ⁇ UPGRADE ⁇ 01/01/01 12:00a ⁇ DIR> . 01/01/01 12:00a ⁇ DIR> .. 12/08/97 01:17p 83,418,895 OS_DRIVE.ZIP 12/08/97 01:21p 12,131,654 NEXTGEN.ZIP 12/08/97 01:21p 12,131,654 BOOT.ZIP 12/08/97 01:21p 12,131,654 UPGRADE.EXE 09/04/97 08:31a ⁇ DIR> SVGA 09/04/97 08:31a ⁇ DIR> VGA 09/04/97 08:31a ⁇ DIR> TOOLS 7 File(s) 95,550,549 bytes Directory of D:(OR G:) ⁇ UPGRADE ⁇ SVGA 09/04/97 08:31a ⁇ DIR> .
  • PROTOCOL.INI 3 File(s) 983 bytes Directory of D:(OR G:) ⁇ UPGRADE ⁇ TOOLS ⁇ CONFIG ⁇ 1E100ET 09/04/97 08:31a ⁇ DIR> . 09/04/97 08:31a ⁇ DIR> .. 06/02/97 02:22p 1,367 PROTOCOL.INI 3 File(s) 1,367 bytes Directory of D:(OR G:) ⁇ UPGRADE ⁇ TOOLS ⁇ CONFIG ⁇ 1E100T 09/04/97 08:31a ⁇ DIR> . 09/04/97 08:31a ⁇ DIR> ...
  • PROTOCOL.INI 3 File(s) 938 bytes Directory of D:(OR G:) ⁇ UPGRADE ⁇ TOOLS ⁇ CONFIG ⁇ 2E 09/04/97 08:31a ⁇ DIR> . 09/04/97 08:31a ⁇ DIR> .. 06/04/97 08:31a 962
  • PROTOCOL.INI 3 File(s) 962 bytes Directory of D:(OR G:) ⁇ UPGRADE ⁇ TOOLS ⁇ CONFIG ⁇ 2E100 09/04/97 08:31a ⁇ DIR> . 09/04/97 08:31a ⁇ DIR> ...
  • PROTOCOL.INI 3 File(s) 1,013 bytes Directory of D:(OR G:) ⁇ UPGRADE ⁇ TOOLS ⁇ CONFIG ⁇ 2E100T 09/04/97 08:31a ⁇ DIR> . 09/04/97 08:31a ⁇ DIR> .. 04/30/97 11:19a 1,393 PROTOCOL.INI 3 File(s) 1,393 bytes Directory of D:(OR G:) ⁇ UPGRADE ⁇ TOOLS ⁇ CONFIG ⁇ 2E1T 09/04/97 08:31a ⁇ DIR> . 09/04/97 08:31a ⁇ DIR> ...
  • the DCS upgrade utility can be started from ESD, from the System Maintenance Menu, or from the command line.
  • the Upgrade Utility is a stand alone application with the following command line syntax:
  • the qualifier “q” is optional. It is used to pre-test the upgrade to see if it will proceed normally.
  • the “s” qualifier is used to indicate that a save and activate will be done if it is necessary. Either the “q” or “s” is used, not both at the same time.
  • ESD will first send a system transaction to the message handler with these one of these sets of parameters:
  • a query will just run the phase 0 part of the upgrade and place the results in a file (upgrade.log).
  • the results include error messages, parameters of the upgrade, the current phase of the upgrade, and the size of the disk drive.
  • ESD will check upgrade.log for error messages. If error messages are found it will not proceed with the upgrade. If no error messages are found, ESD will send a system transaction to the message handler with these parameters:
  • upgrade.exe is started by 300UgradeUtil in ngpblist.c. 300UgradeUtil will prompt the user for the source of the upgrade file, then call upgrade.exe with these parameters:
  • 300UgradeUtil will parse upgrade.log for error messages. If error messages are found, a message will be displayed on a message box on the GUI and the upgrade will end. If there was no errors, upgrade.ini will be parsed again for the parameters of the upgrade, and prompt for a last chance cancel or start based on the parameters. If start is selected, 300UgradeUtil will call upgrade.exe with these parameters:
  • upgrade.ini will be extracted from each zip file.
  • This file will contain the type of the upgrade, the subsections of the type of upgrade, the software version of the upgrade, the version level, and a version controller.
  • the parameters will be used to select the sections of the upgrade that need to be performed. As enhancements are made to the DCS 300 , and new sections to the upgrade process are identified, additional parameters can be added to this file and the upgrade executable.
  • the upgrade.ini file is also for security. If the file cannot be extracted from a zip file then the upgrade will not proceed.
  • An upgrade.ini file typically contains the following tags and parameter definitions:
  • the version level refers to the parameters that can be stored in upgrade.ini. Upgrade.exe (Upgrade.c) contains a version level also. This version level refers to the parameters that upgrade.exe can read. The version numbers must match. When upgrade.exe is ran, it will compare the two version numbers. If the numbers don't match, the upgrade will end.
  • the Upgrade header contains the type of upgrade and the version of the upgrade. These are the types of the upgrade (upgrade.ini):
  • the Processes header contains the processes that need to shut down. SHUTDOWN will need to specify which processes to stop, such as nextgen.exe or data collection. A NO means “don't shutdown processes” and a YES means “shutdown the process”. For all other types of upgrades this subheading is ignored.
  • Changed Software Changed software is only used for SEVERE and REBOOT upgrades. Changed software contains a list of the partitions that will have software updates. Changed software is used to indicate that the software in a partition has changed. For a SEVERE upgrade, If the partition size or file system will change, then, the corresponding setting here will also need to be set to YES because the software will have to be put back after the partition has been reformated.
  • Changed partitions is only used for SEVERE upgrades. All other types will ignore this information.
  • Changed Partitions contains a list of the partitions that will be changed. If the partition is set to NO, it will not be changed. If it is set to YES, it will be changed. Not all partitions will change. It is possible that only one will change (it didn't change size, it could change the file system perhaps). If the BOOT partition changed, the SWAPPER partition should also be changed. This is so the BOOT partition can change sizes. These will be set to one if data on the partition changed (files) or the partition information changed (size, file system, . . . ).
  • the START parameter indicates if the partition is to be created at the bottom or top of the free space on the disk.
  • the current file system is HPFS. This will be changed to FAT for Windows NT.
  • the files system type is used by fdisk when the new partition is created and by format.
  • Vtype indicates if the partition is primary or logical. Usually the operating system is on the primary partition and is on the c: drive.
  • the size information is used to create the partition. These numbers must be correct for the different drive sizes (540M, 2.5 Gig, and 2.2 Gig) or fdisk will return an error.
  • the name of the drive is important to delete the partition using fdisk. The name can be found by doing a fdisk/query. This will need to be done for all three sizes of drives (540M, 2.5 Gig, and 2.2 Gig). If other sizes of disk drives are used, the information will have to be added here too. These parameters are for fdisk.
  • the partition will not be deleted. If the size was no included the partition will not be created. And, if the file system was not specified, the partition will not be formated.
  • the swapper partition will need to be deleted, and recreated at a smaller size because there will be two new partitions.
  • the name of the partition will need to be included. Since it also needs to be created at a smaller size the, the size should also be included as well as the file system.
  • the nextgen and the OS partitions will not be deleted or recreated so the size, file system, and name information for the partitions should not be included.
  • the information on the nextgen and the OS partitions will change, so OS and NEXTGEN should be set to YES under the changed software heading in upgrade.ini.
  • Two new partitions will be created—the boot partition and the boot manager. The names for these should not be included because they didn't exist before.
  • Disk size is the number of cylinders in the d: partition for each of the disk sizes. If a new hard drive is added, new entries will need to be added here. Currently in the field there are 540 Meg hard drives and 2.5 Gig hard drives. Soon there will be 2.2 Gig hard drives.
  • config.sys will be changed when creat_ng is ran. Also, a new config.ngc might be copied over. If the files are changed, they will have to be changed to reference the correct video drivers. Fix_Config will need to be set to YES if the config.ngc or config.sys is changed. If operating system is updated or replaced, then the video driver software for the correct card will have to be copied over to the appropriate directories. Copy_Files will need to be set to YES to cause the files to be copied over.
  • the version controller will contain the range of software that can be upgraded.
  • the type of upgrade shown in the example upgrade.ini file is SEVERE because the upgrade needs to delete and create partitions.
  • the only partition that will be deleted is the swapper partition. It is being deleted to make room for two more partitions.
  • the two new partitions are the alternate boot partition (BOOT) and boot manager.
  • the swapper partition will be recreated at a smaller size.
  • the OS and nextgen partitions will not be deleted or recreated, but new files will be copied over.
  • the boot partition name is not included because no boot partition was there before so no deletion of the partition will be attempted.
  • the delete sections of the upgrade looks for the name of the partition to delete. If the name is NULL the section will be skipped.
  • the name is not included because boot manager was not installed before.
  • Creat_ng will be ran, so Fix_Config under Video_Fix will be set to YES.
  • controller with 0200 Ver 3.0 software can be upgraded to DCS 300 Ver 1.0.
  • Upgrade messages will be sent to the controller screen as well as to a file, upgrade.log.
  • a default upgrade.log will be copied over to d: ⁇ upgrade.
  • Phase 0 messages are used by ESD and 300UgradeUtil to determine if the DCS upgrade utility will proceed without errors. This is what the default message file looks like:
  • phase 1 At the completion of each phase, the next phase to be ran is set here. There are currently six phases (0, 1, 2, 3, 4, and 5). None of the upgrades use all six phases.
  • the MINOR upgrade only uses phase 0 and phase 5.
  • a REBOOT upgrade uses phase 0, phase 4, and phase 5.
  • a SEVERE upgrade uses phase 0, phase 1, phase 2, phase 3, and phase 5.
  • a SHUTDOWN upgrade only uses phase 0 and phase 5.
  • the disk size is written to upgrade.log if the upgrade is SEVERE.
  • An IOCTL command is ran that queries the number of cylinders in drive.
  • a SEVERE and REBOOT upgrade will test to see if a save and activate is necessary. If the save and activate is necessary, the new default files will be copied over. Then data collection will be stopped, CM/2 will be ran, and then LAPs will be initiated. Timers will be used to wait to wait for data collection to stop, and for CM/2 setup and LAPs to finish.
  • the GUI needs to be changed to add the DCS 300 Upgrade Utility to the menu options. If the Upgrade Utility was selected, a new procedure in ngpblist.c will start the upgrade with the query option and examine the results in upgrade.log when the query is done. If there were no error in upgrade.log, the GUI will show a last chance box based on the type of upgrade (the type of upgrade is also in upgrade.log). If START was selected, the upgrade utility will be started without the query option.
  • the GUI needs to be changed to continuously check to see if there is an IPC call for a quiet save and activate.
  • the upgrade utility will need to be able to do a quiet save and avtivate without rebooting or user input.
  • Existing procedures like ActivateCfgOK, DcStopTimer, ActivateAfterStop, CheckCmsetup, ActivateAfterCM2, CheckLapsDone, and ActivateAfterLaps and the procedures they call will need to able to accept two more input parmater (quiet, or not quiet, and no reboot, or reboot possible).
  • the SHUTDOWN type of upgrade will not be used until the DCS 300 is migrated to Windows NT.
  • the new DCS 300 processes should be written with IPC hooks to stop them remotely.
  • Phase 0 determines if the upgrade files are valid, extracts upgrade.ini from the upgrade files, determines if the upgrade.exe is compatible with the upgrade.ini, and determines the type of upgrade. The results of phase 0 is output to upgrade.log. Then upgrade.exe ends.
  • the CreateUpgradeUtil function spawns the upgrade.exe. It then starts a xvt_timer and for each timer event generated, calls CkUpgradeLogFile. This function looks for the update.log file and when successfully opened verifies that no errors were generated by the upgrade.exe application. If errors are present, they are presented to the user in a XVT message dialog otherwise the success message that was written to the log file is displayed. If there were no errors, and based on the type of upgrade, a last resort box will show asking if the user wants to start or cancel the upgrade.
  • CD-ROM was selected as the source then verify a CD is in the drive.
  • This function is called when a E_TIMER event is received in the DCS Upgrade Utility dialog. Loop until a successful open is performed on the upgrade.log file or until nn timer events have be generated. If we time out, then inform the user and quit the process. After a successful open is performed, parse the upgrade.log file using the function:
  • Phase 0 tests to see if the upgrade files are valid and examines the parameters of the upgrade.
  • Phases 1, 2, and 3 are for SEVERE upgrades only.
  • Phases 1, 2, and 3 delete, create, and format partitions.
  • Phase 4 reboots the DCS 300 to the f: drive if the type of upgrade is REBOOT. MINOR and SHUTDOWN upgrades will jump from phase 0 to phase 5.
  • Phase 5 extracts the zip files.
  • an error message is logged to upgrade.log and the upgrade ends.
  • the version of the DCS 300 is compared to the version controller in upgrade.ini. If the DCS version doesn't fall in the range in the version controller, an error message is logged to upgrade.log and the upgrade ends.
  • the type of upgrade is retrieved and logged to upgrade.log. If it is a SEVERE upgrade, the disk size is also logged to upgrade.log. If no errors have occurred, the success messages is logged to upgrade.log. The message tells the current version of the DCS 300 and the version it is being upgraded to. If the “q” parameter was used to call upgrade.exe, the upgrade will end. If the “q” parameter was not used the phase is set to the proper value and the upgrade continues. The new phase is logged in upgrade.log.
  • the DCS 300 will do a save and activate if the /s parameter was passed in.
  • Phase 1 will extract upgdbkup.lst from one of the zip files and back up the users system files to the d: ⁇ upgrade directory. In phase 2 these files will be copied to the boot partition (f: drive).
  • phase I will delete the swapper partition if the name was set in upgrade.ini. This is so the boot partition can change sizes.
  • the boot partition will be deleted if the the name was set in upgrade.ini. If the delete of the boot partition failed an error message recorded to upgrade.log. The old partition settings will be in the upgrade.ini. If the partitions were deleted successfully, the new boot partition will be created if the size is not equal to zero.
  • Phase 2 will be entered in the upgrade.log so that when the DCS reboots, phase two will be started.
  • a new config.sys and startup.cmd will be copied over the old so that when the DCS 300 reboots to the c: drive, the upgrade program will run.
  • Phase two will format the swapper partition in the specified file system if the file system was set in upgrade.ini. If it fails, an error message will be recorded to upgrade.log and a error message will print to the screen and the upgrade will end.
  • the DCS 300 is not functional but it is bootable to the C: drive.
  • boot partition will be formatted in the specified file system if the file system was set in upgrade.ini. If an error occurs, an error message will be written to upgrade.log and the DCS 300 will be set up to boot up normally and the DCS will reboot to the C: drive. The DCS 300 is fully functional, but the upgrade failed. If no errors occur, boot_drive.zip will be exploded into the new drive and the backed up system files will be copied over as well as the upgrade.ini and upgrade.log files.
  • the d: drive will now be deleted if the name was set in upgrade.ini. If it fails, an error message will be recorded to upgrade.log, the swapper partition will be recreated, an error message will print to the screen, and the upgrade will end.
  • the DCS 300 is not functional but it is bootable to the C: drive.
  • the c: drive will now be deleted if the was set in upgrade.ini. If it fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will end.
  • the DCS 300 is not functional but it is bootable to the c: drive.
  • the DCS will reboot to the f: drive if OS, NEXTGEN, or SWAPPER is set to YES under the changed partitions heading in upgrade.ini.
  • Phase three will first format the os partition in the specified file system if the file system was set in upgrade.ini. If the format fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will end.
  • the DCS 300 is not functional and it is not bootable to the c: drive because there is no operating system on the c: drive. The DCS 300 was booted from the f: drive and is at a command prompt.
  • the nextgen partition will be formatted in the specified file system if the file system was set in upgrade.ini. If the format fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will end.
  • the DCS 300 is not functional and it is not bootable to the c: drive because there is no operating system on the c: drive. The DCS 300 was booted from the f: drive and is at a command prompt.
  • the swapper partition will be formatted in the specified file system if the file system was set in upgrade.ini. If the format fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will end.
  • the DCS 300 is not functional and it is not bootable to the c: drive because there is no operating system on the c: drive. The DCS 300 was booted from the f: drive and is at a command prompt. If there are no errors, the upgrade zip files are now ready to be exploded—increment the phase to 5 .
  • the phase is set to 5 in the log file.
  • the DCS 300 will do a save and activate if the /s parameter was passed in and if a save and activate is necessary. Now the DCS 300 will reboot.
  • upgdbkup.lst will be extracted from one of the zip files. This is the list of files to be backed up and restored. The system files will be copied to the d: ⁇ upgrade ⁇ backup directory. If the backup fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will reboot the DCS 300 to the c: drive. The DCS 300 is fully functional and operation will resume as normal except the upgrade did not complete successfully.
  • nextgen_drive.zip will be exploded in the d: drive. If the unzip fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will end.
  • the DCS 300 is might or might not be functional but it is bootable to the c: drive. The DCS 300 was booted from the f: drive and is at a command prompt.
  • creat ng will be ran to restore the user configuration. If the creat_ng fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will reboot to the c: drive and end.
  • the DCS 300 is functional but not configured.
  • the procedure systemRestore will be ran to restore the backed up system files. If the systemRestore fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will reboot to the c: drive and end.
  • the DCS 300 is functional but not configured fully.
  • the procedure EnableTcpipInConfigSys will be ran to start TCP/IP in the config.sys if it was set before. If TcpipInConfigSys fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will reboot to the c: drive and end.
  • the DCS 300 is functional but not configured fully.
  • the DCS 300 is functional but not configured fully.
  • the DCS 300 will now reboot to the c: drive and be ready for normal operation.

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Stored Programmes (AREA)

Abstract

The automated software upgrade utility allows a customer, product supplier or software vendor to upgrade the operating system, firmware, applications and data files on any product regardless of the product type and characteristics. This upgrade process can be invoked from a remote location or via interaction directly with the target device.

Description

    CROSS-REFERENCE TO RELATED APPLICATIONS
  • This application is a continuation of U.S. patent application Ser. No. 09/664,459, filed Sep. 18, 2000, now pending, which application is incorporated herein by reference in its entirety.
  • Additionally, this application claims the benefit under 35 U.S.C. § 119(e) of U.S. Provisional Patent Application No. 60/155,502, filed Sep. 22, 1999, which application is incorporated herein by reference in its entirety.
  • INCORPORATION BY REFERENCE OF COMPUTER PROGRAM LISTING APPENDIX
  • This application herein incorporates by reference the Computer Program Listing Appendix attached hereto as CD-ROMs entitled “Philip M. Denby, Douglas L. Hughes, and Jonathan D. Fletcher, “AUTOMATED SOFTWARE UPGRADE UTILITY,” 480062.665C1, Feb. 3, 2005.” This program listing is included on a total of two (2) compact discs. Compact discs “Copy 1” and “Copy 2” are identical copies. The files located on each compact disc copy include:
      • ngextrn.h, 3/26/04, 20 KB
      • ngpblist.c, 3/25/04, 25 KB
      • upgrade.c, 3/25/04, 270 KB
      • upgrade.h, 3/25/04, 25 KB
      • upgrade.ini, 3/25/04, 2004, 20 KB
    TECHNICAL FIELD
  • Embodiments of this invention relate to automatically upgrading software.
  • BACKGROUND AND SUMMARY
  • Automatic upgrade utilities are known in the prior art. However, prior art automatic upgrade utilities are not known to have provided firmware upgrades across an entire product line for units comprised of a plethora of different characteristics. In addition, prior art on automatic upgrade utilities are not known to operate across any network transports. Prior art on automatic upgrade utilities have rarely operated in the automatic data collection (“ADC”) device platform environment.
  • Many suppliers customize their products according to customer requirements. This is especially true with regard to products related to automatic data collection (“ADC”). Accordingly, the precise characteristics of the products sold by the supplier, even within a single product line, vary greatly. In the prior art, upgrades required a confusing disk swapping process and/or a direct serial connection to the device that required considerable user attention to ensure the upgrade completed successfully. Upgrades frequently consumed several hours, as each detail of the product being upgraded had to be painstakingly checked and disks constantly swapped. Moreover, an operator needed to be present to swap the diskettes. The presence of the operator often meant that during business hours the ADC device platform was unavailable for data collection while an upgrade was being accomplished. Many users were extremely reluctant to perform the installation procedure themselves because they were afraid of making mistakes and they were also concerned that they did not possess the requisite technical understanding to complete the process successfully.
  • The following summary lists the issues resolved by implementing the automated upgrade process:
      • Reduce the downtime of the device due to an upgrade being performed
      • Reduce inputs required from the user to eliminate operator error
      • Reduce the time required to perform an upgrade, reduce manpower required
      • Increase the odds of having the upgrade process conclude successfully
      • Allow for scheduling of the upgrade during off-hours
      • Initiate simultaneous upgrades to multiple target devices
      • Allow for grouping of devices to reduce redundant operations
      • Perform the upgrade over a network to many devices as well as over a serial connection to a single device
      • Allow for upgrades to occur from remote, centralized locations
      • Support differing scopes of upgrades via the same utility, i.e. install a patch versus install a new version of the operating system
      • Provide a single utility that can perform upgrades of a device's operating system, firmware, application and data files.
  • The automated software upgrade utility allows a customer, product supplier or software vendor to upgrade the operating system, firmware, applications and data files on any product regardless of the product type and characteristics. This upgrade process can be invoked from a remote location or via interaction directly with the target device.
  • The automated upgrade process is independent of the device hardware platform, operating system, the network transport utilized by the device, and the target device itself.
  • The automated software upgrade process also allows for modification of the hardware configuration of the target device, e.g., change and reformat a hard drive partition.
  • The automated upgrade utility may reside at remote sites, such as the user's place of business, and periodically query the product supplier for firmware upgrades. Alternatively, the upgrade utility may reside with the product supplier and periodically locate remote products and perform the upgrade process.
  • In both configurations, the software upgrade utility retains the ability to identify all pertinent product characteristics, freeing the developer of the firmware upgrade from concerns regarding installing the upgrade across a wide range of product characteristics and nearly endless possible configurations.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 is a block diagram illustrating a suitable environment for aspects of the invention.
  • FIG. 2 is an example screen display of an example System Maintenance Menu.
  • FIG. 3 is an example screen display of a source inquiry dialog box.
  • FIG. 4 is an example screen display of a minor upgrade confirmation dialog box.
  • FIG. 5 is an example screen display of a major D upgrade confirmation dialog box.
  • FIG. 6 is an example screen display of a major C upgrade confirmation dialog box.
  • FIG. 7 is an example screen display of a severe upgrade confirmation dialog box.
  • DETAILED DESCRIPTION
  • The automated software upgrade utility enables a product supplier or software vendor to remotely upgrade the firmware on any of its products, such as automatic data collection (“ADC”) device platforms, regardless of product type or product characteristics. The upgrade utility may reside at remote sites, such as the product owner's place of business, and periodically query the product provider for firmware upgrades. Alternatively, the upgrade utility may reside with the product provider and periodically locate products at a product owner's facility and perform the upgrade process. In both configurations, the software upgrade utility retains the ability to identify all pertinent product characteristics, freeing the developer of the firmware upgrade from concerns regarding installing the upgrade across a wide range of products, each having nearly endless possible configurations. The invention is applicable for both ADC device platforms, ADC servers, and associated devices such as printers and radios.
  • Upgrades may be classified from minor to severe. The minor upgrades are typically small software patches that have been determined not to pose a serious problem to other functionality. In contrast, severe upgrades constitute functionality that must be carefully provided to the product so as not disrupt the product or its functionality.
  • The Product Supplier or Software Vendor publishes a software update, i.e., patch, upgrade or new release. The published releases can either be pushed down to the software upgrade server or they can be pulled from the published location.
  • Once the software upgrade utility has received the published release, it can be distributed in one of four methods. The first being, the software upgrade utility can act as a publishing location for other software upgrade servers, i.e., push the software release to other software upgrade servers or allow them to pull the latest software releases from the master software upgrade server.
  • The second method is to schedule jobs within the software upgrade utility to push the software release to the target device(s), data collection devices registered in IDRS, at the requested time.
  • The third method involves when devices initially register with IDRS for the first time. If IDRS is configured such that a specific configuration must exist on the device, and software is a component of that standard configuration, then the designated files are automatically transmitted to the target device.
  • The fourth method involves a device that has an outdated version of the software resident. Upon startup of the device a check is done to ensure that the correct version(s) of the applicable software is resident, if not the device initiates the request for the upgrade to be initiated.
  • Following are the functional requirements for the automated upgrade utility:
      • Allow upgrades or replacement of a device's operating system, firmware, application and data files from a single utility.
      • Allow for scheduling of upgrades to occur at designated scheduled times or initiated manually at any time.
      • Allow for devices to be organized into logical groups to allow for a single event to initiate upgrades for multiple devices.
      • Allow for the upgrades to be performed via a remote, centralized location as well as from the location where the devices are physically located.
      • The upgrade process must be independent of the transport network that the device is attached to.
      • The upgrade process must support both devices that exist on wired networks as well as wireless networks.
      • The upgrade process itself must not involve any user involvement once it has been initiated.
      • Software to be upgraded can originate from any location, i.e. CD-ROM, telnet to the hard disk of system running the upgrade process, retrieved from a web site or bulletin board, etc.
      • If the nature of the upgrade requires the hardware configuration of the target device to change, then this must not require user intervention. It must be fully automated as well. An example is changing the size of the hard disk partitions or changing the operating system. After the upgrade is completed, the device must be returned back to a fully functional state such that it can be used in a production environment. All configuration parameters and applications must be restored to allow this to happen.
  • FIG. 1 illustrates a server 100 having a firmware upgrade utility 101. The server 100 may be operated by the producer of ADC device platform, for example. The firmware upgrade utility 101 utilizes a transportation network 102 to reach a host 103. The firmware upgrade utility 101 may perform its operations using any transportation network 102. The host 103 may comprise a centralized computing facility for a purchaser of the ADC device platforms products, for example. The host 103 in turn communicates with one or more controllers 104 over a transportation network 107 that in turn communicate with one or more ADC device platforms 105 over a transportation network 108. Each controller 104 typically communicates with one or more ADC device platforms 105. The firmware upgrade utility 101 may also perform its operations using any transportation network 107 and any transportation network 108.
  • The upgrade utility 101 determines whether the upgrade concerns the controllers 104 and/or the ADC device platforms 105. The upgrade utility 101 locates the communications procedure for communicating with the host 103, the controllers 104, and if necessary with the ADC device platforms 105. The upgrade utility 101 then contacts the host 103 and uses resources on the host 103 to communicate with the controllers 104. For example, the host 103 may identify the type of the transportation network 107 to the upgrade utility 101. The upgrade utility 101 examines the controller 104 for its characteristics pertinent to the upgrade. Alternatively, the upgrade utility 101 may consult a database 106 that contains the characteristics of the controllers 104 and the ADC device platforms 105. The upgrade utility 101 then locates the appropriate upgrade, determines how to proceed with the upgrade given the controller's characteristics, and provides the controller 104 with the necessary upgrade. If the upgrade also applies to the ADC device platforms 105, then the upgrade utility 101 examines the ADC device platform 105 for its characteristics pertinent to the upgrade. Alternatively, the upgrade utility 101 may consult the database 106 for pertinent ADC device platform characteristics. The upgrade utility 101 then locates the appropriate upgrade, determines how to proceed with the upgrade given the ADC device platform's characteristics, and provides the ADC device platform 105 with the necessary upgrade. Finally, the upgrade utility 101 ensures that the controllers 104 and the ADC device platforms are returned to the same state they were in prior to the upgrade.
  • 1.1. DCS Upgrade Utility
  • 1.1.1. Purpose and use of feature
  • The DCS Upgrade Utility is a tool to manage the distribution of upgrade files placed on the Data Collection Server 300 (DCS 300). The DCS upgrade utility will allow the upgrade process to be started from the DCS 300, or from the ESD tool. The ESD tool can be at a remote site (remotely) or on the target DCS 300 (locally). The DCS upgrade utility will eliminate diskette swapping and prompting.
  • BIOS upgrades will continue to be accomplished by diskette.
  • There are four classifications of upgrades: Minor, Reboot, Shutdown, and Severe. A minor upgrade does not require rebooting or shutting processes down. A major C upgrade requires the DCS 300 to reboot. A major D upgrade requires some processes like data collection to shutdown. When the upgrade is finished, the stopped processes will be restarted. A severe upgrade is an upgrade that requires changing partition sizes and/or changing operating systems. This also requires the DCS 300 to reboot. If a severe upgrade is necessary, it will require an upgrade CD-ROM in the CD-ROM drive.
  • 1.1.2. Results of Feature Usage
  • Previous upgrades required disk swapping and considerable user input. Sometimes the upgrade took hours. An operator needed to be present to swap diskettes. This usually meant that during business hours the controller was unavailable for data collection while an upgrade was being accomplished.
  • With the DCS Upgrade Utility in conjunction with the ESD tool, a DCS 300 software upgrade can be scheduled for an inactive time and doesn't require that an operator be present when the upgrade is being accomplished. The amount of time an upgrade takes to perform is also reduced. Initiating an upgrade, from the System Maintenance Menu at the DCS 300, by selecting DCS Upgrade Utility, also requires little attention. Just start the upgrade and walk away.
  • 1.1.3. Feature Options
  • The upgrade can be started remotely or at a DCS 300 using the ESD tool. A start time can be chosen so the upgrade doesn't interfere with data collection. The upgrade can also be started from the System Maintenance Menu at the DCS 300 by selecting DCS Upgrade Utility.
  • 1.1.4. Assumptions
  • To use the DCS Upgrade Utility, the DCS software must be at 300 ver 1.0 or greater. Or, To use the DCS Upgrade Utility, the controller must be at 0200 ver 3.0 and have the DCS Upgrade Utility installed. In this case, if the upgrade is started from the controller, “g:\upgrade\upgrade” must be entered at the command line. The DCS Upgrade Utility can be installed from ESD or from a diskette.
  • The upgrade files can be transferred over to the DCS 300 by ESD, or FTP without the use of a CD-ROM. The upgrade files can be transferred from an Intermec Web page to a DCS 300 with ESD. Or, the upgrade files can be transferred from an Intermec Web page to a PC. Then, ESD or FTP in the binary mode can transfer the files to the DCS 300. If the upgrade files are to reside on the DCS 300, up to 120 MegaBytes must be available on drive d: of the hard drive depending on the size of the upgrade files.
  • An upgrade CD-ROM must be in the CD-ROM drive or these files need to be present in the d:\upgrade directory to start the upgrade:
  • FILE WHEN THE NEW FILE IS COPIED
      • upgrade.exe only when the file changes
      • *.zip every upgrade
  • If a CD-ROM is used in the upgrade of an 0200 controller, the user will need to enable the parallel port in the BIOS at the beginning of the upgrade and disable the parallel port in the BIOS at the end of the upgrade. The DCS 0300 comes with a CD-ROM drive installed and no BIOS changes are necessary.
  • 1.1.5. Interfaces to Initiate or Exercise the Feature
  • 1.1.5.1. Making Upgrade Files Available to the DCS 0300
  • For each upgrade, new upgrade files will need to be made available to the DCS 300 before the upgrade is initiated. There are several methods to make the files available. The user can place a CD-ROM in the CD-ROM drive, or the user can put the files in the d:\upgrade directory with ESD or FTP. There are different ways to make the files available because some users do not have the capability to utilize TCP\IP and won't be able to use ESD remotely or won't be able to use FTP.
  • 1.1.5.1.1.1.1. CD_ROM
  • When using a CD-ROM the user will place an Upgrade CD-ROM in the CD-ROM drive and initiate the upgrade from the System Maintenance Menu or from ESD (remotely of locally).
  • 1.1.5.1.2. ESD Tool
  • When using the ESD tool remotely, the user will download a file (e.g. 300V10.zip) from an Intermec Web page to a PC. The ESD tool will unzip the file in a directory. The ESD tool will copy the upgrade files to the d:\upgrade directory on the target DCS 300. The user will then schedule the upgrade using the ESD tool. ESD will initiate the upgrade remotely at the appropriate time. To use this method, the target DCS 300 must have a LAN card installed with IP enabled.
  • Alternately, the user can put an upgrade CD-ROM in the CD-ROM drive at the target DCS 300 and schedule the upgrade from ESD (locally or remotely).
  • 1.1.5.1.3. FTP
  • When using FTP, the user will download a file (e.g. 300V10.zip) from an Intermec Web page to a PC. The user will unzip the file in a directory. The user will login into the DCS 300 using FTP and set the binary mode. The user will change directories to d:\upgrade. Then, the user will copy all the files to the DCS 300. To use this method, the target DCS 300 must have a LAN card installed with IP enabled.
  • The upgrade can then be started at the DCS 300, from the System Maintenance Menu, or by ESD (remotely or locally).
  • 1.1.5.2. Starting the DCS Upgrade Utility
  • An upgrade can be initiated from ESD remotely or locally or the upgrade can be started from the DCS 300 System maintenance menu.
  • See the ESD section for more information on initiating an upgrade from ESD.
  • Referring to FIG. 2, to initiate an upgrade from the DCS 300, select DCS Upgrade Utility from the System Maintenance Menu.
  • When DCS Upgrade Utility has been selected a box will show that asks the source of the upgrade files. FIG. 3 is an example screen display of a source inquiry dialog box. Referring to FIG. 3, after the source of the upgrade files has been entered a menu will come up and ask if the user wants to start the upgrade or cancel. Pressing start will initiate the upgrade. Pressing cancel with end the upgrade.
  • Different upgrades will cause the DCS Upgrade Utility to present different confirmation dialog boxes to allow the user to have a last chance to cancel the upgrade. FIGS. 4-7 illustrate different dialog boxes that the DCS Upgrade Utility displays dependent upon the severity of the upgrade. Once a Start button has been pressed on any of the dialogs of FIGS. 4-7, the upgrade cannot be stopped.
  • 1.1.5.3. Upgrade Behavior
  • When the upgrade is started, a file, upgrade.ini, is extracted from the zipped up files. This file contains the parameters of the upgrade, the software version of the upgrade, and a version controller.
  • The version controller is a list of versions of DCS 300 software that can be upgraded to its upgrade software version. The DCS 300's software version is compared to the version controller. If the DCS 300's software version is in the list, then the upgrade will proceed. A readme.doc can be found in the same directory as the upgrade files (d:\upgrade or CD-ROM). The readme.doc file contains information on what versions of DCS 300 software the upgrade files can upgrade.
  • The parameter list in the upgrade.ini file controls the upgrade behavior. It controls if the DCS 300 needs to reboot, shut down various DCS 300 processes, or proceed as is. The rebooting and process control is done automatically and requires no user input.
  • 1.1.5.4. User Interface
  • A user at the DCS 300 during an upgrade will see various messages at a command prompt window on the DCS 300 screen depending on the size of the upgrade.
  • If the upgrade is a severe upgrade, the DCS 300 will reboot to an alternate operating system. These are the messages that can show on the screen based on additional upgrade.ini parameters:
      • Backing up system files
      • Deleting partitions
      • Creating partitions
      • Formatting partitions
      • Restoring system files
      • Checking video drivers
      • Restoring configuration
  • In addition to these messages, the user will see a list of files being copied to the appropriate directories after the partitions are formatted.
  • If the upgrade is a major C upgrade, the DCS 300 will reboot to an alternate operating system. These are the messages that can show on the screen based on additional upgrade.ini parameters:
      • Backing up system files
      • Restoring system files
      • Checking video drivers
      • Restoring configuration
  • In addition to these messages, the user will see a list of files being copied to the appropriate directories after the system files are backed up.
  • If the upgrade is a major D upgrade, these are the messages that can show on command prompt window on the DCS 300 screen:
      • stopping data collection
      • starting data collection
      • shutting down the DCS 300 GUI
      • starting the DCS 300 GUI
  • In addition to these messages, the user will see a list of files being copied to the appropriate directories after the processes have been shut down.
  • If the upgrade is a minor upgrade, then all the user will see is a list of files being copied to the appropriate directories.
  • The ESD tool can also inquire the version of the upgrade software on the DCS 300 and the version of the DCS 300 software to make sure the upgrade will proceed normally.
  • The DCS upgrade Utility will behave the same when the operating system is ported to Windows NT in a future release of the DCS 300.
  • 1.2. DCS Upgrade Utility
  • Currently a new upgrade kit is developed for each release. The latest was on CD-ROM. Previous upgrade kits were on diskette and took a long time to install.
  • With the DCS Upgrade Utility, changes to the C: drive will be zipped up into a file called os_drive.zip. Changes to the D: drive drive will be zipped up into a file called nextgen.zip. And, changes to the F: drive will be zipped up into a file called boot.zip. The upgrade files will either be and placed in the D:\upgrade directory with the ESD tool, from CD-ROM, or with FTP if the upgrade is ran from the d:\upgrade drive. If the upgrade is ran from the CD-ROM, the zip files will need to be on the CD-ROM. The upgrade can then be initiated by selecting DCS Upgrade Utility from the System Maintenance Menu, scheduled and initiated by ESD, or from the command line. The DCS Upgrade Utility will allow zipped-up files, on CD-ROM or placed in the d:\upgrade, to be exploded into the appropriate directories.
  • 1.2.1. Making the Zip Files
  • One zip file for each drive will be needed. The zip file will be made with the use of a batch file. The batch file will contain all the names and directories of the files that need to be updated. A typical command in the batch file to zip a single file is “zip-a os_drive.zip c:\ibmcom\1e100t.rsp”. This line adds (-a) c:\ibmcom\1e100t.rsp to the zip file os_drive.zip. To zip the entire ibmcom directory, use this command: “zip -a -r -S os_drive.zip c:\ibmcom”. Because the files that need updated are different for each upgrade, new zip files will be needed for each
  • The same upgrade.ini needs to be zipped up in every zip file. For REBOOT and SEVERE upgrades a list of backup files (upgdbkup.lst) will also need to be zipped up in the zip files. This upgrade.ini is used to verify that the zip file is valid. These are the valid zip file names:
      • os_drive.zip—These are changes to the c: drive which contains the main operating system.
      • nextgen.zip—These are changes to the d: drive which contains the DCS software. The changes to the upgrade.exe should not be in here unless the upgrade is SEVERE. This is because the upgrade.exe on the d:\upgrade directory will be running if the upgrade was initiated from the d:\upgrade drive.
      • boot.zip—These are changes to the f: drive which is the alternate operating system used by SEVERE and REBOOT upgrades.
        1.2.2. Upgrade Files
  • This is what the directory structure should look like on the CD-ROM and in the d:\upgrade directory:
    • Volume in drive D is UNOVA
  • Volume Serial Number is D0AD-8D81
    Directory of D:(OR G:)\UPGRADE\
    01/01/01 12:00a  <DIR>   .
    01/01/01 12:00a  <DIR>   ..
    12/08/97 01:17p   83,418,895 OS_DRIVE.ZIP
    12/08/97 01:21p   12,131,654 NEXTGEN.ZIP
    12/08/97 01:21p   12,131,654 BOOT.ZIP
    12/08/97 01:21p   12,131,654 UPGRADE.EXE
    09/04/97 08:31a  <DIR>   SVGA
    09/04/97 08:31a  <DIR>   VGA
    09/04/97 08:31a  <DIR>   TOOLS
       7 File(s) 95,550,549 bytes
    Directory of D:(OR G:)\UPGRADE\SVGA
    09/04/97 08:31a  <DIR>   .
    01/01/01 12:00a  <DIR>   ..
    01/22/94 11:29a    23,840 BVHSVGA.DLL
    04/08/94 11:29a   123,645 IBMDEV32.DLL
    11/30/93 11:29a    38,704 IBMVGA32.DLL
    04/09/94 11:29a    77,436 VSVGA.SYS
       4 File(s)   250,549 bytes
    Directory of D:(OR G:)\UPGRADE\VGA
    09/04/97 08:31a  <DIR>   .
    01/01/01 12:00a  <DIR>   ..
    08/12/96 11:29a    32,750 BVHSVGA.DLL
    08/04/96 11:29a    82,891 IBMDEV32.DLL
    07/16/96 11:29a    34,439 IBMVGA32.DLL
    08/29/96 11:29a   147,965 VSVGA.SYS
       4 File(s)    250,549 bytes
    Directory of D:(OR G:)\UPGRADE\TOOLS
    09/04/97 08:31a  <DIR>   .
    01/01/01 12:00a  <DIR>   ..
    07/10/97 11:29a    2,149 CARD.IRQ
    06/05/97 01:58p    138,291 UNZIP.EXE
    8 File(s)  233,628 bytes
    Directory of D:(OR G:)\UPGRADE\TOOLS\CONFIG
    09/04/97 08:31a  <DIR>   .
    09/04/97 08:31a  <DIR>   ..
    09/04/97 08:31a  <DIR>   1E
    09/04/97 08:31a  <DIR>   1E100
    09/04/97 08:31a  <DIR>   1E100E
    09/04/97 08:31a  <DIR>   1E100ET
    09/04/97 08:31a  <DIR>   1E100T
    09/04/97 08:31a  <DIR>   1E1T
    09/04/97 08:31a  <DIR>   1T
    09/04/97 08:31a  <DIR>   2E
    09/04/97 08:31a  <DIR>   2E100
    09/04/97 08:31a  <DIR>   2E100T
    09/04/97 08:31a  <DIR>   2E1T
    09/04/97 08:31a  <DIR>   LAN_LESS
    09/04/97 08:31a  <DIR>   LIC_STRT
    09/04/97 08:31a  <DIR>   ONE_RF
    07/19/96 03:34p    37 STARTUP.CMD
    09/04/97 08:31a  <DIR>   TWO_RF
    09/04/97 08:31a  <DIR>   T_AX_CM2
       19 File(s)   37 bytes
    Directory of D:(OR G:)\UPGRADE\TOOLS\CONFIG\1E
    09/04/97 08:31a  <DIR>   .
    09/04/97 08:31a  <DIR>   ..
    06/04/97 08:30a    761 PROTOCOL.INI
       3 File(s)   761 bytes
    Directory of D:(OR G:)\UPGRADE\TOOLS\CONFIG\1E100
    09/04/97 08:31a  <DIR>   .
    09/04/97 08:31a  <DIR>   ..
    04/30/97 11:15a    786 PROTOCOL.INI
       3 File(s)   786 bytes
    Directory of D:(OR G:)\UPGRADE\TOOLS\CONFIG\1E100E
    09/04/97 08:31a  <DIR>   .
    09/04/97 08:31a  <DIR>   ..
    06/02/97 02:35p    983 PROTOCOL.INI
       3 File(s)   983 bytes
    Directory of D:(OR G:)\UPGRADE\TOOLS\CONFIG\1E100ET
    09/04/97 08:31a  <DIR>   .
    09/04/97 08:31a  <DIR>   ..
    06/02/97 02:22p    1,367 PROTOCOL.INI
       3 File(s)   1,367 bytes
    Directory of D:(OR G:)\UPGRADE\TOOLS\CONFIG\1E100T
    09/04/97 08:31a  <DIR>   .
    09/04/97 08:31a  <DIR>   ..
    04/30/97 11:17a    1,160 PROTOCOL.INI
       3 File(s)   1,160 bytes
    Directory of D:(OR G:)\UPGRADE\TOOLS\CONFIG\1E1T
    09/04/97 08:31a  <DIR>   .
    09/04/97 08:31a  <DIR>   ..
    06/04/97 08:31a    1,134 PROTOCOL.INI
       3 File(s)   1,134 bytes
    Directory of D:(OR G:)\UPGRADE\TOOLS\CONFIG\1T
    09/04/97 08:31a  <DIR>   .
    09/04/97 08:31a  <DIR>   ..
    05/01/96 02:07p    938 PROTOCOL.INI
       3 File(s)   938 bytes
    Directory of D:(OR G:)\UPGRADE\TOOLS\CONFIG\2E
    09/04/97 08:31a  <DIR>   .
    09/04/97 08:31a  <DIR>   ..
    06/04/97 08:31a    962 PROTOCOL.INI
       3 File(s)   962 bytes
    Directory of D:(OR G:)\UPGRADE\TOOLS\CONFIG\2E100
    09/04/97 08:31a  <DIR>   .
    09/04/97 08:31a  <DIR>   ..
    04/30/97 11:18a    1,013 PROTOCOL.INI
       3 File(s)   1,013 bytes
    Directory of D:(OR G:)\UPGRADE\TOOLS\CONFIG\2E100T
    09/04/97 08:31a  <DIR>   .
    09/04/97 08:31a  <DIR>   ..
    04/30/97 11:19a    1,393 PROTOCOL.INI
       3 File(s)   1,393 bytes
    Directory of D:(OR G:)\UPGRADE\TOOLS\CONFIG\2E1T
    09/04/97 08:31a  <DIR>   .
    09/04/97 08:31a  <DIR>   ..
    06/04/97 08:31a    1,342 PROTOCOL.INI
       3 File(s)   1,342 bytes
    Directory of D:(OR G:)\UPGRADE\TOOLS\CONFIG\LAN_LESS
    09/04/97 08:31a  <DIR>   .
    09/04/97 08:31a  <DIR>   ..
    02/28/96 11:54a    216 NGSETUP.CMD
    10/02/95 10:25a    627 PROTOCOL.INI
    02/28/96 11:54a    1,509 TCPSTART.CMD
       5 File(s)   2,352 bytes
    Directory of D:(OR G:)\UPGRADE\TOOLS\CONFIG\LIC_STRT
    09/04/97 08:31a  <DIR>   .
    09/04/97 08:31a  <DIR>   ..
    04/04/96 07:41a     17 DCMF1.LIC
    02/08/96 03:13p     17 DCMF2.LIC
    02/08/96 03:15p     17 DCMF3.LIC
    06/20/96 12:54p     17 DCML1.LIC
    04/04/96 07:42a     17 DCML2.LIC
    02/08/96 03:14p     17 DGML3.LIC
    03/21/97 07:38a    1,271 NGSYS.BAK
    06/26/97 12:54p    1,256 NGSYS.INI
    02/08/96 03:14p     17 NOLIMIT.LIC
    02/08/96 03:15p     17 NOLIMITF.LIC
       12 File(s)   2,663 bytes
    Directory of D:(OR G:)\UPGRADE\TOOLS\CONFIG\ONE_RF
    09/04/97 08:31a  <DIR>   .
    09/04/97 08:31a  <DIR>   ..
    06/02/97 02:07p    388 NET.CFG
       3 File(s)   388 bytes
    Directory of D:(OR G:)\UPGRADE\TOOLS\CONFIG\TWO_RF
    09/04/97 08:31a  <DIR>   .
    09/04/97 08:31a  <DIR>   ..
    06/02/97 02:08p    217 NET.CFG
       3 File(s)   217 bytes
    Directory of D:(OR G:)\UPGRADE\TOOLS\CONFIG\T_AX_CM2
    09/04/97 08:31a  <DIR>   .
    09/04/97 08:31a  <DIR>   ..
    11/01/95 04:43p    4,841 TWAX_CM2.CF2
    11/01/95 04:43p   28,928 TWAX_CM2.CFG
    11/01/95 04:43p    2,782 TWAX_CM2.NDF
    11/01/95 04:43p    325 TWAX_CM2.SEC
       6 File(s)  36,876 bytes
     Total Files Listed:
       126 File(s)  96,573,903 bytes
  • If an upgrade is to be performed from the d:\upgrade drive, and changes to this directory tree should be copied over before upgrade begins.
  • 1.2.3. Starting the DCS Upgrade Utility
  • The DCS upgrade utility can be started from ESD, from the System Maintenance Menu, or from the command line. The Upgrade Utility is a stand alone application with the following command line syntax:
      • upgrade [q or s]
  • The qualifier “q” is optional. It is used to pre-test the upgrade to see if it will proceed normally. The “s” qualifier is used to indicate that a save and activate will be done if it is necessary. Either the “q” or “s” is used, not both at the same time.
  • 1.2.3.1. ESD
  • IF ESD is used, ESD will first send a system transaction to the message handler with these one of these sets of parameters:
  • “d:\upgrade\upgrade /q”—The query of the upgrade started from the d: drive.
      • “g:\upgrade\upgrade /q”—The query of the upgrade started from the CD-ROM
  • A query will just run the phase 0 part of the upgrade and place the results in a file (upgrade.log). The results include error messages, parameters of the upgrade, the current phase of the upgrade, and the size of the disk drive. ESD will check upgrade.log for error messages. If error messages are found it will not proceed with the upgrade. If no error messages are found, ESD will send a system transaction to the message handler with these parameters:
  • “\f:\upgrade\upgrade”—The upgrade started from the d: drive
      • “g:\upgrade\upgrade—The upgrade started from the CD-ROM
      • “/f:\upgrade\upgrade /s”—The upgrade started from the d: drive and a save and activate will be done if necessary.
      • “/g:\upgrade\upgrade /s”—The upgrade started from the CD-ROM and a save and activate will be done if necessary
        1.2.3.2. System Maintenance Menu
  • When the upgrade is started from the system maintenance menu, upgrade.exe is started by 300UgradeUtil in ngpblist.c. 300UgradeUtil will prompt the user for the source of the upgrade file, then call upgrade.exe with these parameters:
      • “d:\upgrade\upgrade /q”—The query of the upgrade started from the d: drive.
      • “g:\upgrade\upgrade /q”—The query of the upgrade started from the CD-ROM
  • When the query is done 300UgradeUtil will parse upgrade.log for error messages. If error messages are found, a message will be displayed on a message box on the GUI and the upgrade will end. If there was no errors, upgrade.ini will be parsed again for the parameters of the upgrade, and prompt for a last chance cancel or start based on the parameters. If start is selected, 300UgradeUtil will call upgrade.exe with these parameters:
      • “\f:\upgrade\upgrade”—The upgrade started from the d: drive
      • “g:\upgrade\upgrade—The upgrade started from the CD-ROM
      • “/f:\upgrade\upgrade /s”—The upgrade started from the d: drive and a save and activate will be done if necessary.
      • “/g:\upgrade\upgrade /s”—The upgrade started from the CD-ROM and a save and activate will be done if necessary
        1.2.3.3. Command Line
  • When the upgrade is started from the command line, the user will enter send “f:\upgrade\upgrade” or “g:\upgrade\upgrade”. This should only be used when a 0200 Controller is upgraded to DCS 300, ver 1.0. No save and activate will be done.
  • 1.2.4. Upgrade Control
  • In phase 0 of the upgrade, upgrade.ini will be extracted from each zip file. This file will contain the type of the upgrade, the subsections of the type of upgrade, the software version of the upgrade, the version level, and a version controller. The parameters will be used to select the sections of the upgrade that need to be performed. As enhancements are made to the DCS 300, and new sections to the upgrade process are identified, additional parameters can be added to this file and the upgrade executable. The upgrade.ini file is also for security. If the file cannot be extracted from a zip file then the upgrade will not proceed. An upgrade.ini file typically contains the following tags and parameter definitions:
  • [Version Level]
      • Version=300 x.x
  • [Upgrade]
      • Type={SEVERE, MINOR, REBOOT, or SHUTDOWN}
      • Version=DCS 300 x.x
  • [Changed_Software]
      • OS={YES or NO}
      • NEXTGEN={YES or NO}
      • SWAPPER={YES or NO}
      • BOOT={YES or NO}
      • BOOT_MANAGER={YES or NO}
  • [Changed_Partitions]
      • OS={YES or NO}
      • NEXTGEN={YES or NO}
      • SWAPPER={YES or NO}
      • BOOT={YES or NO}
      • BOOT_MANAGER={YES or NO}
  • [OS]
      • START={BOTTOM or TOP}
      • File_System={FAT or HPFS}
      • Vtype={PRIMARY or SECONDARY}
      • 540_NAME={currently 0000003f}
      • 540_SIZE={the size of the new partition}
      • 2200_NAME={e.g. 0000003f}
      • 2200_SIZE={the size of the new partition}
      • 2500_NAME={currently 0000003f}
      • 2500_SIZE={the size of the new partition}
  • [SWAPPER]
      • START={BOTTOM or TOP}
      • File_System={FAT or HPFS}
      • Vtype={PRIMARY or LOGICAL}
      • 540_NAME={e.g. 0000003f}
      • 540_SIZE={the size of the new partition}
      • 2200_NAME={e.g. 0000003f}
      • 2200_SIZE={the size of the new partition}
      • 2500_NAME={e.g. 0000003f}
      • 2500_SIZE={the size of the new partition}
      • Restore_START={BOTTOM or TOP}
      • Restore_File System={FAT or HPFS}
      • Restore_Vtype={PRIMARY or LOGICAL}
      • Restore540_SIZE={the size of the new partition}
      • Restore2200_SIZE={the size of the new partition}
      • Restore2500_SIZE={the size of the new partition}
  • [NEXTGEN]
      • START={BOTTOM or TOP}
      • File_System={FAT or HPFS}
      • Vtype={PRIMARY or SECONDARY}
      • 540_NAME={e.g. 0000003f}
      • 540_SIZE={the size of the new partition}
      • 2200_NAME={e.g. 0000003f}
      • 2200_SIZE={the size of the new partition}
      • 2500_NAME={e.g. 0000003f}
      • 2500_SIZE={the size of the new partition}
      • Restore_START={BOTTOM or TOP}
      • Restore_File_System={FAT or HPFS}
      • Restore_Vtype={PRIMARY or LOGICAL}
      • Restore540_SIZE={the size of the new partition}
      • Restore2200_SIZE={the size of the new partition}
      • Restore2500_SIZE={the size of the new partition}
  • [BOOT]
      • START={BOTTOM or TOP}
      • File_System={FAT or HPFS}
      • Vtype={PRIMARY or LOGICAL}
      • 540_NAME={e.g. 0000003f}
      • 540_SIZE={the size of the new partition}
      • 2200_NAME={e.g. 0000003f}
      • 2200_SIZE={the size of the new partition}
      • 2500_NAME={e.g. 0000003f}
      • 2500_SIZE={the size of the new partition}
  • [BOOT_MANAGER]
      • START={BOTTOM or TOP}
      • Vtype={PRIMARY or LOGICAL}
      • 540_NAME={e.g. 0000003f}
      • 2200_NAME={e.g. 0000003f}
      • 2500_NAME={e.g. 0000003f}
  • [Processes]
      • NextgenGui={YES or NO}
      • DataCollection={YES or NO}
      • FUU={YES or NO}
      • ViDaemon={YES or NO}
  • [Disk_Size]
      • Num_Cylinders540_D_Drive={e.g. 97}
      • Num_Cylinders2200_D_Drive={e.g. 97}
      • Num_Cylinders2500_D_Drive={e.g. 97}
  • [VIDEO_FIX]
      • Flix_Config={YES or NO}
      • Copy_Files={YES or NO}
  • [Version_Controller]
      • Range={0200 Ver 3.0, DCS 300 Ver x.x-y.y, z.z}
        1.2.4.1. Version Level
  • The version level refers to the parameters that can be stored in upgrade.ini. Upgrade.exe (Upgrade.c) contains a version level also. This version level refers to the parameters that upgrade.exe can read. The version numbers must match. When upgrade.exe is ran, it will compare the two version numbers. If the numbers don't match, the upgrade will end.
  • 1.2.4.2. Upgrade
  • The Upgrade header contains the type of upgrade and the version of the upgrade. These are the types of the upgrade (upgrade.ini):
      • MINOR /* no process need to be stopped, no rebooting */
      • REBOOT /* a major upgrade of the c drive including operating system or and upgrade of running d: drive processes on a DCS 300 with OS/2*/
      • SHUTDOWN /* a major upgrade of the d drive that needs processes shut down. This will not be used until the DCS 300 is migrated to Windows NT. The DCS 300 processes should be written with PC hooks to shut down the process remotely. */
      • SEVERE /* a severe upgrade of the DCS 300 which includes repartitioning or a new operating system */
  • The SEVERE and SHUTDOWN upgrades will need to specify additional information (subsections) in the upgrade.ini.
  • 1.2.4.3. Processes
  • The Processes header contains the processes that need to shut down. SHUTDOWN will need to specify which processes to stop, such as nextgen.exe or data collection. A NO means “don't shutdown processes” and a YES means “shutdown the process”. For all other types of upgrades this subheading is ignored.
  • 1.2.4.4. Changed Software Changed software is only used for SEVERE and REBOOT upgrades. Changed software contains a list of the partitions that will have software updates. Changed software is used to indicate that the software in a partition has changed. For a SEVERE upgrade, If the partition size or file system will change, then, the corresponding setting here will also need to be set to YES because the software will have to be put back after the partition has been reformated.
  • 1.2.4.5. Changed_Partitions
  • Changed partitions is only used for SEVERE upgrades. All other types will ignore this information. Changed Partitions contains a list of the partitions that will be changed. If the partition is set to NO, it will not be changed. If it is set to YES, it will be changed. Not all partitions will change. It is possible that only one will change (it didn't change size, it could change the file system perhaps). If the BOOT partition changed, the SWAPPER partition should also be changed. This is so the BOOT partition can change sizes. These will be set to one if data on the partition changed (files) or the partition information changed (size, file system, . . . ).
  • 1.2.4.6. OS, SWAPPER, NEXTGEN, BOOT, BOOT_MANAGER
  • These headings are used only if they are set to YES in the Changed_Partitions heading. They are only used by SEVERE upgrades. All other upgrades ignore this information. The disk drive information is set here. There needs to be partition information for each partition the was set to YES in Changed_Partitions.
  • The START parameter indicates if the partition is to be created at the bottom or top of the free space on the disk. The current file system is HPFS. This will be changed to FAT for Windows NT. The files system type is used by fdisk when the new partition is created and by format. Vtype indicates if the partition is primary or logical. Usually the operating system is on the primary partition and is on the c: drive. The size information is used to create the partition. These numbers must be correct for the different drive sizes (540M, 2.5 Gig, and 2.2 Gig) or fdisk will return an error. The name of the drive is important to delete the partition using fdisk. The name can be found by doing a fdisk/query. This will need to be done for all three sizes of drives (540M, 2.5 Gig, and 2.2 Gig). If other sizes of disk drives are used, the information will have to be added here too. These parameters are for fdisk.
  • If the name of the partition is not included in the os, swapper, nextgen, or boot sections (used only if the partition was set to YES in Changed_Partitions), then the partition will not be deleted. If the size was no included the partition will not be created. And, if the file system was not specified, the partition will not be formated.
  • For example, for DCS 300 ver 1.0, the swapper partition will need to be deleted, and recreated at a smaller size because there will be two new partitions. For the swapper partition, since it needs to be deleted, the name of the partition will need to be included. Since it also needs to be created at a smaller size the, the size should also be included as well as the file system. The nextgen and the OS partitions will not be deleted or recreated so the size, file system, and name information for the partitions should not be included. The information on the nextgen and the OS partitions will change, so OS and NEXTGEN should be set to YES under the changed software heading in upgrade.ini. Two new partitions will be created—the boot partition and the boot manager. The names for these should not be included because they didn't exist before.
  • 1.2.4.7. Disk_Size
  • Disk size is the number of cylinders in the d: partition for each of the disk sizes. If a new hard drive is added, new entries will need to be added here. Currently in the field there are 540 Meg hard drives and 2.5 Gig hard drives. Soon there will be 2.2 Gig hard drives.
  • 1.2.4.8. Video Fix
  • There are currently three type of video cards out in the field. For SEVERE upgrades and reboot upgrades, config.sys will be changed when creat_ng is ran. Also, a new config.ngc might be copied over. If the files are changed, they will have to be changed to reference the correct video drivers. Fix_Config will need to be set to YES if the config.ngc or config.sys is changed. If operating system is updated or replaced, then the video driver software for the correct card will have to be copied over to the appropriate directories. Copy_Files will need to be set to YES to cause the files to be copied over.
  • 1.2.4.9. Version_Controller
  • The version controller will contain the range of software that can be upgraded.
  • For this release it will be 0200 ver 3.0 that can be upgraded. It can be a list or a range such as 300 ver 3.0-3.3, 3.5.
  • 1.2.4.10. Example
  • An example upgrade.ini file that will be used for upgrades from 0200 Ver 3.0 to DCS 300 Ver 1.0 is included in the Computer Program Listing Appendix:
  • The type of upgrade shown in the example upgrade.ini file is SEVERE because the upgrade needs to delete and create partitions. The only partition that will be deleted is the swapper partition. It is being deleted to make room for two more partitions. The two new partitions are the alternate boot partition (BOOT) and boot manager. The swapper partition will be recreated at a smaller size. The OS and nextgen partitions will not be deleted or recreated, but new files will be copied over.
  • Since the swapper, the boot, and the boot manager partitions will change size, the SWAPPER, BOOT, and BOOT_MANAGER settings under changed_partitions are set to YES.
  • Data for all the partitions will change, so all the values in the Changed_Software are set to YES.
  • For the SWAPPER section, all the information for the partition is added except the name and size of the partition for the 2.2 Gig drive because none exist out in the field.
  • For the BOOT section, the boot partition name is not included because no boot partition was there before so no deletion of the partition will be attempted. The delete sections of the upgrade looks for the name of the partition to delete. If the name is NULL the section will be skipped. The new partition will be created at the top (START=TOP) of the free space on the hard drive.
  • For the BOOT_MANAGER section, the new partition will be created at the top (START=TOP) of the free space on the hard drive. The name is not included because boot manager was not installed before.
  • Creat_ng will be ran, so Fix_Config under Video_Fix will be set to YES.
  • For the Version Controller section, controller with 0200 Ver 3.0 software can be upgraded to DCS 300 Ver 1.0.
  • 1.2.5. Upgrade.log file
  • Upgrade messages will be sent to the controller screen as well as to a file, upgrade.log. At the beginning of the upgrade, a default upgrade.log will be copied over to d:\upgrade. Phase 0 messages are used by ESD and 300UgradeUtil to determine if the DCS upgrade utility will proceed without errors. This is what the default message file looks like:
    • [PHASE]
      • phase=
    • [DISK_SIZE]
      • disk_size=
    • [VIDEO_CARD]
      • VIDEO_CARD=
    • [ERROR_MESSAGES]
    • [SUCCESS_MESSAGES]
  • If the upgrade is SEVERE and the d: partition is to be deleted and recreated, the upgrade.log will be copied over to the f: drive befor the d: drive is deleted.
  • 1.2.5.1. Phase heading
  • At the completion of each phase, the next phase to be ran is set here. There are currently six phases (0, 1, 2, 3, 4, and 5). None of the upgrades use all six phases. The MINOR upgrade only uses phase 0 and phase 5. A REBOOT upgrade uses phase 0, phase 4, and phase 5. A SEVERE upgrade uses phase 0, phase 1, phase 2, phase 3, and phase 5. A SHUTDOWN upgrade only uses phase 0 and phase 5.
  • 1.2.5.2. Disk Size Heading
  • The disk size is written to upgrade.log if the upgrade is SEVERE. An IOCTL command is ran that queries the number of cylinders in drive.
  • 1.2.5.3. Video Card Heading
  • This is used for SEVERE and REBOOT upgrades.
  • 1.2.5.4. Error Messages
  • These are the error messages that can be put in upgrade.log in phase 0:
      • Invalid disk size
      • Invalid zip files(s)
      • The upgrade files are not compatible with the DCS upgrade utility
      • The path for the upgrade files is incorrect.
      • The upgrade.ini is incorrect.
      • Incorrect number of parameters
      • DCS 300 ver x.x can not be upgraded to DCS 300 ver y.y. You must first upgrade to DCS 300 ver z.z the use this upgrade.
  • These are the error messages that can be put in upgrade.log in all other phases:
      • Creat_ng failed. The error messages can be found in TBD.
      • The upgrade completed with errors
      • The upgrade could not complete
      • Error Copying files to C: Drive
      • Error Copying files to D: Drive
      • Error Copying files to F: Drive
      • Backup failure:
      • Restore failure:
      • “Could not open master system file list.
      • Restore is in progress . . .
      • Backup is in progress . . .
      • Target directory creation error.
      • ERROR—Access to drive denied
      • Could not open the migration list file.
        1.2.5.5. Success Messages
  • These are the success messages that can be put in upgrade.log in phase 0:
      • DCS 300 ver x.x will be upgraded to DCS 300 version y.y.
      • 0200 Controller ver 3.0 will be upgraded to DCS 300 version 1.0.
  • These are the success messages that can be put in upgrade.log in all other phases:
      • Successful upgrade
        1.2.6. Save and Activate
  • If the /s parameter was passed in, a SEVERE and REBOOT upgrade will test to see if a save and activate is necessary. If the save and activate is necessary, the new default files will be copied over. Then data collection will be stopped, CM/2 will be ran, and then LAPs will be initiated. Timers will be used to wait to wait for data collection to stop, and for CM/2 setup and LAPs to finish.
  • 1.2.7. Assumptions
  • 1.2.7.1. Processes that Need to be in Place for the Upgrade Utility
  • It is assumed that there will be a config file that contains information on the software version. This will help control upgrades because the DCS 300's software version can be compared to the version controller in the upgrade files.
  • For ESD to start the DCS Upgrade Utility, a new functionality needs to be added that can spawn a command line utility based on a transaction.
  • The GUI needs to be changed to add the DCS 300 Upgrade Utility to the menu options. If the Upgrade Utility was selected, a new procedure in ngpblist.c will start the upgrade with the query option and examine the results in upgrade.log when the query is done. If there were no error in upgrade.log, the GUI will show a last chance box based on the type of upgrade (the type of upgrade is also in upgrade.log). If START was selected, the upgrade utility will be started without the query option.
  • The GUI needs to be changed to continuously check to see if there is an IPC call for a quiet save and activate. The upgrade utility will need to be able to do a quiet save and avtivate without rebooting or user input. Existing procedures like ActivateCfgOK, DcStopTimer, ActivateAfterStop, CheckCmsetup, ActivateAfterCM2, CheckLapsDone, and ActivateAfterLaps and the procedures they call will need to able to accept two more input parmater (quiet, or not quiet, and no reboot, or reboot possible).
  • 1.2.7.2. Limitations
  • When an upgrade to DCS 300 ver 1 from 0200 ver 3.0 is done, no save and activate will occur because the changes to the DCS software are not in place. Also, the upgrade will need to be started from the command line for the same reasons.
  • The SHUTDOWN type of upgrade will not be used until the DCS 300 is migrated to Windows NT. The new DCS 300 processes should be written with IPC hooks to stop them remotely.
      • Much of the previous upgrade kit (upgrade to V3.0 on CD-ROM) can be used. Changes will need to be made to the sections, though. Phases of the upgrade will be used again with the addition of the upgrade parameter list in upgrade.ini.
        1.2.8. Software Structure
        1.2.8.1. ngpblist.c
  • For upgrades started from the GUI, code will need to be added to ngpblist.c to add the DCS 300 Upgrade Utility. A new dialog will be created when this option is selected. Under the create event of this dialog a new function (300UgradeUtil) will be added that will prompt the user for which directory the upgrade files are in. Based upon the choice, 300UgradeUtil will call upgrade.exe with these parameters: “upgrade /d:\upgrade /q”, if “D: Drive” was selected or “upgrade /g:\upgrade /q” if the “CD-ROM” option was selected. Upgrade.exe will perform phase 0 of the upgrade and quit. Phase 0 determines if the upgrade files are valid, extracts upgrade.ini from the upgrade files, determines if the upgrade.exe is compatible with the upgrade.ini, and determines the type of upgrade. The results of phase 0 is output to upgrade.log. Then upgrade.exe ends. The CreateUpgradeUtil function spawns the upgrade.exe. It then starts a xvt_timer and for each timer event generated, calls CkUpgradeLogFile. This function looks for the update.log file and when successfully opened verifies that no errors were generated by the upgrade.exe application. If errors are present, they are presented to the user in a XVT message dialog otherwise the success message that was written to the log file is displayed. If there were no errors, and based on the type of upgrade, a last resort box will show asking if the user wants to start or cancel the upgrade.
  • 1.2.8.1.1. Pseudo-Code for ngpblist.c
  • Pseudo-code for example procedures that SideButtonsMenuListOk calls for the upgrade utility are included in the Computer Program Listing Appendix in file “ngpblist.c.” These procedures include:
      • SideButtonsMenuListOK
      • CreateUgradeUtil
        1.2.8.2. UpgradeUtilok (WINDOW xdWindow)
      • This function is called when the user clicks the OK button in the DCS Upgrade Utility dialog.
  • If CD-ROM was selected as the source then verify a CD is in the drive.
  • If not display an error.
  • Spawn the upgrade.exe application using the /q (query) option for a parameter.
  • Start the xvt_timer
  • 1.2.8.3. CkUpgradeLogFile(VOID)
  • This function is called when a E_TIMER event is received in the DCS Upgrade Utility dialog. Loop until a successful open is performed on the upgrade.log file or until nn timer events have be generated. If we time out, then inform the user and quit the process. After a successful open is performed, parse the upgrade.log file using the function:
    • LONG FindValue (PSZ pszFilePath, PSZ pszSection, /* “[ERROR_MESSAGES]*/PCHAR szFindString)
      • If no errors are found then parse the file again and display the messages written under the “[SUCCESS_MESSAGES]” section in a xvt_note dialog.
      • When we return from the note dialog, parse the upgrade.log file and find the type, (section=”[UPGRADE_TYPE]”).
      • Based on the type, display the appropriate dialog (see functional spec. for the different levels of upgrades.
      • If the type is MINOR or SHUTDOWN, show the user a Start or Cancel type dialog allowing the user to proceed or abort the process. Upgrade.exe is again called with no paramters.
      • IF the type is REBOOT or SEVERE, show the user a Star or Canel type dialog along with a check box to Save and Activate their current configuration.
  • Upgrade.exe is again called and if the Save and Activate check box is checked, then /s is passed in as a parameter to the call.
  • 1.2.8.4. Upgrade.exe
  • There are six phases to the upgrade. Phase 0 tests to see if the upgrade files are valid and examines the parameters of the upgrade. Phases 1, 2, and 3 are for SEVERE upgrades only. Phases 1, 2, and 3 delete, create, and format partitions. Phase 4 reboots the DCS 300 to the f: drive if the type of upgrade is REBOOT. MINOR and SHUTDOWN upgrades will jump from phase 0 to phase 5. Phase 5 extracts the zip files.
  • 1.2.8.4.1. Phase 0
  • Phase 0 does these tests for each possible zip file:
      • A check is done to see if the zip file exists (it is not an error if it does not exist)
      • If it exists the upgrade.ini is extracted from it
      • If there wasn't an upgrade.ini and error is logged to upgrade.log and the upgrade ends.
      • If there was an upgrade.inii, its version is compared to the version of upgrade.exe.
      • If the versions don't match, an error message is logged in upgrade.log and the upgrade ends.
  • At this point, if there is no upgrade.ini, an error message is logged to upgrade.log and the upgrade ends. If there is an upgrade.ini the version of the DCS 300 is compared to the version controller in upgrade.ini. If the DCS version doesn't fall in the range in the version controller, an error message is logged to upgrade.log and the upgrade ends. Next the type of upgrade is retrieved and logged to upgrade.log. If it is a SEVERE upgrade, the disk size is also logged to upgrade.log. If no errors have occurred, the success messages is logged to upgrade.log. The message tells the current version of the DCS 300 and the version it is being upgraded to. If the “q” parameter was used to call upgrade.exe, the upgrade will end. If the “q” parameter was not used the phase is set to the proper value and the upgrade continues. The new phase is logged in upgrade.log.
  • 1.2.8.4.2. Phase 1 (used by SEVERE only)
  • The DCS 300 will do a save and activate if the /s parameter was passed in.
  • Phase 1 will extract upgdbkup.lst from one of the zip files and back up the users system files to the d:\upgrade directory. In phase 2 these files will be copied to the boot partition (f: drive).
  • If BOOT=YES was set in upgrade.ini, phase I will delete the swapper partition if the name was set in upgrade.ini. This is so the boot partition can change sizes. Next, the boot partition will be deleted if the the name was set in upgrade.ini. If the delete of the boot partition failed an error message recorded to upgrade.log. The old partition settings will be in the upgrade.ini. If the partitions were deleted successfully, the new boot partition will be created if the size is not equal to zero.
  • Phase 2 will be entered in the upgrade.log so that when the DCS reboots, phase two will be started.
  • A new config.sys and startup.cmd will be copied over the old so that when the DCS 300 reboots to the c: drive, the upgrade program will run.
  • Now the DCS 300 will reboot if it hasn't already.
  • 1.2.8.4.3. Phase 2 (Used by SEVERE Only)
  • Phase two will format the swapper partition in the specified file system if the file system was set in upgrade.ini. If it fails, an error message will be recorded to upgrade.log and a error message will print to the screen and the upgrade will end. The DCS 300 is not functional but it is bootable to the C: drive.
  • If no error occur, the boot partition will be formatted in the specified file system if the file system was set in upgrade.ini. If an error occurs, an error message will be written to upgrade.log and the DCS 300 will be set up to boot up normally and the DCS will reboot to the C: drive. The DCS 300 is fully functional, but the upgrade failed. If no errors occur, boot_drive.zip will be exploded into the new drive and the backed up system files will be copied over as well as the upgrade.ini and upgrade.log files.
  • If errors occur during the copying, an error message will be written to upgrade.log and the DCS 300 will be set up to boot up normally and the DCS will reboot. The DCS 300 is fully functional, but the upgrade failed. If the e: drive was not deleted before, it can be now if SWAPPER=YES under the changed partitions heading in upgrade.ini. If it fails, an error message will be recorded to upgrade.log and a error message will print to the screen and the upgrade will end. The DCS 300 is fully functional.
  • If there was no errors and If NEXTGEN=YES under the changed partitions heading in upgrade.ini, the d: drive will now be deleted if the name was set in upgrade.ini. If it fails, an error message will be recorded to upgrade.log, the swapper partition will be recreated, an error message will print to the screen, and the upgrade will end. The DCS 300 is not functional but it is bootable to the C: drive.
  • If there was no errors and If OS=YES under the changed partitions heading in upgrade.ini, the c: drive will now be deleted if the was set in upgrade.ini. If it fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will end. The DCS 300 is not functional but it is bootable to the c: drive.
  • If there were no errors, the deleted partitions will now be recreated through fdisk if the sizes were set in upgrade.ini. If a partition creation fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will end. The DCS 300 is not functional and it is not bootable to the c: drive.
  • If no errors occur creating the partitions, the DCS will reboot to the f: drive if OS, NEXTGEN, or SWAPPER is set to YES under the changed partitions heading in upgrade.ini.
  • 1.2.8.4.4. Phase 3 (Used by SEVERE Only)
  • Phase three will first format the os partition in the specified file system if the file system was set in upgrade.ini. If the format fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will end. The DCS 300 is not functional and it is not bootable to the c: drive because there is no operating system on the c: drive. The DCS 300 was booted from the f: drive and is at a command prompt.
  • If there are no errors, the nextgen partition will be formatted in the specified file system if the file system was set in upgrade.ini. If the format fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will end. The DCS 300 is not functional and it is not bootable to the c: drive because there is no operating system on the c: drive. The DCS 300 was booted from the f: drive and is at a command prompt.
  • If there are no errors, the swapper partition will be formatted in the specified file system if the file system was set in upgrade.ini. If the format fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will end. The DCS 300 is not functional and it is not bootable to the c: drive because there is no operating system on the c: drive. The DCS 300 was booted from the f: drive and is at a command prompt. If there are no errors, the upgrade zip files are now ready to be exploded—increment the phase to 5 .
  • 1.2.8.4.5. Phase 4 (Used by REBOOT Only)
  • The phase is set to 5 in the log file. The DCS 300 will do a save and activate if the /s parameter was passed in and if a save and activate is necessary. Now the DCS 300 will reboot.
  • 1.2.8.4.6. Phase 5
  • If REBOOT was set in upgrade.ini, upgdbkup.lst will be extracted from one of the zip files. This is the list of files to be backed up and restored. The system files will be copied to the d:\upgrade\backup directory. If the backup fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will reboot the DCS 300 to the c: drive. The DCS 300 is fully functional and operation will resume as normal except the upgrade did not complete successfully.
  • If the REBOOT parameter is set under the changed partitions heading in upgrade.ini, upgrade.exe will run CreatUpgradeTmpFile. This procedure will read the last successful section from ng_confg.log and copy it to a temp file to be used when creat_ng is ran. If the CreatUpgradeTmpFile fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will reboot the DCS 300 to the c: drive. The DCS 300 is fully functional and operation will resume as normal except the upgrade did not complete successfully.
  • If the SHUTDOWN parameter is set under the changed partitions heading in upgrade.ini, the nextgen processes will now be stopped.
  • For all upgrades, the zip files will now be extracted to the appropriate drive and directories. If OS=YES under the changed_software heading in upgrade.ini, os_drive.zip will be exploded in the c: drive. If the unzip fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will end. The DCS 300 is might or might not be functional and it might or might not be bootable. The status is unknown because the c: drive is corrupted. The DCS 300 was booted from the f: drive and is at a command prompt.
  • If there is no errors and NEXTGEN=YES under the changed_software heading in upgrade.ini, nextgen_drive.zip will be exploded in the d: drive. If the unzip fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will end. The DCS 300 is might or might not be functional but it is bootable to the c: drive. The DCS 300 was booted from the f: drive and is at a command prompt.
  • If there is no errors and the REBOOT or SEVERE parameter is set, creat ng will be ran to restore the user configuration. If the creat_ng fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will reboot to the c: drive and end. The DCS 300 is functional but not configured.
  • If there is no errors and the REBOOT or SEVERE parameter is set, the procedure systemRestore will be ran to restore the backed up system files. If the systemRestore fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will reboot to the c: drive and end. The DCS 300 is functional but not configured fully.
  • If there is no errors and the REBOOT or SEVERE parameter is set, the procedure EnableTcpipInConfigSys will be ran to start TCP/IP in the config.sys if it was set before. If TcpipInConfigSys fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will reboot to the c: drive and end. The DCS 300 is functional but not configured fully.
  • If there is no errors and the REBOOT or SEVERE parameter is set, the procedure HostNAMeRestore will be ran to restore the host name in config.sys. If HostNAMeRestore fails, an error message will be recorded to upgrade.log, an error message will print to the screen, and the upgrade will reboot to the c: drive and end. The DCS 300 is functional but not configured fully.
  • If the REBOOT or SEVERE parameter is set, the DCS 300 will now reboot to the c: drive and be ready for normal operation.
  • If the SHUTDOWN parameter is set, the stopped processes will now be restarted.
  • If there was any errors configuring the controller fully, the user will have to reconfigure the DCS 300.
  • 1.2.8.4.7. Pseudo-Code for upgrade.c
  • The main body of upgrade.c calls these functions:
      • main
        • SearchAndAddStringtoFile
        • FormatPartition
        • DiskSize
        • CreatePartitions
        • IncrementPhase
        • HostNameRestore
        • FindValue
        • UpdtConfigLog
        • SystemBackup
        • SystemRestore
        • CreateUpgradeTmpFile
        • DosExecPgmWrapper
        • EnableTcpipInConfigSys
        • SaveAndActivate
        • RestoreVideoType( )
        • SaveVideoType( )
      • A copy of pseudo-code for an example “upgrade.c” file is included in the Computer Program Listing Appendix.
        1.2.8.4.8. Pseudo-Code for Upgrade.h
      • A copy of pseudo-code for an example header definition is included as file “upgrade.h” in the Computer Program Listing Appendix.
        1.2.9. Data Organization
      • Changes will be made to a SysMaintitems structure in a ngextrn.h file. A copy of pseudo-code for an example header definition is included as file “ngextm.h” in the Computer Program Listing Appendix.

Claims (22)

1. A system for automatically upgrading executable instructions on client devices over a network that selectively provides data communication between the system and the client devices, the system comprising:
at least one memory storing at least one version of a set of upgraded instructions selectively loadable to the client device and executable thereby; and
a server coupled to the memory and operable to execute a first set of server instructions to push the at least one version of the set of upgraded instructions to at least one of the client devices based on a current configuration of the client device, and operable to execute a second set of instructions to allow at least one of the client devices to pull the at least one version of the set of upgraded instructions to the client device based on a current configuration of the client device.
2. The system of claim 1 wherein the client device is an automatic data collection device selected from the group comprising a radio frequency identification reader, a machine-readable symbol reader; and a magnetic stripe reader.
3. The system of claim 1 wherein the current configuration of the client device is stored at the server.
4. The system of claim 1 wherein the client device periodically contacts the server to determine the availability of a specific version of the set of upgraded instruction stored in the at least one memory.
5. The system of claim 1 wherein from time to time, the server contacts the client device at a scheduled time to determine the current configuration of the client device.
6. The system of claim 1 wherein the at least one version of a set of upgraded instructions stored at the at least memory device comprises at least one of an operating system; an application; and a set of user data.
7. The system of claim 1 wherein the at least one version of a set of upgraded instructions stored at the at least memory device comprises an upgraded operating system.
8. The system of claim 1 wherein the server operable to organize a plurality of client devices into a logical group and allow for a single event to initiate at least one of a push or a pull of the set of upgraded instructions to each of the client devices in the logical group.
9. A method for automatically upgrading executable instructions on client devices, the method comprising:
storing remotely from the client devices at least two versions of client executable upgraded instructions selectively loadable to the client device and executable thereby;
communicatively coupling a server and at least one of the client devices;
operating the server in at least a first instance to push an installation of at least a first version of client executable upgraded instructions to the client device; and
operating the server in at least a second instance to allow at least one of the client devices to pull an installation of the first version of client executable upgraded instructions to the client device.
10. The method of claim 9 wherein the first instance occurs before the second instance.
11. The method of claim 9 wherein the second instance occurs before the first instance.
12. The method of claim 9, further comprising:
determining a configuration of the client device;
selecting between the at least two versions of client executable upgraded instructions based on the determined configuration of the client device.
13. The method of claim 12, further comprising:
storing the configuration of the client device at the server.
14. The method of claim 9, further comprising:
determining an availability of a specific version of client executable upgraded instructions.
15. The method of claim 9 wherein the installation of a new operating system comprises:
determining a configuration of at least one of the client devices;
archiving an application and a set of user data of the client device on the server;
providing a version of installation software of the new operating system to the client device corresponding to the configuration of the client device;
rebooting the client device;
installing a version of the archived application optimized to the new operating system on the client device; and
restoring the archived set of user data to the client device.
16. A method for automatically upgrading instructions on a client device, the client device having memory for storing instructions, the method comprising:
providing data communication between a number of client devices and a server through a network;
storing in a memory accessible by the server, a plurality of versions of client upgrade instructions selectively loadable to the client device and executable thereby;
in at least one instance pushing an installation of at least one of the versions of client upgrade instructions from the server to at least one of the client devices; and
in at least a second instance, pulling an installation of at least one of the versions of client upgrade instructions from the server to at least one of the client devices.
17. The method of claim 16, further comprising:
determining a configuration of at least one of the client devices; and
selecting one of the versions of client upgrade instructions based on the determined configuration of the at least one of the client devices before pushing or pulling an installation of at least one of the versions of client upgrade instructions from the server to at least one of the client devices.
18. The method of claim 17, further comprising:
storing a representation of the configuration of the client device at the server.
19. The method of claim 17, further comprising:
storing a representation of the configuration of the client device at the client device.
20. The method of claim 16, further comprising:
from time-to-time, the client device determining whether a specific version of client upgrade instructions is available on the server.
21. The method of claim 16 wherein storing in a memory accessible by the server, a plurality of versions of client upgrade instructions selectively loadable to the client device and executable thereby comprises storing an upgrade version of an operating system.
22. The method of claim 21, further comprising:
determining a configuration of the client device;
archiving an application and a set of user data of the client device on the server;
providing the upgrade version of the operating system to the client device corresponding to the configuration of the client device;
rebooting the client device;
installing a version of the archived application optimized to the upgraded version of the operating system on the client device; and
restoring the archived set of user data to the client device.
US11/051,118 1999-09-22 2005-02-03 Automated software upgrade utility Abandoned US20050257215A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US11/051,118 US20050257215A1 (en) 1999-09-22 2005-02-03 Automated software upgrade utility

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US15550299P 1999-09-22 1999-09-22
US09/664,459 US6976062B1 (en) 1999-09-22 2000-09-18 Automated software upgrade utility
US11/051,118 US20050257215A1 (en) 1999-09-22 2005-02-03 Automated software upgrade utility

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US09/664,459 Continuation US6976062B1 (en) 1999-09-22 2000-09-18 Automated software upgrade utility

Publications (1)

Publication Number Publication Date
US20050257215A1 true US20050257215A1 (en) 2005-11-17

Family

ID=35452706

Family Applications (2)

Application Number Title Priority Date Filing Date
US09/664,459 Expired - Lifetime US6976062B1 (en) 1999-09-22 2000-09-18 Automated software upgrade utility
US11/051,118 Abandoned US20050257215A1 (en) 1999-09-22 2005-02-03 Automated software upgrade utility

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US09/664,459 Expired - Lifetime US6976062B1 (en) 1999-09-22 2000-09-18 Automated software upgrade utility

Country Status (1)

Country Link
US (2) US6976062B1 (en)

Cited By (61)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20050060530A1 (en) * 2003-09-12 2005-03-17 Giga-Byte Technology Co., Ltd Method for displaying information of updating BIOS
US20070157195A1 (en) * 2005-12-30 2007-07-05 Bettina Gaa-Frost Deploying software based on a calculated deployment risk level
US20070282983A1 (en) * 2006-06-05 2007-12-06 Manoj Gujarathi System and Method for Information Handling System Management With a Directory Service Tool Box
US20080001711A1 (en) * 2006-06-15 2008-01-03 Microsoft Corporation Reliability of execution for device provider implementations
US20080001710A1 (en) * 2006-06-15 2008-01-03 Microsoft Corporation Support for batching of events, and shredding of batched events in the rfid infrastructure platform
US20080028391A1 (en) * 2006-07-27 2008-01-31 Microsoft Corporation Minimizing user disruption during modification operations
US20080141235A1 (en) * 2006-12-12 2008-06-12 Russell Woodbury System and Method for Transparent Hard Disk Drive Update
US20080148255A1 (en) * 2003-10-30 2008-06-19 Ramachandran Puthukode G Autonomic auto-configuration using prior installation configuration relationships
US20080163227A1 (en) * 2006-12-27 2008-07-03 Samsung Electronics Co., Ltd. Server and client, and update supporting and performing methods thereof
US20080174404A1 (en) * 2007-01-23 2008-07-24 Microsoft Corporation Dynamic updates in rfid manager
US20080184151A1 (en) * 2007-01-25 2008-07-31 Microsoft Corporation Standardized mechanism for firmware upgrades of rfid devices
US20080288625A1 (en) * 2006-01-04 2008-11-20 Microsoft Corporation Rfid device groups
US20080319555A1 (en) * 2006-03-02 2008-12-25 Mikael Meyer Method For Evaluating, An Automation System And a Controller
US20090017812A1 (en) * 2007-07-11 2009-01-15 Weng Chong Chan Method and system for restoring user settings after over-the-air update of mobile electronic device software
WO2009067258A1 (en) * 2007-11-25 2009-05-28 Trilliant Networks, Inc. Upgrade process system and method
US20090144721A1 (en) * 2007-11-30 2009-06-04 Sap Ag System and method for providing software upgrades
US20090228868A1 (en) * 2008-03-04 2009-09-10 Max Drukman Batch configuration of multiple target devices
US20090235246A1 (en) * 2008-03-17 2009-09-17 Cellnet Innovations, Inc. Methods and Systems for Distributing Firmware Through an Over-the-Air Network
US20090282157A1 (en) * 2004-04-20 2009-11-12 Wyse Technology Inc. Firmware upgrade for thin clients using one or more servers
US20100125840A1 (en) * 2008-11-18 2010-05-20 Schneider James P Automation of application deployment
US7761864B2 (en) 2005-08-09 2010-07-20 Intermec Ip Corp. Method, apparatus and article to load new instructions on processor based devices, for example, automatic data collection devices
US20100251232A1 (en) * 2009-03-30 2010-09-30 Kiyohiko Shinomiya Image processing apparatus, software delivery system, and install processing method
US20100281474A1 (en) * 2009-04-30 2010-11-04 Eason Patrick C Firmware updating
US8069369B2 (en) 1999-01-29 2011-11-29 Intermec Ip Corp. Remote anomaly diagnosis and reconfiguration of an automatic data collection device platform over a telecommunications network
US8138934B2 (en) 2007-11-25 2012-03-20 Trilliant Networks, Inc. System and method for false alert filtering of event messages within a network
US8144596B2 (en) 2007-11-25 2012-03-27 Trilliant Networks, Inc. Communication and message route optimization and messaging in a mesh network
US20120079474A1 (en) * 2010-09-24 2012-03-29 Stephen Gold Reimaging a multi-node storage system
US8171364B2 (en) 2007-11-25 2012-05-01 Trilliant Networks, Inc. System and method for power outage and restoration notification in an advanced metering infrastructure network
US8289182B2 (en) 2008-11-21 2012-10-16 Trilliant Networks, Inc. Methods and systems for virtual energy management display
US8319658B2 (en) 2009-03-11 2012-11-27 Trilliant Networks, Inc. Process, device and system for mapping transformers to meters and locating non-technical line losses
US8332055B2 (en) 2007-11-25 2012-12-11 Trilliant Networks, Inc. Energy use control system and method
US8334787B2 (en) 2007-10-25 2012-12-18 Trilliant Networks, Inc. Gas meter having ultra-sensitive magnetic material retrofitted onto meter dial and method for performing meter retrofit
US20130086231A1 (en) * 2011-09-30 2013-04-04 Samsung Electronics Co., Ltd. Upgrade system and method having adaptive changeable upgrade process
US20130167133A1 (en) * 2010-10-11 2013-06-27 Zte Corporation Method, terminal and system for upgrading software version
US8502640B2 (en) 2007-11-25 2013-08-06 Trilliant Networks, Inc. System and method for transmitting and receiving information on a neighborhood area network
US20140047425A1 (en) * 2012-08-07 2014-02-13 Microsoft Corporation Initiating update operations
US8699377B2 (en) 2008-09-04 2014-04-15 Trilliant Networks, Inc. System and method for implementing mesh network communications using a mesh network protocol
US20140250077A1 (en) * 2013-03-01 2014-09-04 Storagecraft Technology Corporation Deduplication vault storage seeding
US8832428B2 (en) 2010-11-15 2014-09-09 Trilliant Holdings Inc. System and method for securely communicating across multiple networks using a single radio
US8856323B2 (en) 2011-02-10 2014-10-07 Trilliant Holdings, Inc. Device and method for facilitating secure communications over a cellular network
US8944332B2 (en) 2006-08-04 2015-02-03 Intermec Ip Corp. Testing automatic data collection devices, such as barcode, RFID and/or magnetic stripe readers
US8970394B2 (en) 2011-01-25 2015-03-03 Trilliant Holdings Inc. Aggregated real-time power outages/restoration reporting (RTPOR) in a secure mesh network
US9001787B1 (en) 2011-09-20 2015-04-07 Trilliant Networks Inc. System and method for implementing handover of a hybrid communications module
US9013173B2 (en) 2010-09-13 2015-04-21 Trilliant Networks, Inc. Process for detecting energy theft
US9041349B2 (en) 2011-03-08 2015-05-26 Trilliant Networks, Inc. System and method for managing load distribution across a power grid
US9084120B2 (en) 2010-08-27 2015-07-14 Trilliant Networks Inc. System and method for interference free operation of co-located transceivers
US20150362900A1 (en) * 2014-06-11 2015-12-17 Azbil Corporation Engineering device, engineering system, and download processing method
US9282383B2 (en) 2011-01-14 2016-03-08 Trilliant Incorporated Process, device and system for volt/VAR optimization
US20160132321A1 (en) * 2015-02-10 2016-05-12 Mediatek Inc. Methods For Cross-Mounting Devices And Apparatus Utilizing The Same
CN106095822A (en) * 2016-05-31 2016-11-09 北京小米移动软件有限公司 Software recommendation method, device and server
US20170192773A1 (en) * 2015-12-31 2017-07-06 Kony, Inc. Mobile applications
US10073692B2 (en) * 2016-12-12 2018-09-11 Google Llc System and method of managing application updates
US10089260B2 (en) 2015-02-10 2018-10-02 Mediatek Inc. Control method and system for accessing data among different electronic devices
US20180295023A1 (en) * 2003-12-23 2018-10-11 Intel Corporation Method and apparatus for remote modification of system configuration
US20190034188A1 (en) * 2014-09-30 2019-01-31 Apple Inc. Revision locking
CN110502255A (en) * 2018-05-17 2019-11-26 许昌许继软件技术有限公司 A kind of software update system of track traffic synthetic monitoring system
US10528708B2 (en) * 2016-12-16 2020-01-07 International Business Machines Corporation Prevention of unauthorized resource updates
CN112783527A (en) * 2021-01-25 2021-05-11 中国重汽集团济南动力有限公司 Method and device for upgrading vehicle controller program
CN112954036A (en) * 2021-02-03 2021-06-11 博为科技有限公司 Software upgrading method, terminal equipment and system
US11210080B1 (en) * 2006-04-11 2021-12-28 Open Invention Network Llc Workstation uptime, maintenance, and reboot service
WO2023151372A1 (en) * 2022-02-14 2023-08-17 西安广和通无线软件有限公司 Module upgrade method and system

Families Citing this family (78)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7526762B1 (en) * 2000-06-30 2009-04-28 Nokia Corporation Network with mobile terminals as browsers having wireless access to the internet and method for using same
US7496739B1 (en) * 2000-06-30 2009-02-24 Microsoft Corporation System and related methods for automatically configuring a computing system
US7251775B1 (en) * 2000-06-30 2007-07-31 Nokia Corporation System and method for visual history presentation and management
US7103650B1 (en) * 2000-09-26 2006-09-05 Microsoft Corporation Client computer configuration based on server computer update
US7945042B1 (en) * 2000-12-29 2011-05-17 Cisco Technology, Inc. Method for switching active calls
KR100400458B1 (en) * 2001-05-14 2003-10-01 엘지전자 주식회사 Method to Upgrade a Protocol used in Network available Home Appliance
US7106541B2 (en) 2001-09-14 2006-09-12 Convergent Systems Solutions, Llc Digital device configuration and method
US7162578B2 (en) * 2001-09-14 2007-01-09 Cornice, Inc. Digital device configuration and method
US6973535B2 (en) * 2001-09-14 2005-12-06 Cornice, Inc. Digital device configuration and method
JP2003308215A (en) * 2002-02-14 2003-10-31 Canon Inc Information processor, control method, and control program
US7599293B1 (en) 2002-04-25 2009-10-06 Lawrence Michael Bain System and method for network traffic and I/O transaction monitoring of a high speed communications network
JP2003323364A (en) * 2002-05-08 2003-11-14 Canon Inc Network device management device and method, computer program and computer-readable storage medium
US9009694B2 (en) * 2002-05-22 2015-04-14 Oracle America, Inc. Pre-verification and sequencing of patches
US20030221190A1 (en) * 2002-05-22 2003-11-27 Sun Microsystems, Inc. System and method for performing patch installation on multiple devices
US7823148B2 (en) * 2002-05-22 2010-10-26 Oracle America, Inc. System and method for performing patch installation via a graphical user interface
US6836657B2 (en) * 2002-11-12 2004-12-28 Innopath Software, Inc. Upgrading of electronic files including automatic recovery from failures and errors occurring during the upgrade
GB2403105B (en) * 2003-06-17 2006-10-18 Imagine Broadband Ltd Method and system for selectively distributing data to a set of network devices
US7814126B2 (en) * 2003-06-25 2010-10-12 Microsoft Corporation Using task sequences to manage devices
US7337317B2 (en) 2003-07-03 2008-02-26 Hand Held Products, Inc. Memory data copying system for devices
WO2005033964A1 (en) * 2003-09-05 2005-04-14 Itron, Inc. Synchronizing and controlling software downloads, such as for utility meter-reading data collection and processing
US20050114499A1 (en) * 2003-11-24 2005-05-26 Monk John M. System and method for updating testing devices in a distributed environment
US20050125489A1 (en) * 2003-11-26 2005-06-09 Hanes David H. System and method for determining messages on a server as relating to at least one functional component of a client system
JP4666906B2 (en) * 2003-12-04 2011-04-06 株式会社ブロードリーフ Method for detecting violation of system environment rules of client device
US7467378B1 (en) * 2004-02-09 2008-12-16 Symantec Corporation System state rollback after modification failure
US7555679B2 (en) * 2004-10-13 2009-06-30 Lenovo (Singapore) Pte Ltd System and method for computer system rejuvenation
US8209156B2 (en) 2005-04-08 2012-06-26 Caterpillar Inc. Asymmetric random scatter process for probabilistic modeling system for product design
US7565333B2 (en) 2005-04-08 2009-07-21 Caterpillar Inc. Control system and method
US7877239B2 (en) 2005-04-08 2011-01-25 Caterpillar Inc Symmetric random scatter process for probabilistic modeling system for product design
US8364610B2 (en) 2005-04-08 2013-01-29 Caterpillar Inc. Process modeling and optimization method and system
CN1928818A (en) * 2005-09-09 2007-03-14 鸿富锦精密工业(深圳)有限公司 Network device and software updating method thereof
US7487134B2 (en) 2005-10-25 2009-02-03 Caterpillar Inc. Medical risk stratifying method and system
US7499842B2 (en) 2005-11-18 2009-03-03 Caterpillar Inc. Process model based virtual sensor and method
US7934660B2 (en) 2006-01-05 2011-05-03 Hand Held Products, Inc. Data collection system having reconfigurable data collection terminal
US20070180206A1 (en) * 2006-01-18 2007-08-02 Craft Julie L Method of updating a duplicate copy of an operating system on the same disk
US7505949B2 (en) 2006-01-31 2009-03-17 Caterpillar Inc. Process model error correction method and system
US7818740B2 (en) * 2006-05-05 2010-10-19 Microsoft Corporation Techniques to perform gradual upgrades
US20080040767A1 (en) * 2006-08-11 2008-02-14 Sbc Knowledge Ventures, L.P. System and method of providing a set-top box application
US8387038B2 (en) * 2006-08-14 2013-02-26 Caterpillar Inc. Method and system for automatic computer and user migration
US8478506B2 (en) 2006-09-29 2013-07-02 Caterpillar Inc. Virtual sensor based engine control system and method
US7483774B2 (en) 2006-12-21 2009-01-27 Caterpillar Inc. Method and system for intelligent maintenance
US8539473B2 (en) * 2007-01-30 2013-09-17 Microsoft Corporation Techniques for providing information regarding software components for a user-defined context
US9112891B2 (en) * 2007-02-02 2015-08-18 Sharp Laboratories Of America, Inc. Remote firmware management for electronic devices
US8019794B2 (en) * 2007-04-02 2011-09-13 Sharp Laboratories Of America, Inc. Firmware repository for MFP devices
US8307341B2 (en) * 2007-04-25 2012-11-06 International Business Machines Corporation Generating customized documentation for a software product
US7787969B2 (en) 2007-06-15 2010-08-31 Caterpillar Inc Virtual sensor system and method
US7831416B2 (en) 2007-07-17 2010-11-09 Caterpillar Inc Probabilistic modeling system for product design
US7788070B2 (en) 2007-07-30 2010-08-31 Caterpillar Inc. Product design optimization method and system
US8635309B2 (en) 2007-08-09 2014-01-21 Hand Held Products, Inc. Methods and apparatus to change a feature set on data collection devices
US7857222B2 (en) 2007-08-16 2010-12-28 Hand Held Products, Inc. Data collection system having EIR terminal interface node
US7542879B2 (en) 2007-08-31 2009-06-02 Caterpillar Inc. Virtual sensor based control system and method
US7593804B2 (en) 2007-10-31 2009-09-22 Caterpillar Inc. Fixed-point virtual sensor control system and method
US8036764B2 (en) 2007-11-02 2011-10-11 Caterpillar Inc. Virtual sensor network (VSN) system and method
US8224468B2 (en) 2007-11-02 2012-07-17 Caterpillar Inc. Calibration certificate for virtual sensor network (VSN)
CN101150460A (en) * 2007-11-14 2008-03-26 华为技术有限公司 Method and system for automatic debugging and testing of network devices
CN101470610B (en) * 2007-12-25 2011-07-20 英业达股份有限公司 Updating method of program used for test
US8086640B2 (en) 2008-05-30 2011-12-27 Caterpillar Inc. System and method for improving data coverage in modeling systems
US7917333B2 (en) 2008-08-20 2011-03-29 Caterpillar Inc. Virtual sensor network (VSN) based control system and method
US8392904B2 (en) * 2009-03-12 2013-03-05 International Business Machines Corporation Apparatus, system, and method for efficient code update
US8528037B2 (en) 2009-08-28 2013-09-03 CSC Holdings, LLC Dynamic application loader for set top box
US9497092B2 (en) 2009-12-08 2016-11-15 Hand Held Products, Inc. Remote device management interface
US9589164B2 (en) 2010-06-24 2017-03-07 Metrologic Instruments, Inc. Distinctive notice for different symbology information
US9189669B2 (en) 2010-06-24 2015-11-17 Metrologic Instruments, Inc. Distinctive notice for different symbology information
US8517269B2 (en) 2010-11-09 2013-08-27 Hand Held Products, Inc. Using a user'S application to configure user scanner
US10114660B2 (en) * 2011-02-22 2018-10-30 Julian Michael Urbach Software application delivery and launching system
US8793004B2 (en) 2011-06-15 2014-07-29 Caterpillar Inc. Virtual sensor system and method for generating output parameters
US8539123B2 (en) 2011-10-06 2013-09-17 Honeywell International, Inc. Device management using a dedicated management interface
US8621123B2 (en) 2011-10-06 2013-12-31 Honeywell International Inc. Device management using virtual interfaces
KR101850817B1 (en) * 2011-11-17 2018-04-23 삼성전자주식회사 The method and apparatus for auto installing applications into different terminal
US8608053B2 (en) 2012-04-30 2013-12-17 Honeywell International Inc. Mobile communication terminal configured to display multi-symbol decodable indicia
KR102255952B1 (en) * 2013-06-28 2021-05-25 삼성전자 주식회사 Method And Apparatus For Updating Application
US8918775B1 (en) * 2013-07-12 2014-12-23 Ca, Inc. Dynamic release control of software application version changes
US8997082B1 (en) * 2013-07-16 2015-03-31 Amazon Technologies, Inc. Differential patch of content
JP6270616B2 (en) * 2014-05-02 2018-01-31 キヤノン株式会社 Information processing apparatus, control method therefor, and program
US10392918B2 (en) * 2014-12-10 2019-08-27 Baker Hughes, A Ge Company, Llc Method of and system for remote diagnostics of an operational system
US20160314294A1 (en) 2015-04-24 2016-10-27 Hand Held Products, Inc. Secure unattended network authentication
US11209972B2 (en) 2015-09-02 2021-12-28 D&M Holdings, Inc. Combined tablet screen drag-and-drop interface
CN108600031A (en) * 2018-05-10 2018-09-28 烽火通信科技股份有限公司 A kind of lower key of linux system upgrades the implementation method of primary, spare board
US11308050B2 (en) 2019-11-15 2022-04-19 Bank Of America Corporation Conversion mechanism for complex cohabitation databases

Citations (94)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4527237A (en) * 1979-10-11 1985-07-02 Nanodata Computer Corporation Data processing system
US4801786A (en) * 1984-05-25 1989-01-31 Anatoli Stobbe Checking system and method for verifying checking stations in a monitoring system
US4825058A (en) * 1986-10-14 1989-04-25 Hewlett-Packard Company Bar code reader configuration and control using a bar code menu to directly access memory
US5034598A (en) * 1989-12-29 1991-07-23 Hewlett-Packard Company Keyboard emulation system providing audible feedback without a built-in transducer
US5036479A (en) * 1989-04-20 1991-07-30 Trw Inc. Modular automated avionics test system
US5052020A (en) * 1990-01-18 1991-09-24 Norand Corporation Method of and apparatus for controlling modulation of digital signals in frequency-modulated transmissions
US5121342A (en) * 1989-08-28 1992-06-09 Network Communications Corporation Apparatus for analyzing communication networks
US5218188A (en) * 1989-10-24 1993-06-08 Norand Corporation Compact hand-held RF data terminal
US5261079A (en) * 1990-12-18 1993-11-09 International Business Machines Corporation Interface for keyboard emulation provided by an operating system
US5295154A (en) * 1991-10-01 1994-03-15 Norand Corporation Radio frequency local area network
US5309351A (en) * 1988-10-27 1994-05-03 Texas Instruments Incorporated Communications, information, maintenance diagnostic and training system
US5349678A (en) * 1991-08-21 1994-09-20 Norand Corporation Versatile RF data capture system
US5404493A (en) * 1992-11-17 1995-04-04 Intermec Corporation Method and computer system for processing keycode data and symbol code data in a bar code device
US5418684A (en) * 1989-06-07 1995-05-23 Norand Corporation Hand-held data capture system with interchangeable modules
US5425051A (en) * 1992-11-09 1995-06-13 Norand Corporation Radio frequency communication network having adaptive parameters
US5440564A (en) * 1990-06-01 1995-08-08 Motorola, Inc. Data multiplexer with simultaneous multiple channel capability
US5453933A (en) * 1993-09-08 1995-09-26 Hurco Companies, Inc. CNC control system
US5471596A (en) * 1992-04-13 1995-11-28 Digital Equipment Corporation Computer memory device holding a data structure for implementation of function objects
US5490252A (en) * 1992-09-30 1996-02-06 Bay Networks Group, Inc. System having central processor for transmitting generic packets to another processor to be altered and transmitting altered packets back to central processor for routing
US5497450A (en) * 1994-01-07 1996-03-05 Monarch Marking Systems, Inc. Universal controller interface for barcode printers
US5572512A (en) * 1995-07-05 1996-11-05 Motorola, Inc. Data routing method and apparatus for communication systems having multiple nodes
US5577229A (en) * 1989-01-30 1996-11-19 Alantec Corporation Computer system and method for pipelined transfer of data between modules utilizing a shared memory and a pipeline having a plurality of registers
US5579367A (en) * 1995-03-13 1996-11-26 Chaparral Communications, Inc. Multi-medium closed-loop controlled satellite broadcast network for simple end-user operation
US5602742A (en) * 1995-01-10 1997-02-11 Solondz; Leonard I. Postage metering system
US5604516A (en) * 1994-06-30 1997-02-18 Symbol Technologies, Inc. Graphical user interface control for providing both automatic and manual data input
US5613160A (en) * 1992-11-18 1997-03-18 Canon Kabushiki Kaisha In an interactive network board, method and apparatus for placing a network peripheral in a default configuration
US5623604A (en) * 1992-11-18 1997-04-22 Canon Information Systems, Inc. Method and apparatus for remotely altering programmable firmware stored in an interactive network board coupled to a network peripheral
US5623603A (en) * 1994-11-02 1997-04-22 Fls Acquistion Corporation Method of transferring data at adjustable levels of priorities to provide optimum response to user demands
US5640002A (en) * 1995-08-15 1997-06-17 Ruppert; Jonathan Paul Portable RF ID tag and barcode reader
US5673385A (en) * 1994-06-15 1997-09-30 Hewlett-Packard Company Method for downloading special code from a computer to a hard copy apparatus
US5724510A (en) * 1996-09-06 1998-03-03 Fluke Corporation Method of configuring a valid IP address and detecting duplicate IP addresses in a local area network
US5742762A (en) * 1995-05-19 1998-04-21 Telogy Networks, Inc. Network management gateway
US5748884A (en) * 1996-06-13 1998-05-05 Mci Corporation Autonotification system for notifying recipients of detected events in a network environment
US5761428A (en) * 1996-07-05 1998-06-02 Ncr Corporation Method and aparatus for providing agent capability independent from a network node
US5799317A (en) * 1995-11-08 1998-08-25 Mci Communications Corporation Data management system for a telecommunications signaling system 7(SS#7)
US5857190A (en) * 1996-06-27 1999-01-05 Microsoft Corporation Event logging system and method for logging events in a network system
US5860068A (en) * 1997-12-04 1999-01-12 Petabyte Corporation Method and system for custom manufacture and delivery of a data product
US5893083A (en) * 1995-03-24 1999-04-06 Hewlett-Packard Company Methods and apparatus for monitoring events and implementing corrective action in a computer system
US5917043A (en) * 1995-12-22 1999-06-29 Smithkline Beecham Corporation 4-aryl-5-pyrimidine imiazole substituted compounds
US5919248A (en) * 1997-03-25 1999-07-06 Fluke Corporation Method and apparatus for determining network health as a function of combined percent utilization and percent collisions
US5943503A (en) * 1996-01-09 1999-08-24 Canon Kabushiki Kaisha Status-controlled interrogation of peripheral device status
US5961594A (en) * 1996-09-26 1999-10-05 International Business Machines Corporation Remote node maintenance and management method and system in communication networks using multiprotocol agents
US5969326A (en) * 1998-01-14 1999-10-19 Intermec Ip Corp. Method and apparatus of autodiscriminating in symbol reader employing prioritized and updated table of symbologies
US5974237A (en) * 1996-12-18 1999-10-26 Northern Telecom Limited Communications network monitoring
US5979757A (en) * 1996-09-05 1999-11-09 Symbol Technologies, Inc. Method and system for presenting item information using a portable data terminal
US6028605A (en) * 1998-02-03 2000-02-22 Documentum, Inc. Multi-dimensional analysis of objects by manipulating discovered semantic properties
US6027024A (en) * 1994-08-17 2000-02-22 Metrologic Instruments, Inc. Hand-held portable WWW access terminal with visual display panel and GUI-based WWW browser program integrated with bar code symbol reader
US6041041A (en) * 1997-04-15 2000-03-21 Ramanathan; Srinivas Method and system for managing data service systems
US6073169A (en) * 1997-04-08 2000-06-06 Abb Power T&D Company Inc. Automatic meter reading system employing common broadcast command channel
US6094679A (en) * 1998-01-16 2000-07-25 Microsoft Corporation Distribution of software in a computer network environment
US6102295A (en) * 1998-01-14 2000-08-15 Intermec Ip Corp. Method and apparatus for decoding symbols by declaring erasures of element characteristics
US6108782A (en) * 1996-12-13 2000-08-22 3Com Corporation Distributed remote monitoring (dRMON) for networks
US6122664A (en) * 1996-06-27 2000-09-19 Bull S.A. Process for monitoring a plurality of object types of a plurality of nodes from a management node in a data processing system by distributing configured agents
US6119941A (en) * 1998-05-04 2000-09-19 Intermec Ip Corp. Automated help instructions for automatically or adaptively configuring a hand-held device, such as a bar code reader or hand-held personal computer
US6170015B1 (en) * 1998-05-15 2001-01-02 Nortel Networks Limited Network apparatus with Java co-processor
US6175868B1 (en) * 1998-05-15 2001-01-16 Nortel Networks Limited Method and apparatus for automatically configuring a network switch
US6178426B1 (en) * 1998-01-15 2001-01-23 Symbol Technologies, Inc. Apparatus with extended markup language data capture capability
US6195171B1 (en) * 1995-05-12 2001-02-27 Canon Kabushiki Kaisha Printer and interface unit, printing system, and method for setting communication parameters in printer
US6226675B1 (en) * 1998-10-16 2001-05-01 Commerce One, Inc. Participant server which process documents for commerce in trading partner networks
US6229540B1 (en) * 1996-02-23 2001-05-08 Visionael Corporation Auditing networks
US6243105B1 (en) * 1998-11-19 2001-06-05 Ncr Corporation Drill-down method to historical data in a performance monitor using a platform independent program
US6263387B1 (en) * 1997-10-01 2001-07-17 Micron Electronics, Inc. System for automatically configuring a server after hot add of a device
US6269330B1 (en) * 1997-10-07 2001-07-31 Attune Networks Ltd. Fault location and performance testing of communication networks
US6272537B1 (en) * 1997-11-17 2001-08-07 Fujitsu Limited Method for building element manager for a computer network element using a visual element manager builder process
US6279153B1 (en) * 1995-10-16 2001-08-21 Nec Corporation Multi-user flash ROM update
US6285889B1 (en) * 1996-08-08 2001-09-04 Nokia Mobile Phones Limited Information output system, method for outputting information and terminal devices for outputting information via mobile communication network
US6289501B1 (en) * 1999-03-31 2001-09-11 Unisys Corp. Method for generating simple document type definitions
US6305605B1 (en) * 1999-08-09 2001-10-23 John W. Goetz Multiple-casualty incident patient tracking
US6308205B1 (en) * 1998-10-22 2001-10-23 Canon Kabushiki Kaisha Browser-based network management allowing administrators to use web browser on user's workstation to view and update configuration of network devices
US6335795B1 (en) * 1997-09-15 2002-01-01 International Business Machines Corporation Method for customizing print attribute choices based on selected model, media, and printer
US6356949B1 (en) * 1999-01-29 2002-03-12 Intermec Ip Corp. Automatic data collection device that receives data output instruction from data consumer
US6360255B1 (en) * 1998-06-25 2002-03-19 Cisco Technology, Inc. Automatically integrating an external network with a network management system
US6378069B1 (en) * 1998-11-04 2002-04-23 Nortel Networks Limited Apparatus and methods for providing software updates to devices in a communication network
US6389464B1 (en) * 1997-06-27 2002-05-14 Cornet Technology, Inc. Device management system for managing standards-compliant and non-compliant network elements using standard management protocols and a universal site server which is configurable from remote locations via internet browser technology
US6398105B2 (en) * 1999-01-29 2002-06-04 Intermec Ip Corporation Automatic data collection device that intelligently switches data based on data type
US6409661B1 (en) * 1997-03-08 2002-06-25 Remote Diagnostic Technologies Limited Diagnostic apparatus
US6457883B1 (en) * 1999-06-30 2002-10-01 Silverbrook Research Pty Ltd Interactive printer reward scheme
US6460070B1 (en) * 1998-06-03 2002-10-01 International Business Machines Corporation Mobile agents for fault diagnosis and correction in a distributed computer environment
US6473798B1 (en) * 1998-12-15 2002-10-29 Cisco Technology, Inc. Method and system for testing a layer-2 tunnel in a data communication network
US6473788B1 (en) * 1996-11-15 2002-10-29 Canon Kabushiki Kaisha Remote maintenance and servicing of a network peripheral device over the world wide web
US6507856B1 (en) * 1999-01-05 2003-01-14 International Business Machines Corporation Dynamic business process automation system using XML documents
US6539422B1 (en) * 1998-05-04 2003-03-25 Intermec Ip Corp. Automatic data collection device having a network communications capability
US20030058469A1 (en) * 2001-09-26 2003-03-27 International Business Machines Corporation Method and apparatus for printing XML directly using a formatting template
US6540142B1 (en) * 2001-12-17 2003-04-01 Zih Corp. Native XML printer
US6568596B1 (en) * 2000-10-02 2003-05-27 Symbol Technologies, Inc. XML-based barcode scanner
US6571215B1 (en) * 1997-01-21 2003-05-27 Microsoft Corporation System and method for generating a schedule based on resource assignments
US6587684B1 (en) * 1998-07-28 2003-07-01 Bell Atlantic Nynex Mobile Digital wireless telephone system for downloading software to a digital telephone using wireless data link protocol
US6597465B1 (en) * 1994-08-09 2003-07-22 Intermec Ip Corp. Automatic mode detection and conversion system for printers and tag interrogators
US6614804B1 (en) * 1999-03-22 2003-09-02 Webtv Networks, Inc. Method and apparatus for remote update of clients by a server via broadcast satellite
US6618162B1 (en) * 1999-01-26 2003-09-09 Intermec Ip Corp. Apparatus and method to configure a device, such as a printer, over a network
US20040040023A1 (en) * 2002-08-22 2004-02-26 Ellis David G. Remote identification loader
US6764009B2 (en) * 2001-05-30 2004-07-20 Lightwaves Systems, Inc. Method for tagged bar code data interchange
US20050034029A1 (en) * 1999-01-29 2005-02-10 Intermec Ip Corp. Remote anomaly diagnosis and reconfiguration of an automatic data collection device platform over a telecommunications network
US6908034B2 (en) * 2001-12-17 2005-06-21 Zih Corp. XML system

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6151643A (en) * 1996-06-07 2000-11-21 Networks Associates, Inc. Automatic updating of diverse software products on multiple client computer systems by downloading scanning application to client computer and generating software list on client computer
US6006034A (en) * 1996-09-05 1999-12-21 Open Software Associates, Ltd. Systems and methods for automatic application version upgrading and maintenance
US6167567A (en) * 1998-05-05 2000-12-26 3Com Corporation Technique for automatically updating software stored on a client computer in a networked client-server environment

Patent Citations (99)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4527237A (en) * 1979-10-11 1985-07-02 Nanodata Computer Corporation Data processing system
US4801786A (en) * 1984-05-25 1989-01-31 Anatoli Stobbe Checking system and method for verifying checking stations in a monitoring system
US4825058A (en) * 1986-10-14 1989-04-25 Hewlett-Packard Company Bar code reader configuration and control using a bar code menu to directly access memory
US5309351A (en) * 1988-10-27 1994-05-03 Texas Instruments Incorporated Communications, information, maintenance diagnostic and training system
US5577229A (en) * 1989-01-30 1996-11-19 Alantec Corporation Computer system and method for pipelined transfer of data between modules utilizing a shared memory and a pipeline having a plurality of registers
US5036479A (en) * 1989-04-20 1991-07-30 Trw Inc. Modular automated avionics test system
US5418684A (en) * 1989-06-07 1995-05-23 Norand Corporation Hand-held data capture system with interchangeable modules
US5121342A (en) * 1989-08-28 1992-06-09 Network Communications Corporation Apparatus for analyzing communication networks
US5322991A (en) * 1989-10-24 1994-06-21 Norand Corporation Compact hand-held RF data terminal
US5218188A (en) * 1989-10-24 1993-06-08 Norand Corporation Compact hand-held RF data terminal
US5034598A (en) * 1989-12-29 1991-07-23 Hewlett-Packard Company Keyboard emulation system providing audible feedback without a built-in transducer
US5365546A (en) * 1990-01-18 1994-11-15 Norand Corporation Method of and apparatus for controlling modulation of digital signals in frequency-modulated transmissions
US5052020A (en) * 1990-01-18 1991-09-24 Norand Corporation Method of and apparatus for controlling modulation of digital signals in frequency-modulated transmissions
US5440564A (en) * 1990-06-01 1995-08-08 Motorola, Inc. Data multiplexer with simultaneous multiple channel capability
US5261079A (en) * 1990-12-18 1993-11-09 International Business Machines Corporation Interface for keyboard emulation provided by an operating system
US5349678A (en) * 1991-08-21 1994-09-20 Norand Corporation Versatile RF data capture system
US5295154A (en) * 1991-10-01 1994-03-15 Norand Corporation Radio frequency local area network
US5471596A (en) * 1992-04-13 1995-11-28 Digital Equipment Corporation Computer memory device holding a data structure for implementation of function objects
US5490252A (en) * 1992-09-30 1996-02-06 Bay Networks Group, Inc. System having central processor for transmitting generic packets to another processor to be altered and transmitting altered packets back to central processor for routing
US5425051A (en) * 1992-11-09 1995-06-13 Norand Corporation Radio frequency communication network having adaptive parameters
US5404493A (en) * 1992-11-17 1995-04-04 Intermec Corporation Method and computer system for processing keycode data and symbol code data in a bar code device
US5623604A (en) * 1992-11-18 1997-04-22 Canon Information Systems, Inc. Method and apparatus for remotely altering programmable firmware stored in an interactive network board coupled to a network peripheral
US5613160A (en) * 1992-11-18 1997-03-18 Canon Kabushiki Kaisha In an interactive network board, method and apparatus for placing a network peripheral in a default configuration
US5453933A (en) * 1993-09-08 1995-09-26 Hurco Companies, Inc. CNC control system
US5497450A (en) * 1994-01-07 1996-03-05 Monarch Marking Systems, Inc. Universal controller interface for barcode printers
US5673385A (en) * 1994-06-15 1997-09-30 Hewlett-Packard Company Method for downloading special code from a computer to a hard copy apparatus
US5604516A (en) * 1994-06-30 1997-02-18 Symbol Technologies, Inc. Graphical user interface control for providing both automatic and manual data input
US6597465B1 (en) * 1994-08-09 2003-07-22 Intermec Ip Corp. Automatic mode detection and conversion system for printers and tag interrogators
US6027024A (en) * 1994-08-17 2000-02-22 Metrologic Instruments, Inc. Hand-held portable WWW access terminal with visual display panel and GUI-based WWW browser program integrated with bar code symbol reader
US5623603A (en) * 1994-11-02 1997-04-22 Fls Acquistion Corporation Method of transferring data at adjustable levels of priorities to provide optimum response to user demands
US5602742A (en) * 1995-01-10 1997-02-11 Solondz; Leonard I. Postage metering system
US5579367A (en) * 1995-03-13 1996-11-26 Chaparral Communications, Inc. Multi-medium closed-loop controlled satellite broadcast network for simple end-user operation
US5893083A (en) * 1995-03-24 1999-04-06 Hewlett-Packard Company Methods and apparatus for monitoring events and implementing corrective action in a computer system
US6195171B1 (en) * 1995-05-12 2001-02-27 Canon Kabushiki Kaisha Printer and interface unit, printing system, and method for setting communication parameters in printer
US5742762A (en) * 1995-05-19 1998-04-21 Telogy Networks, Inc. Network management gateway
US5572512A (en) * 1995-07-05 1996-11-05 Motorola, Inc. Data routing method and apparatus for communication systems having multiple nodes
US5640002A (en) * 1995-08-15 1997-06-17 Ruppert; Jonathan Paul Portable RF ID tag and barcode reader
US6279153B1 (en) * 1995-10-16 2001-08-21 Nec Corporation Multi-user flash ROM update
US5799317A (en) * 1995-11-08 1998-08-25 Mci Communications Corporation Data management system for a telecommunications signaling system 7(SS#7)
US5917043A (en) * 1995-12-22 1999-06-29 Smithkline Beecham Corporation 4-aryl-5-pyrimidine imiazole substituted compounds
US5943503A (en) * 1996-01-09 1999-08-24 Canon Kabushiki Kaisha Status-controlled interrogation of peripheral device status
US6229540B1 (en) * 1996-02-23 2001-05-08 Visionael Corporation Auditing networks
US5748884A (en) * 1996-06-13 1998-05-05 Mci Corporation Autonotification system for notifying recipients of detected events in a network environment
US6122664A (en) * 1996-06-27 2000-09-19 Bull S.A. Process for monitoring a plurality of object types of a plurality of nodes from a management node in a data processing system by distributing configured agents
US5857190A (en) * 1996-06-27 1999-01-05 Microsoft Corporation Event logging system and method for logging events in a network system
US5761428A (en) * 1996-07-05 1998-06-02 Ncr Corporation Method and aparatus for providing agent capability independent from a network node
US6285889B1 (en) * 1996-08-08 2001-09-04 Nokia Mobile Phones Limited Information output system, method for outputting information and terminal devices for outputting information via mobile communication network
US5979757A (en) * 1996-09-05 1999-11-09 Symbol Technologies, Inc. Method and system for presenting item information using a portable data terminal
US6199753B1 (en) * 1996-09-05 2001-03-13 Symbol Technologies, Inc. Method and system for presenting item information using a portable data terminal
US5724510A (en) * 1996-09-06 1998-03-03 Fluke Corporation Method of configuring a valid IP address and detecting duplicate IP addresses in a local area network
US5961594A (en) * 1996-09-26 1999-10-05 International Business Machines Corporation Remote node maintenance and management method and system in communication networks using multiprotocol agents
US6473788B1 (en) * 1996-11-15 2002-10-29 Canon Kabushiki Kaisha Remote maintenance and servicing of a network peripheral device over the world wide web
US6108782A (en) * 1996-12-13 2000-08-22 3Com Corporation Distributed remote monitoring (dRMON) for networks
US5974237A (en) * 1996-12-18 1999-10-26 Northern Telecom Limited Communications network monitoring
US6571215B1 (en) * 1997-01-21 2003-05-27 Microsoft Corporation System and method for generating a schedule based on resource assignments
US6409661B1 (en) * 1997-03-08 2002-06-25 Remote Diagnostic Technologies Limited Diagnostic apparatus
US5919248A (en) * 1997-03-25 1999-07-06 Fluke Corporation Method and apparatus for determining network health as a function of combined percent utilization and percent collisions
US6073169A (en) * 1997-04-08 2000-06-06 Abb Power T&D Company Inc. Automatic meter reading system employing common broadcast command channel
US6041041A (en) * 1997-04-15 2000-03-21 Ramanathan; Srinivas Method and system for managing data service systems
US6389464B1 (en) * 1997-06-27 2002-05-14 Cornet Technology, Inc. Device management system for managing standards-compliant and non-compliant network elements using standard management protocols and a universal site server which is configurable from remote locations via internet browser technology
US6335795B1 (en) * 1997-09-15 2002-01-01 International Business Machines Corporation Method for customizing print attribute choices based on selected model, media, and printer
US6263387B1 (en) * 1997-10-01 2001-07-17 Micron Electronics, Inc. System for automatically configuring a server after hot add of a device
US6269330B1 (en) * 1997-10-07 2001-07-31 Attune Networks Ltd. Fault location and performance testing of communication networks
US6272537B1 (en) * 1997-11-17 2001-08-07 Fujitsu Limited Method for building element manager for a computer network element using a visual element manager builder process
US5860068A (en) * 1997-12-04 1999-01-12 Petabyte Corporation Method and system for custom manufacture and delivery of a data product
US5969326A (en) * 1998-01-14 1999-10-19 Intermec Ip Corp. Method and apparatus of autodiscriminating in symbol reader employing prioritized and updated table of symbologies
US6102295A (en) * 1998-01-14 2000-08-15 Intermec Ip Corp. Method and apparatus for decoding symbols by declaring erasures of element characteristics
US6095422A (en) * 1998-01-14 2000-08-01 Intermec Ip Corp. Method and apparatus of autodiscriminating in symbol reader employing prioritized and updated table of symbologies
US6178426B1 (en) * 1998-01-15 2001-01-23 Symbol Technologies, Inc. Apparatus with extended markup language data capture capability
US6094679A (en) * 1998-01-16 2000-07-25 Microsoft Corporation Distribution of software in a computer network environment
US6028605A (en) * 1998-02-03 2000-02-22 Documentum, Inc. Multi-dimensional analysis of objects by manipulating discovered semantic properties
US6539422B1 (en) * 1998-05-04 2003-03-25 Intermec Ip Corp. Automatic data collection device having a network communications capability
US6119941A (en) * 1998-05-04 2000-09-19 Intermec Ip Corp. Automated help instructions for automatically or adaptively configuring a hand-held device, such as a bar code reader or hand-held personal computer
US6170015B1 (en) * 1998-05-15 2001-01-02 Nortel Networks Limited Network apparatus with Java co-processor
US6175868B1 (en) * 1998-05-15 2001-01-16 Nortel Networks Limited Method and apparatus for automatically configuring a network switch
US6460070B1 (en) * 1998-06-03 2002-10-01 International Business Machines Corporation Mobile agents for fault diagnosis and correction in a distributed computer environment
US6360255B1 (en) * 1998-06-25 2002-03-19 Cisco Technology, Inc. Automatically integrating an external network with a network management system
US6587684B1 (en) * 1998-07-28 2003-07-01 Bell Atlantic Nynex Mobile Digital wireless telephone system for downloading software to a digital telephone using wireless data link protocol
US6226675B1 (en) * 1998-10-16 2001-05-01 Commerce One, Inc. Participant server which process documents for commerce in trading partner networks
US6308205B1 (en) * 1998-10-22 2001-10-23 Canon Kabushiki Kaisha Browser-based network management allowing administrators to use web browser on user's workstation to view and update configuration of network devices
US6378069B1 (en) * 1998-11-04 2002-04-23 Nortel Networks Limited Apparatus and methods for providing software updates to devices in a communication network
US6243105B1 (en) * 1998-11-19 2001-06-05 Ncr Corporation Drill-down method to historical data in a performance monitor using a platform independent program
US6473798B1 (en) * 1998-12-15 2002-10-29 Cisco Technology, Inc. Method and system for testing a layer-2 tunnel in a data communication network
US6507856B1 (en) * 1999-01-05 2003-01-14 International Business Machines Corporation Dynamic business process automation system using XML documents
US6618162B1 (en) * 1999-01-26 2003-09-09 Intermec Ip Corp. Apparatus and method to configure a device, such as a printer, over a network
US6398105B2 (en) * 1999-01-29 2002-06-04 Intermec Ip Corporation Automatic data collection device that intelligently switches data based on data type
US6857013B2 (en) * 1999-01-29 2005-02-15 Intermec Ip.Corp. Remote anomaly diagnosis and reconfiguration of an automatic data collection device platform over a telecommunications network
US20050034029A1 (en) * 1999-01-29 2005-02-10 Intermec Ip Corp. Remote anomaly diagnosis and reconfiguration of an automatic data collection device platform over a telecommunications network
US6356949B1 (en) * 1999-01-29 2002-03-12 Intermec Ip Corp. Automatic data collection device that receives data output instruction from data consumer
US6614804B1 (en) * 1999-03-22 2003-09-02 Webtv Networks, Inc. Method and apparatus for remote update of clients by a server via broadcast satellite
US6289501B1 (en) * 1999-03-31 2001-09-11 Unisys Corp. Method for generating simple document type definitions
US6457883B1 (en) * 1999-06-30 2002-10-01 Silverbrook Research Pty Ltd Interactive printer reward scheme
US6305605B1 (en) * 1999-08-09 2001-10-23 John W. Goetz Multiple-casualty incident patient tracking
US6568596B1 (en) * 2000-10-02 2003-05-27 Symbol Technologies, Inc. XML-based barcode scanner
US6764009B2 (en) * 2001-05-30 2004-07-20 Lightwaves Systems, Inc. Method for tagged bar code data interchange
US20030058469A1 (en) * 2001-09-26 2003-03-27 International Business Machines Corporation Method and apparatus for printing XML directly using a formatting template
US6540142B1 (en) * 2001-12-17 2003-04-01 Zih Corp. Native XML printer
US6908034B2 (en) * 2001-12-17 2005-06-21 Zih Corp. XML system
US20040040023A1 (en) * 2002-08-22 2004-02-26 Ellis David G. Remote identification loader

Cited By (88)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8069369B2 (en) 1999-01-29 2011-11-29 Intermec Ip Corp. Remote anomaly diagnosis and reconfiguration of an automatic data collection device platform over a telecommunications network
US20050060530A1 (en) * 2003-09-12 2005-03-17 Giga-Byte Technology Co., Ltd Method for displaying information of updating BIOS
US20080148255A1 (en) * 2003-10-30 2008-06-19 Ramachandran Puthukode G Autonomic auto-configuration using prior installation configuration relationships
US8234639B2 (en) * 2003-10-30 2012-07-31 International Business Machines Corporation Autonomic auto-configuration using prior installation configuration relationships
US20180295023A1 (en) * 2003-12-23 2018-10-11 Intel Corporation Method and apparatus for remote modification of system configuration
US9075680B2 (en) * 2004-04-20 2015-07-07 Wyse Technology L.L.C. Firmware upgrade for thin clients using one or more servers
US8037198B2 (en) * 2004-04-20 2011-10-11 Wyse Technology Inc. Firmware upgrade for thin clients using one or more servers
US20090282128A1 (en) * 2004-04-20 2009-11-12 Wyse Technology Inc. Firmware upgrade for thin clients using one or more servers
US20090282157A1 (en) * 2004-04-20 2009-11-12 Wyse Technology Inc. Firmware upgrade for thin clients using one or more servers
US7761864B2 (en) 2005-08-09 2010-07-20 Intermec Ip Corp. Method, apparatus and article to load new instructions on processor based devices, for example, automatic data collection devices
US20070157195A1 (en) * 2005-12-30 2007-07-05 Bettina Gaa-Frost Deploying software based on a calculated deployment risk level
US8046755B2 (en) 2005-12-30 2011-10-25 Sap Ag Deploying software based on a calculated deployment risk level
US8452860B2 (en) 2006-01-04 2013-05-28 Microsoft Corporation RFID device groups
US20080288625A1 (en) * 2006-01-04 2008-11-20 Microsoft Corporation Rfid device groups
US20080319555A1 (en) * 2006-03-02 2008-12-25 Mikael Meyer Method For Evaluating, An Automation System And a Controller
US8112165B2 (en) * 2006-03-02 2012-02-07 Abb Ab Method for evaluating, an automation system and a controller
US11210080B1 (en) * 2006-04-11 2021-12-28 Open Invention Network Llc Workstation uptime, maintenance, and reboot service
US20070282983A1 (en) * 2006-06-05 2007-12-06 Manoj Gujarathi System and Method for Information Handling System Management With a Directory Service Tool Box
US8207822B2 (en) 2006-06-15 2012-06-26 Microsoft Corporation Support for batching of events, and shredding of batched events in the RFID infrastructure platform
US20080001710A1 (en) * 2006-06-15 2008-01-03 Microsoft Corporation Support for batching of events, and shredding of batched events in the rfid infrastructure platform
US20080001711A1 (en) * 2006-06-15 2008-01-03 Microsoft Corporation Reliability of execution for device provider implementations
US20080028391A1 (en) * 2006-07-27 2008-01-31 Microsoft Corporation Minimizing user disruption during modification operations
US7873957B2 (en) * 2006-07-27 2011-01-18 Microsoft Corporation Minimizing user disruption during modification operations
US8944332B2 (en) 2006-08-04 2015-02-03 Intermec Ip Corp. Testing automatic data collection devices, such as barcode, RFID and/or magnetic stripe readers
US20080141235A1 (en) * 2006-12-12 2008-06-12 Russell Woodbury System and Method for Transparent Hard Disk Drive Update
US8271968B2 (en) * 2006-12-12 2012-09-18 Dell Products L.P. System and method for transparent hard disk drive update
US20080163227A1 (en) * 2006-12-27 2008-07-03 Samsung Electronics Co., Ltd. Server and client, and update supporting and performing methods thereof
US20080174404A1 (en) * 2007-01-23 2008-07-24 Microsoft Corporation Dynamic updates in rfid manager
US20080184151A1 (en) * 2007-01-25 2008-07-31 Microsoft Corporation Standardized mechanism for firmware upgrades of rfid devices
US8245219B2 (en) 2007-01-25 2012-08-14 Microsoft Corporation Standardized mechanism for firmware upgrades of RFID devices
US20090017812A1 (en) * 2007-07-11 2009-01-15 Weng Chong Chan Method and system for restoring user settings after over-the-air update of mobile electronic device software
US8334787B2 (en) 2007-10-25 2012-12-18 Trilliant Networks, Inc. Gas meter having ultra-sensitive magnetic material retrofitted onto meter dial and method for performing meter retrofit
US8171364B2 (en) 2007-11-25 2012-05-01 Trilliant Networks, Inc. System and method for power outage and restoration notification in an advanced metering infrastructure network
US8138934B2 (en) 2007-11-25 2012-03-20 Trilliant Networks, Inc. System and method for false alert filtering of event messages within a network
US8725274B2 (en) 2007-11-25 2014-05-13 Trilliant Networks, Inc. Energy use control system and method
US8144596B2 (en) 2007-11-25 2012-03-27 Trilliant Networks, Inc. Communication and message route optimization and messaging in a mesh network
WO2009067258A1 (en) * 2007-11-25 2009-05-28 Trilliant Networks, Inc. Upgrade process system and method
US8502640B2 (en) 2007-11-25 2013-08-06 Trilliant Networks, Inc. System and method for transmitting and receiving information on a neighborhood area network
US8332055B2 (en) 2007-11-25 2012-12-11 Trilliant Networks, Inc. Energy use control system and method
US8370697B2 (en) 2007-11-25 2013-02-05 Trilliant Networks, Inc. System and method for power outage and restoration notification in an advanced metering infrastructure network
US20090144721A1 (en) * 2007-11-30 2009-06-04 Sap Ag System and method for providing software upgrades
US8225303B2 (en) * 2007-11-30 2012-07-17 Sap Ag System and method for providing software upgrades
US20090228868A1 (en) * 2008-03-04 2009-09-10 Max Drukman Batch configuration of multiple target devices
US20090235246A1 (en) * 2008-03-17 2009-09-17 Cellnet Innovations, Inc. Methods and Systems for Distributing Firmware Through an Over-the-Air Network
US8402455B2 (en) * 2008-03-17 2013-03-19 Landis+Gyr Innovations, Inc. Methods and systems for distributing firmware through an over-the-air network
US9621457B2 (en) 2008-09-04 2017-04-11 Trilliant Networks, Inc. System and method for implementing mesh network communications using a mesh network protocol
US8699377B2 (en) 2008-09-04 2014-04-15 Trilliant Networks, Inc. System and method for implementing mesh network communications using a mesh network protocol
US20100125840A1 (en) * 2008-11-18 2010-05-20 Schneider James P Automation of application deployment
US8943493B2 (en) * 2008-11-18 2015-01-27 Red Hat, Inc. Automation of application deployment
US8289182B2 (en) 2008-11-21 2012-10-16 Trilliant Networks, Inc. Methods and systems for virtual energy management display
US9189822B2 (en) 2009-03-11 2015-11-17 Trilliant Networks, Inc. Process, device and system for mapping transformers to meters and locating non-technical line losses
US8319658B2 (en) 2009-03-11 2012-11-27 Trilliant Networks, Inc. Process, device and system for mapping transformers to meters and locating non-technical line losses
US20100251232A1 (en) * 2009-03-30 2010-09-30 Kiyohiko Shinomiya Image processing apparatus, software delivery system, and install processing method
US20100281474A1 (en) * 2009-04-30 2010-11-04 Eason Patrick C Firmware updating
US9084120B2 (en) 2010-08-27 2015-07-14 Trilliant Networks Inc. System and method for interference free operation of co-located transceivers
US9013173B2 (en) 2010-09-13 2015-04-21 Trilliant Networks, Inc. Process for detecting energy theft
US20120079474A1 (en) * 2010-09-24 2012-03-29 Stephen Gold Reimaging a multi-node storage system
US20130167133A1 (en) * 2010-10-11 2013-06-27 Zte Corporation Method, terminal and system for upgrading software version
US8832428B2 (en) 2010-11-15 2014-09-09 Trilliant Holdings Inc. System and method for securely communicating across multiple networks using a single radio
US9282383B2 (en) 2011-01-14 2016-03-08 Trilliant Incorporated Process, device and system for volt/VAR optimization
US8970394B2 (en) 2011-01-25 2015-03-03 Trilliant Holdings Inc. Aggregated real-time power outages/restoration reporting (RTPOR) in a secure mesh network
US8856323B2 (en) 2011-02-10 2014-10-07 Trilliant Holdings, Inc. Device and method for facilitating secure communications over a cellular network
US9041349B2 (en) 2011-03-08 2015-05-26 Trilliant Networks, Inc. System and method for managing load distribution across a power grid
US9001787B1 (en) 2011-09-20 2015-04-07 Trilliant Networks Inc. System and method for implementing handover of a hybrid communications module
US9158527B2 (en) * 2011-09-30 2015-10-13 Samsung Electronics Co., Ltd. Upgrade system and method having adaptive changeable upgrade process
US20130086231A1 (en) * 2011-09-30 2013-04-04 Samsung Electronics Co., Ltd. Upgrade system and method having adaptive changeable upgrade process
US20160335076A1 (en) * 2012-08-07 2016-11-17 Microsoft Technology Licensing, Llc Initiating Update Operations
US20140047425A1 (en) * 2012-08-07 2014-02-13 Microsoft Corporation Initiating update operations
US10303457B2 (en) * 2012-08-07 2019-05-28 Microsoft Technology Licensing, Llc Initiating update operations
US9405526B2 (en) * 2012-08-07 2016-08-02 Microsoft Technology Licensing, Llc Initiating update operations
US10007505B2 (en) * 2012-08-07 2018-06-26 Microsoft Technology Licensing, Llc Initiating update operations
US20140250077A1 (en) * 2013-03-01 2014-09-04 Storagecraft Technology Corporation Deduplication vault storage seeding
US20150362900A1 (en) * 2014-06-11 2015-12-17 Azbil Corporation Engineering device, engineering system, and download processing method
US10295978B2 (en) * 2014-06-11 2019-05-21 Azbil Corporation Engineering device, engineering system, and download processing method
US11016748B2 (en) * 2014-09-30 2021-05-25 Apple Inc. Revision locking
US20190034188A1 (en) * 2014-09-30 2019-01-31 Apple Inc. Revision locking
US9952853B2 (en) * 2015-02-10 2018-04-24 Mediatek Inc. Methods for cross-mounting devices and apparatus utilizing the same
US10089260B2 (en) 2015-02-10 2018-10-02 Mediatek Inc. Control method and system for accessing data among different electronic devices
US20160132321A1 (en) * 2015-02-10 2016-05-12 Mediatek Inc. Methods For Cross-Mounting Devices And Apparatus Utilizing The Same
US20170192773A1 (en) * 2015-12-31 2017-07-06 Kony, Inc. Mobile applications
US11340893B2 (en) * 2015-12-31 2022-05-24 Kony, Inc. Mobile application update preserving changes to the application made by a client
CN106095822A (en) * 2016-05-31 2016-11-09 北京小米移动软件有限公司 Software recommendation method, device and server
US10073692B2 (en) * 2016-12-12 2018-09-11 Google Llc System and method of managing application updates
US10528708B2 (en) * 2016-12-16 2020-01-07 International Business Machines Corporation Prevention of unauthorized resource updates
CN110502255A (en) * 2018-05-17 2019-11-26 许昌许继软件技术有限公司 A kind of software update system of track traffic synthetic monitoring system
CN112783527A (en) * 2021-01-25 2021-05-11 中国重汽集团济南动力有限公司 Method and device for upgrading vehicle controller program
CN112954036A (en) * 2021-02-03 2021-06-11 博为科技有限公司 Software upgrading method, terminal equipment and system
WO2023151372A1 (en) * 2022-02-14 2023-08-17 西安广和通无线软件有限公司 Module upgrade method and system

Also Published As

Publication number Publication date
US6976062B1 (en) 2005-12-13

Similar Documents

Publication Publication Date Title
US6976062B1 (en) Automated software upgrade utility
US6816964B1 (en) System, method and medium storing a program controlling a computer, to install a program remotely and automatically into a client by pre-downloaded agent using managing record recording an install execution state of the client and execution control information
TW454147B (en) Recoverable software installation process and apparatus for a computer system
US5764593A (en) Method and system for the interception and control of the computer boot process
US8819670B2 (en) Automated software installation with interview
US20020112232A1 (en) System and process for building host computers
US9075680B2 (en) Firmware upgrade for thin clients using one or more servers
US6408434B1 (en) System and method for using a substitute directory to automatically install an update program
US7650531B2 (en) System and method for automatically restoring hard drives on failure
US6920555B1 (en) Method for deploying an image into other partition on a computer system by using an imaging tool and coordinating migration of user profile to the imaged computer system
CA2010965C (en) Method for loading an operating system through a network
US6301710B1 (en) System and method for creating a substitute registry when automatically installing an update program
US6928579B2 (en) Crash recovery system
US6944653B2 (en) Zero-click deployment of data processing systems
US20020092010A1 (en) Upgrade of a program
US8042107B2 (en) System and method for expediting and automating mainframe computer setup
CN102567051A (en) Method and device for preparing graphical installation system of Loongson platform
US6859924B1 (en) System restore apparatus and method employing virtual restore disk
US5968170A (en) Primary swap size increase on a UNIX based computer system
US5991860A (en) Root file system size increase on a unix based computer system
US20040221024A1 (en) Apparatus and method for setting environment of client in client / server system, and program recording medium therefor
JP5048498B2 (en) Boot disk management utilities
Cisco Chapter 2 - Sun Solaris 8 Operating System Installation
JPH1124934A (en) Distribution management method for client program in client server system
EP1160666A2 (en) Switching versions of software in a system background

Legal Events

Date Code Title Description
STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION