ec/dell/mec5035: Add command to control radio state
This was determined by sniffing the LPC bus while moving the hardware wireless switch between the enabled and disabled positions on the Latitude E6400. The vendor BIOS provides options to change which radios the switch controls, which was used to determine the mapping between each radio device and the command argument values. Change-Id: I173dc197d63cda232dd7ede0cb798ab0a364482b Signed-off-by: Nicholas Chin <nic.c3.14@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/77534 Reviewed-by: Felix Held <felix-coreboot@felixheld.de> Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Paul Menzel <paulepanter@mailbox.org>
This commit is contained in:
parent
5991754451
commit
2f48eaf36f
|
@ -84,6 +84,15 @@ u8 mec5035_mouse_touchpad(u8 setting)
|
|||
return buf[0];
|
||||
}
|
||||
|
||||
void mec5035_control_radio(enum ec_radio_dev dev, enum ec_radio_state state)
|
||||
{
|
||||
/* From LPC traces and userspace testing with other values,
|
||||
the second byte has to be 2 for an unknown reason. */
|
||||
u8 buf[RADIO_CTRL_NUM_ARGS] = {(u8)dev, 2, (u8)state};
|
||||
write_mailbox_regs(buf, 2, RADIO_CTRL_NUM_ARGS);
|
||||
ec_command(CMD_RADIO_CTRL);
|
||||
}
|
||||
|
||||
void mec5035_early_init(void)
|
||||
{
|
||||
/* If this isn't sent the EC shuts down the system after about 15
|
||||
|
|
|
@ -16,8 +16,22 @@
|
|||
|
||||
#define CMD_CPU_OK 0xc2
|
||||
|
||||
#define CMD_RADIO_CTRL 0x2b
|
||||
#define RADIO_CTRL_NUM_ARGS 3
|
||||
enum ec_radio_dev {
|
||||
RADIO_WLAN = 0,
|
||||
RADIO_WWAN,
|
||||
RADIO_BT
|
||||
};
|
||||
|
||||
enum ec_radio_state {
|
||||
RADIO_OFF = 0,
|
||||
RADIO_ON
|
||||
};
|
||||
|
||||
u8 mec5035_mouse_touchpad(u8 setting);
|
||||
void mec5035_cpu_ok(void);
|
||||
void mec5035_early_init(void);
|
||||
void mec5035_control_radio(enum ec_radio_dev device, enum ec_radio_state state);
|
||||
|
||||
#endif /* _EC_DELL_MEC5035_H_ */
|
||||
|
|
Loading…
Reference in New Issue