greybus: svc: clean up CPortFlags handling

Clean up CPortFlags handling and explicitly disable CSD when E2EFC is
enabled (CSD_n is ignored when E2EFC is set).

Note that the bootrom requires E2EFC, CSD, and CSV to all be disabled.

Signed-off-by: Johan Hovold <johan@hovoldconsulting.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@google.com>
This commit is contained in:
Johan Hovold 2016-03-03 13:34:37 +01:00 коммит произвёл Greg Kroah-Hartman
Родитель cb033188d8
Коммит 34145b608d
1 изменённых файлов: 5 добавлений и 12 удалений

Просмотреть файл

@ -291,21 +291,14 @@ int gb_svc_connection_create(struct gb_svc *svc,
request.cport1_id = cpu_to_le16(cport1_id);
request.intf2_id = intf2_id;
request.cport2_id = cpu_to_le16(cport2_id);
/*
* XXX: fix connections paramaters to TC0 and all CPort flags
* for now.
*/
request.tc = 0;
request.tc = 0; /* TC0 */
/*
* We need to skip setting E2EFC and other flags to the connection
* create request, for all cports, on an interface that need to boot
* over unipro, i.e. interfaces required to download firmware.
*/
/* The ES2/ES3 bootrom requires E2EFC, CSD and CSV to be disabled. */
request.flags = CPORT_FLAGS_CSV_N;
if (boot_over_unipro)
request.flags = CPORT_FLAGS_CSV_N | CPORT_FLAGS_CSD_N;
request.flags |= CPORT_FLAGS_CSD_N;
else
request.flags = CPORT_FLAGS_CSV_N | CPORT_FLAGS_E2EFC;
request.flags |= CPORT_FLAGS_CSD_N | CPORT_FLAGS_E2EFC;
return gb_operation_sync(svc->connection, GB_SVC_TYPE_CONN_CREATE,
&request, sizeof(request), NULL, 0);