The present invention relates generally to the field of welding systems, and more particularly to techniques for updating embedded microcontrollers on printed circuit boards used in such systems.
Welding system component boards generally include programmed control circuitry, such as an embedded microcontroller and memory, operating based on a set of embedded software instructions stored in the memory. The embedded software instructions are commonly referred to as firmware. Often, during a welding system product life cycle, subsequent firmware revisions and updates are released in order to fix software bugs in prior versions of the firmware, or to improve, introduce or enable new features for the welding system. Firmware updates and revisions may be installed as part of routine equipment maintenance and service, or when existing firmware is found to be defective. Firmware updates may also be performed in the event that a welding system becomes inoperable.
Unfortunately, existing techniques for firmware updates are time consuming, difficult/complex, and/or costly. For example, one technique for updating the firmware on component boards is by downloading the firmware updates from an internet website onto a computer or a handheld programming device, and subsequently loading the downloaded firmware updates onto the appropriate component boards via a programming cable or interface. This technique, however, is not without drawbacks. Computers and handheld programming devices are relatively expensive and require technical knowledge in order to operate effectively. As such, customers may not have the means for purchasing a computer or handheld programming device nor the knowledge to operate one with proficiency. Improperly updating firmware may result in damage not only to the component board, but also to other components of the welding system.
Moreover, to ensure proper compatibility when performing firmware updates, operating systems installed on computers and handheld programming devices may require the welding system component board to run a particular operating system, for example, Microsoft Windows CE®, sold by Microsoft Corporation. This increases the system complexity and adds to the cost of manufacturing the component boards. Furthermore, handheld programming devices may have their own component boards requiring periodic firmware updates. Often times, a handheld programming device running an outdated firmware version will interface correctly with a welding system component board prior to a firmware update, but then the firmware update renders the handheld programming device inoperable with the particular component board. Additionally, this technique requires manufacturers to create and support an internet website accessible by customers for downloading firmware revisions and updates to computers and handheld programming devices. As such, the aforementioned factors unnecessarily increase the overall production cost of welding systems.
Another technique for updating the firmware involves replacement of the entire component board. Upon receipt of a replacement component board having preinstalled firmware updates, the customer would remove the outdated component board from the welding system and then install the new updated component board. Unfortunately, customers may not have the technical knowledge to properly remove and install the component boards, and improper installation may damage the component board or possibly damage the welding system, both of which may be costly to replace or repair.
Embodiments of the present invention provide a low cost system and method for updating torch systems, such as welding and plasma cutting systems. In accordance with embodiments of the present invention, the torch system includes an interface for receiving a removable memory device which may contain updated software code, such as software, device drivers, or firmware, just to name a few. Upon mating the removable memory device to the interface, the updated software code may be installed onto one or more components of the torch system.
Embodiments of the present invention may reduce the cost and labor associated with conventional torch system updating systems and methods, which may include maintaining and supporting an internet website to facilitate downloading of software updates and/or sending new preinstalled updated component boards directly to customers. Moreover, inserting a memory card is a relatively simple task and does not require a customer to have the technical expertise that may be necessary for installing a replacement component board or loading firmware updates to a welding system from a computer or handheld programming device.
These and other features, aspects, and advantages of the present invention will become better understood when the following detailed description is read with reference to the accompanying drawings in which like characters represent like parts throughout the drawings, wherein:
Turning now to the drawings and referring first to
In the illustrated embodiment, the torch system 10 is a welding system, but other embodiments may include a cutting system, such as a plasma cutting system. In other words, any welding, cutting, or like torch system may be employed within the scope of the disclosed embodiments. Similarly, the present technique may also be applied to other industrial systems, such as induction heating systems. The following discussion refers to the system 10 as a welding system 10 as an example without limitation. Furthermore, the following discussion merely relates to exemplary embodiments of the system 10, interface 38, device 40, and so forth. As such, the appended claims should not be viewed as limited to the embodiments described herein.
The illustrated welding system 10 includes a base unit 12 operably coupled with a welding torch 14 via a conduit 15. The system also includes an electrode 16 (e.g., welding wire) fed through the conduit 15 to the torch 14, and a work cable 17 having a work clamp 18 coupled to a work piece 20. Placement of the welding torch 14 proximate to work piece 20 allows electrical current, supplied by power supply 24, to form an arc 22 from electrode 16 to the work piece 20. The arc 22 completes an electrical circuit from power supply 24 to electrode 16, to the work piece 20, then back to the welding system 10 via work clamp 18 and work cable 17. The heat produced by arc 22 causes the electrode 16 and/or work piece 20 to transition to a molten state, thereby creating the weld.
The system 10 also includes a wire feeder 26, a gas supply 28, and an electrode supply 30 (e.g., coil of welding wire). Base unit 12 supplies welding torch 14 with voltage and current from power supply 24, electrode 16 from electrode supply 30 via wire feeder 26, and shielding gas from gas supply 28 through conduit 15. The electrode 16 may be any suitable type of traditional consumable electrode. Also, in alternate embodiments, the electrode 16 may include a non-consumable electrode without the wire feeder 26 or electrode supply 30. Shielding gas from gas supply 28 shields the weld area from contaminants during welding in order to enhance arc performance and to improve the quality of the resulting weld.
In addition, the system 10 includes a controller or slave board 32, an operator interface board 34 coupled to the board 32, and an operator interface coupled to board 34. An operator may manipulate welding parameters via the operator interface 36 in order to precisely control the deposition of molten material from electrode 16 onto work piece 20. Where operator inputs are used, these may be provided by digital devices, analog circuits (i.e., dials with associated potentiometers), and so forth. The processed operator inputs are communicated to slave board 32. Slave board 32 is operably coupled to and is configured to control the power supply 24, wire feeder 26, and gas supply 28 based on the operator inputs received. For example, slave board 32 may be configured to adjust the power output from power supply 24 based on operator inputs while monitoring supply voltage and current with voltage sensor 44 and current sensor 46. Slave board 32 may also be configured to regulate the advancement of electrode 16 via wire feeder 26, as well as the shielding gas output from gas supply 28 based on the operator inputs.
Operator interface board 34 and slave controller board 32 may include any suitable control circuitry and may be based upon a general purpose or application-specific microprocessor or microcontroller or other programmed control circuitry. Although not represented in
Removable memory interface 38 is operably coupled to operator interface board 34 and is configured to transmit data from removable memory device 40 to one or more component boards of the welding system 10. As illustrated in
As discussed above, embodiments of the present invention provide a simple low cost solution for updating torch systems, such as the presently illustrated welding system 10. Accordingly, embodiments of the removable memory device 40 may include any one of available low cost and/or portable memory devices, as will be discussed in further detail below. That is, embodiments of the removable memory device 40 are simply a memory/storage device containing updated software code (e.g., firmware) without a handheld device, processor, or other electronic components. Therefore, the updating of the welding system 10 via the removable memory interface 38 and the removable memory device 40 not only eliminates the need for downloading updates onto handheld programming devices or replacing components, but also further eliminates potential software version conflicts between the welding system 10 and conventional handheld programming devices.
Removable memory device 40 stores both updated firmware code 60 to replace outdated or defective firmware code 70 stored in memory 68 on operator interface board 34, as well as a set of execution instructions 62 for loading, updating, or overwriting the outdated or defective firmware 70. That is, the removable memory device 40 consists essentially of memory and an update stored thereon. Moreover, in contrast to conventional handheld programming devices, embodiments of the removable memory device 40 generally exclude a display, a processor, a battery, a network connection, or the like. In other words, embodiments of the removable memory device 40 may simply be low cost, portable memory devices containing the appropriate update 60 and/or execution instructions 62. In one embodiment, the removable memory device 40 may have a form factor of less than 10 cubic inches. For example, the removable memory device 40 may include a portable external hard disk drive. In another embodiment, the removable memory device 40 may have a form factor of less than 3 cubic inches. For example, the removable memory device 40 may include a universal serial bus (“USB”) drive, a data-flash card, a multimedia card, a Secure Digital card, a Compact Flash card, a Micro Secure Digital card, a Mini Secure Digital card, a Smart Media card, a Memory Stick Pro Duo card, or any other type of portable compact memory.
For purposes of clarity and explanation, removable memory interface 38 is illustrated by a single input arrow and a single output arrow between removable memory device 40 and operator interface component board 34. However, a number of interfaces may be used for interfacing removable memory device 40 to a component board. That is, removable memory interface 38 may include any type of suitable interface, including a USB interface, a serial advanced technology attachment (SATA) interface, a IEEE 1394 (FireWire) interface, a serial peripheral interface (SPI), a universal synchronous and asynchronous interface (USART), a controller area network (CAN), as well as any other interface supporting the above discussed removable memories, just to name a few.
As discussed above, operator interface component board 34 may be based upon programmed control circuitry, such as a microcontroller, represented generally by processor 64, input/output circuitry 66, and memory 68. The operator interface component board 34 receives operator inputs from operator interface 36 via input/output circuitry 66, operating based on firmware code 70 stored in memory 68.
The execution instructions 62 stored on removable memory device 40 may be performed by processor 64 and may be initiated by a user (e.g., via operator interface 36) upon inserting removable memory device 40 into removable memory interface 38 while welding system 10 is powered. The execution instructions 62 may initiate loading of the updated firmware code 60 to memory 68 of operator interface component board 34. For example, the execution instructions 62 may be configured to send the updated firmware code 60 to the operator interface component board 34 via removable memory interface 38 and store the updated firmware code 60 to an address in memory 68. In one embodiment, the current firmware code 70 may be overwritten by the updated firmware code 60.
In certain embodiments, the execution instructions 62 may be further configured to first determine whether or not a component board 34 may require a firmware update before initiating the update procedures. Alternatively, the component board 34 may include decision logic configured to compare the firmware 60 (e.g., version check) on the removable memory device 40 to the firmware 70 currently stored in component board memory 68 to determine if a firmware update is desirable. After the update is complete, the operator interface component board 34 operates based on the updated firmware code 60. In some embodiments, removable memory device 40 may include only the updated firmware code 60, and not include execution instructions 62. Such embodiments may passively rely on instructions stored on the recipient system (e.g., welding system 10) or on one or more component boards (e.g., boards 32 and 34) to perform all the necessary execution and processing steps to install the updated firmware code stored on removable memory device 10 into the welding system 10. Certain embodiments may also utilize plug-and-play technologies, such that the updated firmware code 60 may be automatically installed by the system 10 upon detecting the insertion of removable memory device 40 into removable memory interface 38. Further, certain embodiments may provide the user with verification that an update has been successfully installed (e.g., via the operator interface 36).
In certain embodiments, security features may be implemented so that the removable memory device 40 will permit only a one time update and/or limit updating to only authorized welding systems. For example, when execution instructions 62 are executed, a bit may be set in removable memory device 40 to prevent the execution instructions 62 from being re-executed subsequently on another welding system. Alternatively, the execution instructions 62 may be protected by a unique password or personal identification number (PIN) which must be entered by a user, such as via a keypad on operator interface 36, prior to allowing execution and updating. Furthermore, the execution instructions 62 may be configured to check and compare a welding system's serial number with a list of authorized serial numbers to verify that the welding system is authenticated to receive the updated firmware code 60. In another embodiment, authentication may be provided by one or more security keys. For example, the system 10 may include a unique or shared key, whereas the removable memory device 40 includes a key that permits removable memory device 40 to work only with a system 10 having an authorized key. Further, some embodiments may include a combination of the above described security features for providing additional levels of security.
In
Removable memory device 40, as shown in
The installation process 130 may be initiated once an operator, having received the removable memory device, inserts the removable memory device into the removable memory interface, as shown at block 132. At block 134, execution instructions stored on the removable memory device may be executed by a processor on one or more welding system component boards to initiate loading of the updated firmware code into the memory of the one or more component boards. As discussed above, the execution code may also initiate security checks, such as authenticating the receiving system prior to updating the firmware. At block 136, the updated firmware code may be loaded from the removable memory device into memory on one or more target component boards in the welding system 10. The current firmware stored in the component board memory may be overwritten by the updated firmware. Once the update is complete, an operator may remove the memory device from the interface, ending the installation process 130 at block 138. The welding system and its various component boards may now operate based on the newly installed firmware, as shown by block 140.
While only certain features of the invention have been illustrated and described herein, many modifications and changes will occur to those skilled in the art. It is, therefore, to be understood that the appended claims are intended to cover all such modifications and changes as fall within the true spirit of the invention.