blob: 5470e45cf83ed4865469f0fff3f07b4074756e54 [file] [log] [blame]
Andrew Jeffery68023072018-08-06 10:08:11 +09301// SPDX-License-Identifier: Apache-2.0
2// Copyright (C) 2018 IBM Corp.
3#include <errno.h>
4#include <stdlib.h>
5
Andrew Jeffery26558db2018-08-10 00:22:38 +09306#include "common.h"
Andrew Jeffery68023072018-08-06 10:08:11 +09307#include "dbus.h"
Andrew Jeffery26558db2018-08-10 00:22:38 +09308#include "mboxd.h"
Andrew Jefferyeebc6bd2018-08-08 10:38:19 +09309#include "flash.h"
Andrew Jefferycd186112018-08-08 10:47:55 +093010#include "lpc.h"
Andrew Jeffery457a6e52018-08-08 11:21:08 +093011#include "transport_mbox.h"
Andrew Jefferyf593b1b2018-08-08 11:01:04 +093012#include "windows.h"
Andrew Jeffery68023072018-08-06 10:08:11 +093013
14int control_ping(struct mbox_context *context)
15{
16 return 0;
17}
18
19int control_daemon_state(struct mbox_context *context)
20{
21 return (context->state & STATE_SUSPENDED) ?
22 DAEMON_STATE_SUSPENDED : DAEMON_STATE_ACTIVE;
23}
24
25int control_lpc_state(struct mbox_context *context)
26{
27 if ((context->state & MAPS_MEM) && !(context->state & MAPS_FLASH)) {
28 return LPC_STATE_MEM;
29 } else if (!(context->state & MAPS_MEM) &&
30 (context->state & MAPS_FLASH)) {
31 return LPC_STATE_FLASH;
32 }
33
34 return LPC_STATE_INVALID;
35}
36
37int control_reset(struct mbox_context *context)
38{
39 int rc;
40
41 /* We don't let the host access flash if the daemon is suspened */
42 if (context->state & STATE_SUSPENDED) {
43 return -EBUSY;
44 }
45
46 /*
47 * This will close (and flush) the current window and reset the lpc bus
48 * mapping back to flash, or memory in case we're using a virtual pnor.
49 * Better set the bmc event to notify the host of this.
50 */
Andrew Jeffery5335f092018-08-09 14:56:08 +093051 windows_reset_all(context, EVENT_TRIGGER);
Andrew Jeffery17971e42018-08-08 16:36:10 +093052 rc = lpc_reset(context);
Andrew Jeffery68023072018-08-06 10:08:11 +093053 if (rc < 0) {
54 return rc;
55 }
56
57 return 0;
58}
59
60int control_kill(struct mbox_context *context)
61{
62 context->terminate = 1;
63
64 MSG_INFO("DBUS Kill - Exiting...\n");
65
66 return 0;
67}
68
69int control_modified(struct mbox_context *context)
70{
71 /* Flash has been modified - can no longer trust our erased bytemap */
Andrew Jefferyf953f792018-08-08 16:56:03 +093072 flash_set_bytemap(context, 0, context->flash_size, FLASH_DIRTY);
Andrew Jeffery68023072018-08-06 10:08:11 +093073
74 /* Force daemon to reload all windows -> Set BMC event to notify host */
Andrew Jeffery5335f092018-08-09 14:56:08 +093075 windows_reset_all(context, EVENT_TRIGGER);
Andrew Jeffery68023072018-08-06 10:08:11 +093076
77 return 0;
78}
79
80int control_suspend(struct mbox_context *context)
81{
82 int rc;
83
84 if (context->state & STATE_SUSPENDED) {
85 /* Already Suspended */
Andrew Jefferyef9e62d2018-08-08 15:48:27 +093086 return 0;
Andrew Jeffery68023072018-08-06 10:08:11 +093087 }
88
89 /* Nothing to check - Just set the bit to notify the host */
Andrew Jeffery5335f092018-08-09 14:56:08 +093090 rc = protocol_events_set(context, BMC_EVENT_FLASH_CTRL_LOST, EVENT_TRIGGER);
Andrew Jeffery68023072018-08-06 10:08:11 +093091 if (rc < 0) {
92 return rc;
93 }
94
95 context->state |= STATE_SUSPENDED;
96
97 return rc;
98}
99
100int control_resume(struct mbox_context *context, bool modified)
101{
102 int rc;
103
104 if (!(context->state & STATE_SUSPENDED)) {
105 /* We weren't suspended... */
Andrew Jefferyef9e62d2018-08-08 15:48:27 +0930106 return 0;
Andrew Jeffery68023072018-08-06 10:08:11 +0930107 }
108
109 if (modified) {
110 /* Call the flash modified handler */
111 control_modified(context);
112 }
113
114 /* Clear the bit and send the BMC Event to the host */
Andrew Jeffery5335f092018-08-09 14:56:08 +0930115 rc = protocol_events_clear(context, BMC_EVENT_FLASH_CTRL_LOST, EVENT_TRIGGER);
Andrew Jeffery68023072018-08-06 10:08:11 +0930116 if (rc < 0) {
Andrew Jefferyef9e62d2018-08-08 15:48:27 +0930117 return rc;
Andrew Jeffery68023072018-08-06 10:08:11 +0930118 }
119 context->state &= ~STATE_SUSPENDED;
120
121 return rc;
122}