1. Technical Field
Embodiments of the present disclosure generally relate to serial port management, and more particularly to a system and method for switching use of a serial port.
2. Description of Related Art
A serial port of a server can be used by a baseboard management controller (BMC) and a basic input output system (BIOS) of the server. The BMC or the BIOS uses the serial port by switching a multiplexer (MUX) of the server. If the BIOS has not been initialized and the BMC requests to use the serial port, the initialization of the BIOS has to be suspended until the BMC has used the serial port. The suspension of the initialization of the BIOS may degrade stability of the server.
The application is illustrated by way of examples and not by way of limitation in the figures of the accompanying drawings in which like references indicate similar elements. It should be noted that references to “an” or “one” embodiment in this disclosure are not necessarily to the same embodiment, and such references mean at least one.
In general, the word “module”, as used herein, refers to logic embodied in hardware or firmware, or to a collection of software instructions, written in a programming language, such as, Java, C, or assembly. One or more software instructions in the modules may be embedded in firmware, such as EPROM. The modules described herein may be implemented as either software and/or hardware modules and may be stored in any type of non-transitory computer-readable medium or other storage device. Some non-limiting examples of non-transitory computer-readable media include CDs, DVDs, BLU-RAY, flash memory, and hard disk drives.
The switching system 10 controls a voltage level of the GPIO pin 6. For example, if the server 2 is powered on, the voltage level of the GPIO pin 6 is set to a high level by the switching system 10. If the BIOS 5 is being initialized, the voltage level of the GPIO pin 6 is set to a low level by the switching system 10. In some embodiments, the high level may be logic 1, and the low level may be logic 0. After the BIOS 5 has been initialized, the GPIO pin 6 is pulled up back to the high level. If the BMC 1 sends data to the serial port 4, namely the BMC 1 uses the serial port 4, the voltage level of the GPIO pin 6 will be pulled up to the high level.
In an exemplary embodiment, the BMC 1 includes at least one processor 11 and a storage system 12. The switching system 10 may include one or more modules. The one or more modules may comprise computerized code in the form of one or more programs that are stored in the storage system 12. In one embodiment, the storage system 12 may be a cache or a memory, such as an EPROM or a flash, or other suitable storage medium. The computerized code includes instructions that are executed by the at least one processor 11 to provide functions for the one or more modules.
As shown in
If the server 2 is powered on, the setting module 100 sets the voltage level of the GPIO pin 6 to the high level.
The initialization module 101 initializes the BIOS 5, and pulls down the voltage level of the GPIO pin 6 to the low level, and the BIOS 5 uses the serial port 4.
The detection module 102 detects if the BMC 1 requests to use the serial port 4. In one embodiment, the BMC 1 may request to use the serial port 4 by sending a request command to the serial port 4. The request command may be a request to send or receive data using the serial port 4. If the BMC 1 requests to use the serial port 4, the detection module 102 detects if the voltage level of the GPIO pin 6 is high. If the voltage level of the GPIO pin 6 is high, meaning the BIOS is not currently using the serial port 4, the control module 103 controls the BMC 1 to use the serial port 4.
If currently there is no request from the BMC 1 to use the serial port 4, or if the BMC 1 requests to use the serial port 4 and the voltage level of the GPIO PIN 6 is low, meaning the serial port 4 is currently switched for use by the BIOS 5, or if the serial port 4 is currently switched for use by the BMC 1 but the BMC 1 no longer needs the serial port 4, the detection module 102 detects if the initialization of the BIOS 5 has been completed. If initialization of the BIOS 5 has not been completed, the initialization module 101 continues initializing the BIOS 5. If the BIOS 5 has been initialized, the control module 103 pulls up the voltage level of the GPIO pin 6.
In block S30, if the server 2 is powered on, the setting module 100 sets the voltage level of the GPIO pin 6 to the high level.
In block S31, the initialization module 101 initializes the BIOS 5, and pull down the voltage level of the GPIO pin 6 to the low level.
In block S32, the detection module 102 detects if the BMC 1 requests to use the serial port 4. If the BMC 1 requests to use the serial port 4, block S33 is implemented. If the BMC 1 does not requests to use the serial port 4, block S35 is implemented.
In block S33, the detection module 102 detects if the voltage level of the GPIO pin 6 is at the high level. If the voltage level of the GPIO pin 6 is at the high level, block S34 is implemented. If voltage level of the GPIO pin 6 is not at the high level, block S35 is implemented.
In block S34, the control module 103 controls the BMC 1 to use the serial port 4. If the BMC 1 has used the serial port 4, block S35 is implemented.
In block S35, the detection module 102 detects if the BIOS 5 has been initialized. If the BIOS 5 has been initialized, block S36 is implemented. If the BIOS 5 has not been initialized, block S32 is repeated.
In block S36, the control module 103 pulls up the voltage level of the GPIO pin 6 to the high level.
Although certain inventive embodiments of the present disclosure have been specifically described, the present disclosure is not to be construed as being limited thereto. Various changes or modifications may be made to the present disclosure beyond departing from the scope and spirit of the present disclosure.
Number | Date | Country | Kind |
---|---|---|---|
2010 1 0589290 | Dec 2010 | CN | national |
Number | Name | Date | Kind |
---|---|---|---|
20070088988 | Gupta et al. | Apr 2007 | A1 |
20080282075 | Hsu et al. | Nov 2008 | A1 |
20080288764 | Lu | Nov 2008 | A1 |
20090234999 | Huang et al. | Sep 2009 | A1 |
20100017630 | Chen et al. | Jan 2010 | A1 |
20100125752 | Chen et al. | May 2010 | A1 |
20100332707 | Jayakumar | Dec 2010 | A1 |
20110231639 | Chien | Sep 2011 | A1 |
20120005494 | Peng | Jan 2012 | A1 |
20120079260 | Yin et al. | Mar 2012 | A1 |
20120144180 | Tang | Jun 2012 | A1 |
Number | Date | Country |
---|---|---|
101661453 | Apr 2011 | CN |
102147640 | Aug 2011 | CN |
103049282 | Apr 2013 | CN |
Number | Date | Country | |
---|---|---|---|
20120159035 A1 | Jun 2012 | US |