US20070157176A1 - Verification of software application attributes for optimal compatibility with a software system - Google Patents

Verification of software application attributes for optimal compatibility with a software system Download PDF

Info

Publication number
US20070157176A1
US20070157176A1 US11/685,204 US68520407A US2007157176A1 US 20070157176 A1 US20070157176 A1 US 20070157176A1 US 68520407 A US68520407 A US 68520407A US 2007157176 A1 US2007157176 A1 US 2007157176A1
Authority
US
United States
Prior art keywords
information
compatibility
electronic device
software module
operating system
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/685,204
Inventor
Jesse Donaldson
Steven Lemke
Roger Flores
Robert Ebert
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.)
Access Systems Americas Inc
Original Assignee
Access Systems Americas Inc
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 Access Systems Americas Inc filed Critical Access Systems Americas Inc
Priority to US11/685,204 priority Critical patent/US20070157176A1/en
Assigned to PALMSOURCE, INC. reassignment PALMSOURCE, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: EBERT, ROBERT, DONALDSON, JESSE, FLORES, ROGER, LEMKE, STEVEN C.
Publication of US20070157176A1 publication Critical patent/US20070157176A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45537Provision of facilities of other operating environments, e.g. WINE

Definitions

  • the present specification relates to compatibility of software add-ons with electronic devices.
  • the invention relates to a compatibility information source in a software add-on, application, module, or plug-in which contains information relating to the compatibility of the software application with the electronic device on which the add-on, application, module, or plug-in is to run.
  • Handheld computers as well as other types of electronic devices include the use of an operating system running on an electronic processor.
  • Third party software developers often develop software modules configured to run under the operating system, on the processor and using the electronic device hardware.
  • the software module may make certain assumptions about the operating system or about the characteristics (hardware and/or software) of the device that are no longer applicable under the new operating system and/or device. Provided with such assumptions, the software module is often unable to function or functions in an undesirable manner.
  • compatibility information source or software attribute verification resource that is defined by the operating system and is included in the software module.
  • a compatibility information source in software modules, add-ons, applications, or plug-ins which communicate assumptions about the operating system and device hardware as well as behavior data.
  • a compatibility information source in a software module that is configured to communicate hardware requirements for the software module.
  • a method of developing software which includes the inclusion of software compatibility information within the software module.
  • An exemplary embodiment relates to a method of providing compatibility between a software module and an electronic device.
  • the method includes providing an electronic device having a processor and a memory, the processor running an operating system.
  • the method also includes providing access to the software module configured to run on the processor of the electronic device. Further, the method includes checking operating system compatibility information, the operating system compatibility information being included in the software module.
  • Another exemplary embodiment relates to a method of developing a software module for an electronic device.
  • the method includes accessing a software development tool kit.
  • the method also includes developing the primary functionality of the software module using the software development tool kit. Further, the method includes configuring compatibility information to be included in the software module. Further still, the method includes compiling the software module into a format executable by the electronic device.
  • Yet another exemplary embodiment relates to an information source configured to be used in a software module for an electronic device.
  • the resource includes a data structure specifying a plurality of fields configured to contain compatibility information.
  • the compatibility information includes at least one of minimum operating system version information, maximum operating system version information, required features information, and supported features information.
  • Yet still another exemplary embodiment relates to a method of providing compatibility between a software module and an electronic device.
  • the method includes providing an electronic device having a processor and a memory, the processor running an operating system.
  • the method also includes providing access to the software module configured to run on the processor of the electronic device.
  • the method includes checking development tools version information. The development tools version information based on the version of development tools used to develop the software module.
  • Yet further still another exemplary embodiment relates to a method of using an electronic device.
  • the method includes providing an electronic device having a processor and memory, the processor running an operating system.
  • the method also includes providing access to the software module configured to run on the processor of the electronic device.
  • the method includes providing access to the software module configured to run on the processor of the electronic device.
  • the method includes selectively enabling an operating system backward compatibility mode based on the operating system compatibility information.
  • FIG. 1 is a block diagram of a handheld computer system in a particular embodiment configured for installation of a software application
  • FIG. 2 is a flow diagram depicting exemplary steps in using a software attribute verification resource in a software application.
  • FIG. 3 is a flow diagram depicting exemplary steps in developing a software module including a compatibility information source.
  • a system 10 including a computer, such as personal computer 12 , a third party software module, add-on application, plug-in, or the like, such as but not limited to software application 15 which may be stored on computer 12 , and a portable electronic device, such as but not limited to handheld computer 14 .
  • Handheld computer 14 may include a synchronization device, such as synchronization cradle 16 which is electronically coupled to computer 12 via a data link, such as a data cable 18 .
  • a user of handheld computer 14 that wants to install software application 15 onto handheld computer 14 , may first store application 15 on computer 12 . The user then initiates a synchronization or transfer of information over data cable 18 to handheld computer 16 during which application 15 is installed on handheld computer 14 .
  • system configurations may be used for the installation of software applications such as, but not limited to the direct coupling of handheld computer 14 to a data storage device, such as but not limited to a flash memory card, a disk drive, a CD-ROM drive, a DVD ROM drive, among others.
  • software applications may be installed over a direct communications network link, a wireless communications link, such as a radio frequency (RF) link or over an optical link, for example.
  • RF radio frequency
  • a flow diagram 20 depicts steps for accommodating software module requirements.
  • a software module is first installed on handheld computer 14 (step 21 ) using any of a variety of methods and systems including, but not limited to those described above.
  • the operating system on handheld device 14 or a user of device 14 then initiates the software module (step 22 ).
  • the compatibility information source in the application is then checked for operating system compatibility (step 23 ). In particular the maximum operating system version compatibility and the minimum operating system version compatibility may be checked. Further, in an exemplary embodiment, different types of operating systems may be checked.
  • the software compatibility information source is checked for other software application attributes (step 24 ).
  • the other software attributes may include a variety of attributes relating to both software and hardware configurations of the handheld device. For example, misbehavior information may be included in the resource.
  • Misbehavior information may include information relating to functions of the software application's behavior that are discouraged but are still allowed because future problems may occur if they are not allowed.
  • Some examples of misbehaviors include, but are not limited to reading or writing directly to the screen, reading or writing to the hardware registers, reading or writing to the system global definitions, reading or writing to the memory or data manager structures, reading or writing to unowned resources or record databases.
  • Another example of a software attribute that may be included in the compatibility information source is a “break me” bit which would indicate that the application behaves in an undesirable manner unless the proper operating system is used. Accordingly, a warning dialog may be displayed when the application is run on an operating system that the application did not know about.
  • misbehavior information in general could be used for a variety of uses including restricting access to certain hardware, globals, or other applications.
  • the operating system could also specify that only applications matching certain criteria could be run.
  • Behavior information may further include, but is not limited to information about an application's behavior which is legal, but the device needs to be aware of or know about. For example, it may be desirable that a device know about or be aware of whether the application uses or accesses wireless data links or accesses or uses networked resources, accesses or uses expansion cards, communicates with other applications, utilizes a preferred screen depth (allowing the system to make the switch to the preferred screen depth automatically), or provides a list of supported screen depths.
  • compatibility resource includes, for example, devices or special hardware that may be required for use by the application, such as but not limited to Bluetooth radio, or bar code scanners, for example. Further, certain device hardware may be required, such as specific processors, memory sizes and speeds, hardware abstraction layer (HAL) implementations and the like.
  • HAL hardware abstraction layer
  • the compatibility resource contained in a first application may be accessible by a second application, such that the second application may use the first application having the compatibility resource and may make the first application look different, hide the first application, or move the first application to a special category when the second application requirements or assumptions were not met.
  • the operating system may be able to enforce such a constraint or enforce other types of constraints.
  • the enforcement of the constraint may be made for security reasons such that a virus could not spread using the network, for example.
  • the compatibility information source could be checked by the installation software or by the operating system and reject (refuse to install) any software modules, for which the device is not compatible.
  • the operating system when launching or installing software modules, may provide an error warning to the user that all application requirements are not met. Further, the operating system may use the information to selectively enable additional “backwards compatibility modes” which would allow older software modules that would otherwise “crash,” or fail to operate properly, to run on current devices. For example, games which were written for black and white devices and draw directly to the screen could be made to run on color devices. If the black and white compatibility was known, the operating system could be used to force the application to draw to a virtual display and then convert such drawing to the color display screen.
  • a data structure defined for a software module may be structured as follows: typedef struct ⁇ // Version 1 fields UInt16 version; // version of structure, should be 1 for now. UInt16 reserved; // Reserved for future use UInt32 minOSVersion; // Minimum required version of PalmOS, UInt32 maxOSVersion; // Latest version of PalmOS the application was designed for UInt32 requireFlags; // Flags for features required by the application UInt32 compatFlags; // Flags for features that the application supports // New fields should be added at the end of the structure, underneath // a new comment specifying the structure & OS versions (as above). ⁇ CompatibilityInfoType;
  • the minOS and maxOS version numbers may be used to provide the minimum operating system version and maximum operating system version numbers with which the application has been thoroughly tested. Further, the minOS and maxOS version numbers may be replaced by the software development kit version used for the development of the software module.
  • the software development kit version is representative of the minOS and maxOS versions and further may be used to assess backward compatibility.
  • the “require flags” may include bits defined in the following manner:
  • the “require flags” are not limited to the above mentioned possibilities but may include a variety of other types of bits including but not limited to bits indicating the need for Bluetooth, wireless hardware, Universal Serial Bus (USB) hardware, specific screen depth, drawing directly to the screen, hardware page flipping, GSM/short message service, specific screen sizes, tilt sensor, and many others including but not limited to those discussed above.
  • step 24 adjustments may be performed or background applications may be run to address the compatibility issues or to flag the compatibility issues to a user by display of a dialog or error message.
  • software modules, applications, add-ons, or plug-ins may be developed by software developers using software development tools.
  • a software developer may, in an exemplary embodiment follow a process, such as process 30 depicted in FIG. 3 to develop a software module or the like.
  • the software developer optionally accesses a set of software module development tools (step 31 ), such as a software development kit (SDK) or the like.
  • SDK software development kit
  • the developer then develops the primary functionality of the application (step 32 ).
  • the developer configures the compatibility data (step 33 ) in a form as exemplified in the discussion above or any of a variety of other forms as described by a device maker, for example.
  • the program is compiled (step 34 ) into a format useable by the device, such as handheld computer 14 .
  • the completed program is installed on an electronic device (step 35 ), such as but not limited to handheld computer 14 .

Abstract

A method and system of providing compatibility between a software application and an electronic device are disclosed. An exemplary method includes providing an electronic device having a processor and a memory, the processor running an operating system. The method also includes providing access to a software application configured to run on the process of the electronic device. Further, the method includes checking operating system compatibility information. The operating system compatibility information is included in the software application.

Description

    CROSS REFERENCE TO RELATED APPLICATIONS
  • This application is a continuation application of application Ser. No. 09/796,031, entitled “VERIFICATION OF SOFTWARE APPLICATON ATTRIBUTES FOR OPTIMAL COMPATIBILITY WITH A SOFTWARE SYSTEM,” filed Feb. 28, 2001, to be issued as U.S. Pat. No. 7,191,439, assigned to the assignee of the present application. The subject matter in the above-identified co-pending and commonly owned applications are incorporated herein by reference.
  • FIELD OF THE INVENTION
  • The present specification relates to compatibility of software add-ons with electronic devices. In particular, the invention relates to a compatibility information source in a software add-on, application, module, or plug-in which contains information relating to the compatibility of the software application with the electronic device on which the add-on, application, module, or plug-in is to run.
  • BACKGROUND OF THE INVENTION
  • Handheld computers as well as other types of electronic devices include the use of an operating system running on an electronic processor. Third party software developers often develop software modules configured to run under the operating system, on the processor and using the electronic device hardware. When a new version of the operating system or a new version or type of device is developed, the software module may make certain assumptions about the operating system or about the characteristics (hardware and/or software) of the device that are no longer applicable under the new operating system and/or device. Provided with such assumptions, the software module is often unable to function or functions in an undesirable manner.
  • Accordingly, there is a need for a compatibility information source or software attribute verification resource that is defined by the operating system and is included in the software module. Further, there is a need for a compatibility information source in software modules, add-ons, applications, or plug-ins which communicate assumptions about the operating system and device hardware as well as behavior data. Further, there is a need for a compatibility information source in a software module that is configured to communicate hardware requirements for the software module. Further still, there is a need for a method of developing software which includes the inclusion of software compatibility information within the software module.
  • The techniques herein below extend to those embodiments which fall within the scope of the appended claims, regardless of whether they accomplish one or more of the above mentioned needs.
  • SUMMARY OF THE INVENTION
  • An exemplary embodiment relates to a method of providing compatibility between a software module and an electronic device. The method includes providing an electronic device having a processor and a memory, the processor running an operating system. The method also includes providing access to the software module configured to run on the processor of the electronic device. Further, the method includes checking operating system compatibility information, the operating system compatibility information being included in the software module.
  • Another exemplary embodiment relates to a method of developing a software module for an electronic device. The method includes accessing a software development tool kit. The method also includes developing the primary functionality of the software module using the software development tool kit. Further, the method includes configuring compatibility information to be included in the software module. Further still, the method includes compiling the software module into a format executable by the electronic device.
  • Yet another exemplary embodiment relates to an information source configured to be used in a software module for an electronic device. The resource includes a data structure specifying a plurality of fields configured to contain compatibility information. The compatibility information includes at least one of minimum operating system version information, maximum operating system version information, required features information, and supported features information.
  • Yet still another exemplary embodiment relates to a method of providing compatibility between a software module and an electronic device. The method includes providing an electronic device having a processor and a memory, the processor running an operating system. The method also includes providing access to the software module configured to run on the processor of the electronic device. Further, the method includes checking development tools version information. The development tools version information based on the version of development tools used to develop the software module.
  • Yet further still another exemplary embodiment relates to a method of using an electronic device. The method includes providing an electronic device having a processor and memory, the processor running an operating system. The method also includes providing access to the software module configured to run on the processor of the electronic device. Further, the method includes providing access to the software module configured to run on the processor of the electronic device. Further still, the method includes selectively enabling an operating system backward compatibility mode based on the operating system compatibility information.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • The invention will become more fully understood from the following detailed description, taken in conjunction with the accompanying drawings, wherein like reference numerals refer to like elements, in which:
  • FIG. 1 is a block diagram of a handheld computer system in a particular embodiment configured for installation of a software application;
  • FIG. 2 is a flow diagram depicting exemplary steps in using a software attribute verification resource in a software application; and
  • FIG. 3 is a flow diagram depicting exemplary steps in developing a software module including a compatibility information source.
  • DETAILED DESCRIPTION OF THE INVENTION
  • Referring to FIG. 1, a system 10 is depicted including a computer, such as personal computer 12, a third party software module, add-on application, plug-in, or the like, such as but not limited to software application 15 which may be stored on computer 12, and a portable electronic device, such as but not limited to handheld computer 14. Handheld computer 14 may include a synchronization device, such as synchronization cradle 16 which is electronically coupled to computer 12 via a data link, such as a data cable 18. In operation a user of handheld computer 14 that wants to install software application 15 onto handheld computer 14, may first store application 15 on computer 12. The user then initiates a synchronization or transfer of information over data cable 18 to handheld computer 16 during which application 15 is installed on handheld computer 14.
  • In alternative embodiments, other system configurations may be used for the installation of software applications such as, but not limited to the direct coupling of handheld computer 14 to a data storage device, such as but not limited to a flash memory card, a disk drive, a CD-ROM drive, a DVD ROM drive, among others. Further, software applications may be installed over a direct communications network link, a wireless communications link, such as a radio frequency (RF) link or over an optical link, for example.
  • Referring now to FIG. 2, a flow diagram 20 depicts steps for accommodating software module requirements. A software module is first installed on handheld computer 14 (step 21) using any of a variety of methods and systems including, but not limited to those described above. The operating system on handheld device 14 or a user of device 14 then initiates the software module (step 22). The compatibility information source in the application is then checked for operating system compatibility (step 23). In particular the maximum operating system version compatibility and the minimum operating system version compatibility may be checked. Further, in an exemplary embodiment, different types of operating systems may be checked.
  • Once the operating system compatibility is determined, the software compatibility information source is checked for other software application attributes (step 24). The other software attributes may include a variety of attributes relating to both software and hardware configurations of the handheld device. For example, misbehavior information may be included in the resource.
  • Misbehavior information may include information relating to functions of the software application's behavior that are discouraged but are still allowed because future problems may occur if they are not allowed. Some examples of misbehaviors include, but are not limited to reading or writing directly to the screen, reading or writing to the hardware registers, reading or writing to the system global definitions, reading or writing to the memory or data manager structures, reading or writing to unowned resources or record databases.
  • Another example of a software attribute that may be included in the compatibility information source is a “break me” bit which would indicate that the application behaves in an undesirable manner unless the proper operating system is used. Accordingly, a warning dialog may be displayed when the application is run on an operating system that the application did not know about.
  • The misbehavior information in general could be used for a variety of uses including restricting access to certain hardware, globals, or other applications. The operating system could also specify that only applications matching certain criteria could be run.
  • In an alternative exemplary embodiment, other types of behavior information may be specified in the compatibility information source for the module. Behavior information may further include, but is not limited to information about an application's behavior which is legal, but the device needs to be aware of or know about. For example, it may be desirable that a device know about or be aware of whether the application uses or accesses wireless data links or accesses or uses networked resources, accesses or uses expansion cards, communicates with other applications, utilizes a preferred screen depth (allowing the system to make the switch to the preferred screen depth automatically), or provides a list of supported screen depths.
  • Other alternative examples of information that may be included in the compatibility resource include, for example, devices or special hardware that may be required for use by the application, such as but not limited to Bluetooth radio, or bar code scanners, for example. Further, certain device hardware may be required, such as specific processors, memory sizes and speeds, hardware abstraction layer (HAL) implementations and the like.
  • Additionally, the compatibility resource contained in a first application may be accessible by a second application, such that the second application may use the first application having the compatibility resource and may make the first application look different, hide the first application, or move the first application to a special category when the second application requirements or assumptions were not met.
  • In a further alternative exemplary embodiment, if an application specifies in the compatibility information source that it should not be accessing any network resources or other such resources, the operating system may be able to enforce such a constraint or enforce other types of constraints. The enforcement of the constraint may be made for security reasons such that a virus could not spread using the network, for example.
  • In yet another exemplary embodiment, when software module is being installed on the device, the compatibility information source could be checked by the installation software or by the operating system and reject (refuse to install) any software modules, for which the device is not compatible.
  • Further still, in another exemplary embodiment, when launching or installing software modules, the operating system may provide an error warning to the user that all application requirements are not met. Further, the operating system may use the information to selectively enable additional “backwards compatibility modes” which would allow older software modules that would otherwise “crash,” or fail to operate properly, to run on current devices. For example, games which were written for black and white devices and draw directly to the screen could be made to run on color devices. If the black and white compatibility was known, the operating system could be used to force the application to draw to a virtual display and then convert such drawing to the color display screen.
  • In an exemplary embodiment, a data structure defined for a software module may be structured as follows:
    typedef struct
    {
    // Version 1 fields
    UInt16 version; // version of structure, should be 1 for now.
    UInt16 reserved; // Reserved for future use
    UInt32 minOSVersion; // Minimum required version of PalmOS,
    UInt32 maxOSVersion; // Latest version of PalmOS the application
    was designed for
    UInt32 requireFlags; // Flags for features required by the
    application
    UInt32 compatFlags; // Flags for features that the application
    supports // New fields should be added at the end of the structure,
    underneath // a new comment specifying the structure & OS versions
    (as above).
    } CompatibilityInfoType;
  • In an exemplary embodiment, the minOS and maxOS version numbers may be used to provide the minimum operating system version and maximum operating system version numbers with which the application has been thoroughly tested. Further, the minOS and maxOS version numbers may be replaced by the software development kit version used for the development of the software module. The software development kit version is representative of the minOS and maxOS versions and further may be used to assess backward compatibility.
  • Also, in an exemplary embodiment, the “require flags” may include bits defined in the following manner:
    • requires MC68328 processor;
    • requires MC68328EZ processor;
    • requires MC68328VZ processor;
    • requires ARM family processor;
    • requires 68K family processor; or
    • requires IrDA.
  • The “require flags” are not limited to the above mentioned possibilities but may include a variety of other types of bits including but not limited to bits indicating the need for Bluetooth, wireless hardware, Universal Serial Bus (USB) hardware, specific screen depth, drawing directly to the screen, hardware page flipping, GSM/short message service, specific screen sizes, tilt sensor, and many others including but not limited to those discussed above.
  • The “compatFlags” mentioned above may be configured to provide for bits defined as follows:
    • warn the user when launching if maxOS requirements are exceeded;
    • do not allow application to be run if maxOS requirements are exceeded;
    • supports NotifyMgr, which prevents receiving system-wide broadcasts which have been replaced by notifications (time changes, e.g.);
    • modifies command bar; and
    • other possibilities.
  • Referring again to FIG. 2, if certain compatibility problems are identified in step 24, adjustments may be performed or background applications may be run to address the compatibility issues or to flag the compatibility issues to a user by display of a dialog or error message.
  • In yet still another exemplary embodiment, software modules, applications, add-ons, or plug-ins may be developed by software developers using software development tools. A software developer may, in an exemplary embodiment follow a process, such as process 30 depicted in FIG. 3 to develop a software module or the like. The software developer optionally accesses a set of software module development tools (step 31), such as a software development kit (SDK) or the like. The developer then develops the primary functionality of the application (step 32). Next, the developer configures the compatibility data (step 33) in a form as exemplified in the discussion above or any of a variety of other forms as described by a device maker, for example. The program is compiled (step 34) into a format useable by the device, such as handheld computer 14. Finally, the completed program is installed on an electronic device (step 35), such as but not limited to handheld computer 14.
  • While the detailed drawings, specific examples and particular formulations given describe exemplary embodiments, they serve the purpose of illustration only. The hardware and software configurations shown and described may differ depending on the chosen performance characteristics and physical characteristics of the computing devices. For example, the type of computing device, data structures, or devices used may differ. The systems and methods shown and described are not limited to the precise details and conditions disclosed. Furthermore, other substitutions, modifications, changes, and omissions may be made in the design, operating conditions, and arrangement of the exemplary embodiments and the steps of the exemplary embodiments without departing from the scope of the invention as expressed in the appended claims.

Claims (29)

1. A method of providing compatibility between a software module and an electronic device, comprising:
providing an electronic device having a processor and a memory, the processor running an operating system;
providing access to the software module configured to run on the processor of the electronic device; and
checking operating system compatibility information, the operating system compatibility information being included in the software module.
2. The method of claim 1, wherein the electronic device is a handheld computer.
3. The method of claim 1, further comprising:
installing the software module on the electronic device.
4. The method of claim 1, further comprising:
performing adjustments based on the operating system compatibility information.
5. The apparatus of claim 1, further comprising:
starting a background application based on the operating system compatibility information.
6. The method of claim 1, further comprising:
checking other software module attribute information the software module attribute information being included in the software module.
7. The method of claim 6, further comprising:
starting a background application based on the software module attribute information.
8. A method of developing a software module for an electronic device, comprising:
accessing a software development tool kit;
developing the primary functionality of the software module using the software development tool kit;
configuring compatibility information to be included in the software module; and
compiling the software module into a format executable by the electronic device.
9. The method of claim 8, wherein the electronic device is a handheld computer.
10. The method of claim 8, wherein the compatibility information includes operating system information.
11. The method of claim 8, wherein the compatibility information includes wireless access information.
12. The method of claim 8, wherein the compatibility information includes display type information.
13. The method of claim 8, wherein the compatibility information includes sound system type information.
14. The method of claim 8, wherein the compatibility information includes processor information.
15. An information source configured to be used in a software module for an electronic device, comprising:
a data structure specifying a plurality of fields configured to contain compatibility information, the compatibility information including at least one of minimum operating system version information, maximum operating system version information, required features information, and supported features information.
16. The information source of claim 15, wherein the electronic device is a handheld computer.
17. The information source of claim 15, wherein the required features information includes a flag relating to the processor type.
18. The information source of claim 15, wherein the required features information includes a flag relating to the display type.
19. The information source of claim 15, wherein the required features information includes wireless access information.
20. The information source of claim 15, wherein the required features information includes screen depth information.
21. The information source of claim 15, wherein the supported features information includes a flag relating to the processor type.
22. The information source of claim 15, wherein the supported features information includes a flag relating to the display type.
23. The information source of claim 15, wherein the supported features information includes wireless access information.
24. The information source of claim 15, wherein the supported features information includes screen depth information.
25. The information source of claim 15, wherein the compatibility information further includes misbehavior information.
26. A method of providing compatibility between a software module and an electronic device, comprising:
providing an electronic device having a processor and a memory, the processor running an operating system;
configured to run on the processor of the electronic device; and
checking development tools version information, the development tools version information based on the version of development tools used to develop the software module.
27. The method of claim 26, further comprising:
determining the compatibility of the software module with the operating system based on the development tools version information.
28. The method of claim 27, further comprising:
enforcing constraints based on the development tools version information.
29. A method of using an electronic device, comprising:
providing an electronic device having a processor and a memory, the processor running an operating system;
providing access to the software module configured to run on the processor of the electronic device;
checking operating system compatibility information; and selectively enabling an operating system backward compatibility mode based on the operating system compatibility information.
US11/685,204 2001-02-28 2007-03-13 Verification of software application attributes for optimal compatibility with a software system Abandoned US20070157176A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US11/685,204 US20070157176A1 (en) 2001-02-28 2007-03-13 Verification of software application attributes for optimal compatibility with a software system

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US09/796,031 US7191439B2 (en) 2001-02-28 2001-02-28 Verification of software application attributes for optimal compatibility with a software system
US11/685,204 US20070157176A1 (en) 2001-02-28 2007-03-13 Verification of software application attributes for optimal compatibility with a software system

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US09/796,031 Continuation US7191439B2 (en) 2001-02-28 2001-02-28 Verification of software application attributes for optimal compatibility with a software system

Publications (1)

Publication Number Publication Date
US20070157176A1 true US20070157176A1 (en) 2007-07-05

Family

ID=25167085

Family Applications (2)

Application Number Title Priority Date Filing Date
US09/796,031 Expired - Fee Related US7191439B2 (en) 2001-02-28 2001-02-28 Verification of software application attributes for optimal compatibility with a software system
US11/685,204 Abandoned US20070157176A1 (en) 2001-02-28 2007-03-13 Verification of software application attributes for optimal compatibility with a software system

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US09/796,031 Expired - Fee Related US7191439B2 (en) 2001-02-28 2001-02-28 Verification of software application attributes for optimal compatibility with a software system

Country Status (1)

Country Link
US (2) US7191439B2 (en)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090183151A1 (en) * 2008-01-15 2009-07-16 Sam Gharabally Obtaining Software for a Handheld Device
CN106959853A (en) * 2017-03-20 2017-07-18 宇龙计算机通信科技(深圳)有限公司 Radio-frequency devices initial method and system
US9841969B2 (en) 2015-09-02 2017-12-12 Google Inc. Software development and distribution platform
US11392351B2 (en) 2015-08-28 2022-07-19 Twitter, Inc. Feature switching kits

Families Citing this family (31)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CA2369228A1 (en) * 2002-01-24 2003-07-24 Alcatel Canada Inc. System and method for managing configurable elements of devices in a network element and a network
US20030167463A1 (en) * 2002-03-01 2003-09-04 Microsft Corporation Custom application-compatibility systems and layers
US20080313282A1 (en) 2002-09-10 2008-12-18 Warila Bruce W User interface, operating system and architecture
US7180531B2 (en) * 2004-02-27 2007-02-20 Microsoft Corporation Method and apparatus for enabling application program compatibility with display devices having improved pixel density
US7680758B2 (en) 2004-09-30 2010-03-16 Citrix Systems, Inc. Method and apparatus for isolating execution of software applications
US8095940B2 (en) 2005-09-19 2012-01-10 Citrix Systems, Inc. Method and system for locating and accessing resources
US7752600B2 (en) 2004-09-30 2010-07-06 Citrix Systems, Inc. Method and apparatus for providing file-type associations to multiple applications
US8171479B2 (en) 2004-09-30 2012-05-01 Citrix Systems, Inc. Method and apparatus for providing an aggregate view of enumerated system resources from various isolation layers
US8117559B2 (en) 2004-09-30 2012-02-14 Citrix Systems, Inc. Method and apparatus for virtualizing window information
US20070083620A1 (en) * 2005-10-07 2007-04-12 Pedersen Bradley J Methods for selecting between a predetermined number of execution methods for an application program
US8131825B2 (en) 2005-10-07 2012-03-06 Citrix Systems, Inc. Method and a system for responding locally to requests for file metadata associated with files stored remotely
US7818756B2 (en) * 2005-10-12 2010-10-19 Microsoft Corporation SKU determination mechanism and API
US7739660B2 (en) * 2006-03-31 2010-06-15 Sap Ag Code management in a distributed software development environment
US7721250B2 (en) * 2006-04-12 2010-05-18 International Business Machines Corporation System and method for interactive and integrated software development process and phases
CA2648528C (en) * 2006-04-21 2016-08-23 Cirba Inc. Method and system for determining compatibility of computer systems
US7865889B1 (en) 2006-09-14 2011-01-04 Crimson Corporation Systems and methods for verifying the compatibility of software with a group of managed nodes
US7802252B2 (en) * 2007-01-09 2010-09-21 International Business Machines Corporation Method and apparatus for selecting the architecture level to which a processor appears to conform
JP2008243007A (en) * 2007-03-28 2008-10-09 Fujitsu Ltd Information processor, information processing method and information processing program
US20080244519A1 (en) * 2007-03-30 2008-10-02 Microsoft Corporation Identifying, Correcting and Displaying Application Website and Device Compatibility Issues
US8171483B2 (en) 2007-10-20 2012-05-01 Citrix Systems, Inc. Method and system for communicating between isolation environments
US8090797B2 (en) 2009-05-02 2012-01-03 Citrix Systems, Inc. Methods and systems for launching applications into existing isolation environments
EP2608017A1 (en) * 2011-12-21 2013-06-26 Siemens Aktiengesellschaft Method for modifying the look and behavior of a web application
US11216854B2 (en) * 2012-04-27 2022-01-04 Blackberry Limited Software distribution accounting
CN104077178A (en) * 2013-03-29 2014-10-01 纬创资通股份有限公司 Management method and electronic device
US9760316B2 (en) * 2015-03-27 2017-09-12 Konica Minolta Laboratory U.S.A., Inc. Method and system for managing software version compatibility amongst devices in a multi-device network environment
US9563446B2 (en) 2015-04-30 2017-02-07 Microsoft Technology Licensing, Llc Binary file generation
US10705830B2 (en) 2017-07-20 2020-07-07 Vmware, Inc. Managing hosts of a pre-configured hyper-converged computing device
US10838776B2 (en) * 2017-07-20 2020-11-17 Vmware, Inc. Provisioning a host of a workload domain of a pre-configured hyper-converged computing device
US10705831B2 (en) 2017-07-20 2020-07-07 Vmware, Inc. Maintaining unallocated hosts of a pre-configured hyper-converged computing device at a baseline operating system version
US11847479B2 (en) * 2018-03-23 2023-12-19 Vmware, Inc. Allocating a host of a pre-configured hyper-converged computing device to a workload domain
CN111427603B (en) * 2020-04-15 2023-07-14 浙江大华技术股份有限公司 Application program upgrading method and device

Citations (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5579509A (en) * 1991-02-08 1996-11-26 International Business Machines Corporation Apparatus and method for verifying compatibility of system components
US5870611A (en) * 1995-04-05 1999-02-09 International Business Machines Corporation Install plan object for network installation of application programs
US6237144B1 (en) * 1998-09-21 2001-05-22 Microsoft Corporation Use of relational databases for software installation
US20010042032A1 (en) * 2000-05-11 2001-11-15 Crawshaw Geoffrey K. System for capturing, processing, tracking and reporting time and expense data
US6334213B1 (en) * 1998-01-20 2001-12-25 Preview Systems Merging of separate executable computer programs to form a single executable computer program
US6397254B1 (en) * 1994-12-12 2002-05-28 Charles J. Northrup Access-method-independent exchange 3
US6487723B1 (en) * 1996-02-14 2002-11-26 Scientific-Atlanta, Inc. Multicast downloading of software and data modules and their compatibility requirements
US6571285B1 (en) * 1999-12-23 2003-05-27 Accenture Llp Providing an integrated service assurance environment for a network
US6658659B2 (en) * 1999-12-16 2003-12-02 Cisco Technology, Inc. Compatible version module loading
US20040031030A1 (en) * 2000-05-20 2004-02-12 Equipe Communications Corporation Signatures for facilitating hot upgrades of modular software components
US6727918B1 (en) * 2000-02-18 2004-04-27 Xsides Corporation Method and system for controlling a complementary user interface on a display surface
US7032213B1 (en) * 1999-09-01 2006-04-18 Microsoft Corporation Fixing incompatible applications using a light debugger
US20060225068A1 (en) * 2000-10-30 2006-10-05 Microsoft Corporation System and method for dynamically verifying the compatibility of a user interface resource
US7406676B2 (en) * 2000-09-18 2008-07-29 Microsoft Corporation Access redirector and entry reflector

Patent Citations (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5579509A (en) * 1991-02-08 1996-11-26 International Business Machines Corporation Apparatus and method for verifying compatibility of system components
US6397254B1 (en) * 1994-12-12 2002-05-28 Charles J. Northrup Access-method-independent exchange 3
US5870611A (en) * 1995-04-05 1999-02-09 International Business Machines Corporation Install plan object for network installation of application programs
US6487723B1 (en) * 1996-02-14 2002-11-26 Scientific-Atlanta, Inc. Multicast downloading of software and data modules and their compatibility requirements
US6334213B1 (en) * 1998-01-20 2001-12-25 Preview Systems Merging of separate executable computer programs to form a single executable computer program
US6237144B1 (en) * 1998-09-21 2001-05-22 Microsoft Corporation Use of relational databases for software installation
US7032213B1 (en) * 1999-09-01 2006-04-18 Microsoft Corporation Fixing incompatible applications using a light debugger
US6658659B2 (en) * 1999-12-16 2003-12-02 Cisco Technology, Inc. Compatible version module loading
US6571285B1 (en) * 1999-12-23 2003-05-27 Accenture Llp Providing an integrated service assurance environment for a network
US6727918B1 (en) * 2000-02-18 2004-04-27 Xsides Corporation Method and system for controlling a complementary user interface on a display surface
US20010042032A1 (en) * 2000-05-11 2001-11-15 Crawshaw Geoffrey K. System for capturing, processing, tracking and reporting time and expense data
US20040031030A1 (en) * 2000-05-20 2004-02-12 Equipe Communications Corporation Signatures for facilitating hot upgrades of modular software components
US7406676B2 (en) * 2000-09-18 2008-07-29 Microsoft Corporation Access redirector and entry reflector
US20060225068A1 (en) * 2000-10-30 2006-10-05 Microsoft Corporation System and method for dynamically verifying the compatibility of a user interface resource
US7673299B2 (en) * 2000-10-30 2010-03-02 Microsoft Corporation System and method for dynamically verifying the compatibility of a user interface resource

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090183151A1 (en) * 2008-01-15 2009-07-16 Sam Gharabally Obtaining Software for a Handheld Device
US11392351B2 (en) 2015-08-28 2022-07-19 Twitter, Inc. Feature switching kits
US9841969B2 (en) 2015-09-02 2017-12-12 Google Inc. Software development and distribution platform
CN106959853A (en) * 2017-03-20 2017-07-18 宇龙计算机通信科技(深圳)有限公司 Radio-frequency devices initial method and system

Also Published As

Publication number Publication date
US7191439B2 (en) 2007-03-13
US20020199180A1 (en) 2002-12-26

Similar Documents

Publication Publication Date Title
US7191439B2 (en) Verification of software application attributes for optimal compatibility with a software system
JP4327363B2 (en) Automatic generation of ACPI source language for peripheral resource configuration
US6167511A (en) Method to reflect BIOS set up changes into ACPI machine language
CN1315042C (en) Method and system for creating and using operation system with optional functions
US7146609B2 (en) Method, system and article of manufacture for a firmware image
US5761448A (en) Physical-to-logical bus mapping scheme for computer systems having multiple PCI bus configuration
KR100671153B1 (en) Method for installing a device driver
US6078402A (en) Accessory based resource offset mechanism for a PCI bus in a printer
US20030217358A1 (en) Method, system, and article of manufacture for firmware downloads
US20050162678A1 (en) Information processing apparatus on which printer driver can be installed, information processing apparatus, control method, program, and storage medium
JP2003345618A (en) Method of switching between tow or more images of firmware
US9116770B2 (en) Recipe-based application conversion
US8185888B2 (en) Software execution with minimal impact deployment
KR20060063642A (en) Enabling inter-subsystem resource sharing
EP2372565A1 (en) Method for managing USB devices
CN113064610A (en) Method, device and medium for updating BIOS
US8074205B2 (en) Binary verification service
US7124226B2 (en) Method or apparatus for establishing a plug and play (PnP) communication channel via an abstraction layer interface
US7228263B2 (en) Method for representing root busses using object oriented abstractions
US20040153580A1 (en) Component based operation system dynamic device drive method
US7406549B2 (en) Support for non-standard device containing operating system data
CN113377458B (en) Plug-in management method and device, electronic equipment and storage medium
US20070118658A1 (en) User selectable management alert format
US20070159879A1 (en) Method and system for probing FCode in problem state memory
US20040255292A1 (en) Delivering multiple installation images and computer-readable installation keys on installation media

Legal Events

Date Code Title Description
AS Assignment

Owner name: PALMSOURCE, INC., CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:DONALDSON, JESSE;LEMKE, STEVEN C.;FLORES, ROGER;AND OTHERS;REEL/FRAME:018997/0749;SIGNING DATES FROM 20010226 TO 20010228

STCB Information on status: application discontinuation

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