Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 3054
b: refs/heads/master
c: 77cf397
h: refs/heads/master
v: v3
  • Loading branch information
Corey Minyard authored and Linus Torvalds committed Jun 24, 2005
1 parent be9b49a commit 3213398
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 13 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 3b6259432dee81f928c22c48c080d5f6325ed92e
refs/heads/master: 77cf3973f22c7e7158f5e2c3c3d6809125b77e4b
25 changes: 13 additions & 12 deletions trunk/drivers/char/ipmi/ipmi_poweroff.c
Original file line number Diff line number Diff line change
Expand Up @@ -31,12 +31,13 @@
* with this program; if not, write to the Free Software Foundation, Inc.,
* 675 Mass Ave, Cambridge, MA 02139, USA.
*/
#include <asm/semaphore.h>
#include <linux/kdev_t.h>
#include <linux/config.h>
#include <linux/module.h>
#include <linux/moduleparam.h>
#include <linux/proc_fs.h>
#include <linux/string.h>
#include <linux/completion.h>
#include <linux/kdev_t.h>
#include <linux/ipmi.h>
#include <linux/ipmi_smi.h>

Expand Down Expand Up @@ -89,10 +90,10 @@ static struct ipmi_recv_msg halt_recv_msg =

static void receive_handler(struct ipmi_recv_msg *recv_msg, void *handler_data)
{
struct semaphore *sem = recv_msg->user_msg_data;
struct completion *comp = recv_msg->user_msg_data;

if (sem)
up(sem);
if (comp)
complete(comp);
}

static struct ipmi_user_hndl ipmi_poweroff_handler =
Expand All @@ -105,27 +106,27 @@ static int ipmi_request_wait_for_response(ipmi_user_t user,
struct ipmi_addr *addr,
struct kernel_ipmi_msg *send_msg)
{
int rv;
struct semaphore sem;
int rv;
struct completion comp;

sema_init (&sem, 0);
init_completion(&comp);

rv = ipmi_request_supply_msgs(user, addr, 0, send_msg, &sem,
rv = ipmi_request_supply_msgs(user, addr, 0, send_msg, &comp,
&halt_smi_msg, &halt_recv_msg, 0);
if (rv)
return rv;

down (&sem);
wait_for_completion(&comp);

return halt_recv_msg.msg.data[0];
}

/* We are in run-to-completion mode, no semaphore is desired. */
/* We are in run-to-completion mode, no completion is desired. */
static int ipmi_request_in_rc_mode(ipmi_user_t user,
struct ipmi_addr *addr,
struct kernel_ipmi_msg *send_msg)
{
int rv;
int rv;

rv = ipmi_request_supply_msgs(user, addr, 0, send_msg, NULL,
&halt_smi_msg, &halt_recv_msg, 0);
Expand Down

0 comments on commit 3213398

Please sign in to comment.