blob: d674ad60007cf3de50759f236db2c30f656dcb6f [file] [log] [blame]
David Hendricksa9151312013-07-01 12:21:01 -07001/*
2 * This file is part of the flashrom project.
3 *
4 * Copyright 2013 Google Inc.
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
19 */
20
David Hendricksb907de32014-08-11 16:47:09 -070021#ifndef __CROS_EC_H_
22#define __CROS_EC_H_
David Hendricksa9151312013-07-01 12:21:01 -070023
24/* FIXME: We should be able to forward declare enum ec_current_image here
David Hendricksb907de32014-08-11 16:47:09 -070025 * instead of including cros_ec_ec_commands.h */
David Hendricksa5c5cf82014-08-11 16:40:17 -070026#include "cros_ec_commands.h"
Puthikorn Voravootivatc0993cf2014-08-28 16:04:58 -070027#include "programmer.h"
David Hendricksa9151312013-07-01 12:21:01 -070028
David Hendricksb907de32014-08-11 16:47:09 -070029struct cros_ec_priv {
David Hendricksa9151312013-07-01 12:21:01 -070030 int detected;
Simon Glass01c11672013-07-01 18:03:33 +090031 enum ec_current_image current_image;
Simon Glassc453a642013-07-01 18:08:53 +090032 struct ec_response_flash_region_info *region;
David Hendricksa9151312013-07-01 12:21:01 -070033 int (*ec_command)(int command, int ver, const void *indata, int insize,
34 void *outdata, int outsize);
David Hendricks14935fe2014-08-14 17:38:24 -070035
36 /*
Gwendal Grignou94e87d62014-11-25 15:34:15 -080037 * Latest kernel supports handling of several ECs in the system.
38 * To use that feature, the proper device file should be used:
39 * The format is /dev/cros_XX, where XX is the type of device:
40 * - ec: the main EC
41 * - pd: the Power Delivery EC
42 * - sh: the Sensor Hub EC.
David Hendricks14935fe2014-08-14 17:38:24 -070043 */
Gwendal Grignou94e87d62014-11-25 15:34:15 -080044 const char* dev;
David Hendricksfbd5e6d2014-08-21 15:01:43 -070045
46 /*
47 * Some CrOS ECs support page write mode for their flash memory. This
48 * represents the ideal size of a data payload to write to flash.
49 */
50 unsigned int ideal_write_size;
Duncan Laurie84328722014-09-10 23:25:01 -070051
52 /*
53 * Allow block size to be overwritten in case the EC is incorrect.
54 */
55 unsigned int erase_block_size;
David Hendricksa9151312013-07-01 12:21:01 -070056};
57
David Hendricksb907de32014-08-11 16:47:09 -070058int cros_ec_test(struct cros_ec_priv *priv);
Puthikorn Voravootivatc0993cf2014-08-28 16:04:58 -070059void cros_ec_set_max_size(struct cros_ec_priv *priv,
60 struct opaque_programmer *op);
David Hendricks14935fe2014-08-14 17:38:24 -070061int cros_ec_parse_param(struct cros_ec_priv *priv);
David Hendricksb907de32014-08-11 16:47:09 -070062int cros_ec_probe_size(struct flashchip *flash);
63int cros_ec_block_erase(struct flashchip *flash,
David Hendricksa9151312013-07-01 12:21:01 -070064 unsigned int blockaddr, unsigned int len);
David Hendricksb907de32014-08-11 16:47:09 -070065int cros_ec_read(struct flashchip *flash, uint8_t *readarr,
David Hendricksa9151312013-07-01 12:21:01 -070066 unsigned int blockaddr, unsigned int readcnt);
David Hendricksb907de32014-08-11 16:47:09 -070067int cros_ec_write(struct flashchip *flash, uint8_t *buf, unsigned int addr,
David Hendricksa9151312013-07-01 12:21:01 -070068 unsigned int nbytes);
69
David Hendricksb907de32014-08-11 16:47:09 -070070#endif /* __CROS_EC_H_ */