From mboxrd@z Thu Jan 1 00:00:00 1970 From: Wei Chen Subject: Re: [PATCH 4/7] xen/arm: SMMU: Detect types of device tree binding Date: Thu, 6 Jul 2017 02:25:53 +0000 Message-ID: References: <1498792511-25149-1-git-send-email-Wei.Chen@arm.com> <1498792511-25149-5-git-send-email-Wei.Chen@arm.com> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Return-path: In-Reply-To: Content-Language: en-US List-Unsubscribe: , List-Post: List-Help: List-Subscribe: , Errors-To: xen-devel-bounces@lists.xen.org Sender: "Xen-devel" To: Stefano Stabellini Cc: Kaly Xin , Julien Grall , nd , "xen-devel@lists.xen.org" , Steve Capper List-Id: xen-devel@lists.xenproject.org DQoNCj4gLS0tLS1PcmlnaW5hbCBNZXNzYWdlLS0tLS0NCj4gRnJvbTogU3RlZmFubyBTdGFiZWxs aW5pIFttYWlsdG86c3N0YWJlbGxpbmlAa2VybmVsLm9yZ10NCj4gU2VudDogMjAxN+W5tDfmnIg2 5pelIDI6MDgNCj4gVG86IFdlaSBDaGVuIDxXZWkuQ2hlbkBhcm0uY29tPg0KPiBDYzogU3RlZmFu byBTdGFiZWxsaW5pIDxzc3RhYmVsbGluaUBrZXJuZWwub3JnPjsgS2FseSBYaW4gPEthbHkuWGlu QGFybS5jb20+Ow0KPiBKdWxpZW4gR3JhbGwgPEp1bGllbi5HcmFsbEBhcm0uY29tPjsgU3RldmUg Q2FwcGVyIDxTdGV2ZS5DYXBwZXJAYXJtLmNvbT47IG5kDQo+IDxuZEBhcm0uY29tPjsgeGVuLWRl dmVsQGxpc3RzLnhlbi5vcmcNCj4gU3ViamVjdDogUmU6IFtYZW4tZGV2ZWxdIFtQQVRDSCA0Lzdd IHhlbi9hcm06IFNNTVU6IERldGVjdCB0eXBlcyBvZiBkZXZpY2UNCj4gdHJlZSBiaW5kaW5nDQo+ IA0KPiBPbiBUdWUsIDQgSnVsIDIwMTcsIFdlaSBDaGVuIHdyb3RlOg0KPiA+IEhpIFN0ZWZhbm8s DQo+ID4NCj4gPiA+IC0tLS0tT3JpZ2luYWwgTWVzc2FnZS0tLS0tDQo+ID4gPiBGcm9tOiBTdGVm YW5vIFN0YWJlbGxpbmkgW21haWx0bzpzc3RhYmVsbGluaUBrZXJuZWwub3JnXQ0KPiA+ID4gU2Vu dDogMjAxN+W5tDfmnIg05pelIDY6MzANCj4gPiA+IFRvOiBXZWkgQ2hlbiA8V2VpLkNoZW5AYXJt LmNvbT4NCj4gPiA+IENjOiB4ZW4tZGV2ZWxAbGlzdHMueGVuLm9yZzsgc3N0YWJlbGxpbmlAa2Vy bmVsLm9yZzsgU3RldmUgQ2FwcGVyDQo+ID4gPiA8U3RldmUuQ2FwcGVyQGFybS5jb20+OyBLYWx5 IFhpbiA8S2FseS5YaW5AYXJtLmNvbT47IEp1bGllbiBHcmFsbA0KPiA+ID4gPEp1bGllbi5HcmFs bEBhcm0uY29tPjsgbmQgPG5kQGFybS5jb20+DQo+ID4gPiBTdWJqZWN0OiBSZTogW1hlbi1kZXZl bF0gW1BBVENIIDQvN10geGVuL2FybTogU01NVTogRGV0ZWN0IHR5cGVzIG9mIGRldmljZQ0KPiA+ ID4gdHJlZSBiaW5kaW5nDQo+ID4gPg0KPiA+ID4gT24gRnJpLCAzMCBKdW4gMjAxNywgV2VpIENo ZW4gd3JvdGU6DQo+ID4gPiA+IFRoZSBkZXZpY2UgdHJlZSBwcm92aWRlcyB0d28gdHlwZXMgb2Yg SU9NTVUgYmluZGluZ3MsIG9uZSBpcyBsZWdhY3kNCj4gPiA+ID4gYW5vdGhlciBpcyBnZW5lcmlj LiBUaGUgbGVnYWN5IGJpbmRpbmdzIHdpbGwgYmUgZGVwZXJjYXRlZCBpbiBmYXZvdXINCj4gPiA+ ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXiBkZXBy ZWNhdGVkDQo+ID4gPg0KPiA+ID4gPiBvZiB0aGUgZ2VuZXJpYyBiaW5kaW5ncy4gQnV0IGluIHRo ZSB0cmFuc2l0aW9uYWwgcGVyaW9kLCB3ZSBoYXZlIHRvDQo+ID4gPiA+IHN1cHBvcnQgYm90aCBv ZiB0aGVtLg0KPiA+ID4gPg0KPiA+ID4gPiBUaGUgY29kZXMgdG8gaGFuZGxlIHRoZXNlIHR3byB0 eXBlcyBvZiBiaW5kaW5ncyBhcmUgdmVyeSBkaWZmZXJuZXQsDQo+ID4gPiAgICAgICBeIGNvZGUg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIF4gZGlmZmVyZW50 DQo+ID4gPg0KPiA+ID4gUGxlYXNlIHVzZSBhIHNwZWxsY2hlY2tlci4NCj4gPg0KPiA+IFRoYW5r cywgSSB3aWxsIGZpeCB0aGVtLg0KPiA+DQo+ID4gPg0KPiA+ID4gPiBzbyB3ZSBoYXZlIHRvIGRl dGVjdCB0aGUgYmluZGluZyB0eXBlcyB3aGlsZSBkb2luZyBTTU1VIHByb2JpbmcuDQo+ID4gPiA+ DQo+ID4gPiA+IFRoaXMgZGV0ZWN0IGNvZGUgaXMgYmFzZWQgb24gTGludXggQVJNIFNNTVV2MiBk cml2ZXI6DQo+ID4gPiA+IGh0dHBzOi8vZ2l0aHViLmNvbS90b3J2YWxkcy9saW51eC9ibG9iL21h c3Rlci9kcml2ZXJzL2lvbW11L2FybS1zbW11LmMNCj4gPiA+ID4NCj4gPiA+ID4gU2lnbmVkLW9m Zi1ieTogV2VpIENoZW4gPFdlaS5DaGVuQGFybS5jb20+DQo+ID4gPiA+IC0tLQ0KPiA+ID4gPiAg eGVuL2RyaXZlcnMvcGFzc3Rocm91Z2gvYXJtL3NtbXUuYyB8IDIzICsrKysrKysrKysrKysrKysr KysrKysrDQo+ID4gPiA+ICAxIGZpbGUgY2hhbmdlZCwgMjMgaW5zZXJ0aW9ucygrKQ0KPiA+ID4g Pg0KPiA+ID4gPiBkaWZmIC0tZ2l0IGEveGVuL2RyaXZlcnMvcGFzc3Rocm91Z2gvYXJtL3NtbXUu Yw0KPiA+ID4gYi94ZW4vZHJpdmVycy9wYXNzdGhyb3VnaC9hcm0vc21tdS5jDQo+ID4gPiA+IGlu ZGV4IDJlZmE1MmQuLjQ0MWMyOTYgMTAwNjQ0DQo+ID4gPiA+IC0tLSBhL3hlbi9kcml2ZXJzL3Bh c3N0aHJvdWdoL2FybS9zbW11LmMNCj4gPiA+ID4gKysrIGIveGVuL2RyaXZlcnMvcGFzc3Rocm91 Z2gvYXJtL3NtbXUuYw0KPiA+ID4gPiBAQCAtMTQzLDYgKzE0Myw4IEBAIHR5cGVkZWYgZW51bSBp cnFyZXR1cm4gaXJxcmV0dXJuX3Q7DQo+ID4gPiA+DQo+ID4gPiA+ICAjZGVmaW5lIGRldl9uYW1l KGRldikgZHRfbm9kZV9mdWxsX25hbWUoZGV2X3RvX2R0KGRldikpDQo+ID4gPiA+DQo+ID4gPiA+ ICsjZGVmaW5lIHByX25vdGljZShmbXQsIC4uLikgcHJpbnRrKFhFTkxPR19JTkZPIGZtdCwgIyMg X19WQV9BUkdTX18pDQo+ID4gPiA+ICsNCj4gPiA+ID4gIC8qIEFsaWFzIHRvIFhlbiBhbGxvY2F0 aW9uIGhlbHBlcnMgKi8NCj4gPiA+ID4gICNkZWZpbmUga2ZyZWUgeGZyZWUNCj4gPiA+ID4gICNk ZWZpbmUga21hbGxvYyhzaXplLCBmbGFncykJCV94bWFsbG9jKHNpemUsIHNpemVvZih2b2lkICop KQ0KPiA+ID4gPiBAQCAtNjgxLDYgKzY4Myw4IEBAIHN0cnVjdCBhcm1fc21tdV9vcHRpb25fcHJv cCB7DQo+ID4gPiA+ICAJY29uc3QgY2hhciAqcHJvcDsNCj4gPiA+ID4gIH07DQo+ID4gPiA+DQo+ ID4gPiA+ICtzdGF0aWMgYm9vbCB1c2luZ19sZWdhY3lfYmluZGluZywgdXNpbmdfZ2VuZXJpY19i aW5kaW5nOw0KPiA+ID4NCj4gPiA+IF9faW5pdGRhdGE/DQo+ID4gPg0KPiA+DQo+ID4gSSB0aGlu ayB0aGVzZSB0d28gdmFyaWFibGVzIGFyZSBub3Qgb25seSB1c2VkIGluIGluaXRpYWxpemF0aW9u LiBUaGV5IGFsc28NCj4gPiBoYXZlIGJlZW4gdXNlZCBpbiBvcHMtPmFkZF9kZXZpY2UuIEFsdGhy b3VnaCB0aGUgYWRkX2RldmljZSBpcyBvbmx5IGJlDQo+ID4gaW52b2tlZCB3aGlsZSBjb25zdHJ1 Y3RfZG9tMC4NCj4gDQo+IEkgZG9uJ3QgdGhpbmsgdGhhdCBhZGRfZGV2aWNlIGlzIHN1cHBvc2Vk IHRvIGJlIGxpbWl0ZWQgYXQgYm9vdC4gSXQncw0KPiBiZXN0IHRvIGF2b2lkIF9faW5pdGRhdGEg dGhlbi4NCj4gDQoNClllcy4gU28gbGV0IGtlZXAgdGhlc2UgdHdvIHZhcmlhYmxlcyB3aXRob3V0 IF9faW5pdGRhdGEgaGVyZS4NCg0KPiANCj4gPiA+IEJ1dCB3aHkgZG8gdGhlc2UgdHdvIHZhcmlh YmxlcyBuZWVkIHRvIGJlIHN0YXRpYz8gQ2FuJ3QgdGhleSBqdXN0IGJlDQo+ID4gPiBsb2NhbCB2 YXJpYWJsZXMgaW4gYXJtX3NtbXVfZGV2aWNlX2R0X3Byb2JlPw0KPiA+ID4NCj4gPiA+IElzIGl0 IHRvIGVuZm9yY2UgdGhhdCBhbGwgc21tdXMgb24gYSBnaXZlbiBwbGF0Zm9ybSBhcmUgZWl0aGVy IHVzaW5nIHRoZQ0KPiA+ID4gbGVnYWN5IG9yIHRoZSBnZW5lcmljIGJpbmRpbmdzLCBidXQgbm90 IGEgbWl4IG9mIHRoZSB0d28/IElmIHNvLCBpdA0KPiA+ID4gc2hvdWxkIGJlIGNsZWFybHkgd3Jp dHRlbi4gQWxzbywgSSBhbSBub3Qgc3VyZSB3ZSBzaG91bGQgcmVhbGx5IGJlDQo+ID4NCj4gPiBZ ZXMsIHRoaXMgY2hlY2tpbmcgd2lsbCBlbmZvcmNlIGFsbCBzbW11cyBhcmUgdXNpbmcgdGhlIHNh bWUgYmluZGluZ3MuDQo+ID4NCj4gPiA+IGNoZWNraW5nIGZvciB0aGF0LiBJdCBzZWVtcyB0byBt ZSB0aGF0IG9uZSBzbW11IGNvdWxkIGJlIHVzaW5nIGdlbmVyaWMNCj4gPiA+IGJpbmRpbmdzIGFu ZCBhbm90aGVyIGNvdWxkIGJlIHVzaW5nIGxlZ2FjeSBiaW5kaW5ncy4gSXMgaXQgc3BlY2lmaWVk DQo+ID4gPiBhbnl3aGVyZSB0aGF0IGl0IGNhbm5vdCBiZSB0aGUgY2FzZT8NCj4gPiA+DQo+ID4N Cj4gPiBJbiB0aGVvcnksIGRpZmZlcmVudCBTTU1VcyBjYW4gdXNlIGRpZmZlcmVudCBiaW5kaW5n cy4gQWJvdXQgdGhpcyBjb25jZXJuLA0KPiA+IEkgaGF2ZSBkaXNjdXNzZWQgd2l0aCBSb2JpbiBN dXJwaHkgYW5kIEp1bGllbi4gV2UgaGF2ZSB0aHJlZSByZWFzb25zOg0KPiA+DQo+ID4gVGhlIGZp cnN0IGlzIHRoYXQsIHdlIHBvcnRlZCB0aGlzIGNoZWNraW5nIGZyb20gTGludXgsIHdlIGFyZSB0 cnlpbmcgdG8ga2VlcA0KPiA+IHRoZSBjb2RlIHZlcnkgY2xvc2UgdG8gdGhlIExpbnV4IGRyaXZl ci4gVG8gZWFzZSBiYWNrcG9ydGluZyBjaGFuZ2VzLg0KPiA+DQo+ID4gVGhlIHNlY29uZCBpcyB0 aGF0LCB3ZSB0aGluayBpdCBpcyBhIGdvb2QgY2hhbmdlIHRvIHRyeSB0byBwaGFzZSBvdXQgdGhl DQo+ID4gbGVnYWN5IGJpbmRpbmcgYW5kIHJlcXVlc3QgdG8gdXNlIGdlbmVyaWMgYmluZGluZ3Mg ZXZlcnl3aGVyZSBpZiB5b3UNCj4gPiBzdGFydCB0byB1c2UgaW4gb25lIFNNTVUuDQo+ID4NCj4g PiBUaGUgb3RoZXIgbGVzcyB0ZWNobmljYWwgcmVhc29uIGZvciBub3Qgc3VwcG9ydGluZyBib3Ro IGF0IG9uY2UgaXMgdGhhdA0KPiBhbnlvbmUNCj4gPiB3aG8gY2FuIHVwZGF0ZSB0aGVpciBEVCB0 byBhZGQgb3IgdXBkYXRlIFNNTVVzIHdpdGggdGhlIG5ldyBiaW5kaW5nIGhhcyBubw0KPiBnb29k DQo+ID4gZXhjdXNlIGZvciBub3QgdXBkYXRpbmcgdGhlIHdob2xlIGxvdC4gSXQncyB0aGUgbGlr ZXMgb2YgU2VhdHRsZSBhbmQNCj4gVGh1bmRlclgNCj4gPiBib3hlcyB3aXRoIGZpcm13YXJlIHRo YXQgd29uJ3QgZ2V0IHVwZGF0ZWQgZm9yIHdoaWNoIHdlIGhhdmUgdG8gcHJlc2VydmUNCj4gIm1t dS1tYXN0ZXJzIg0KPiA+IHN1cHBvcnQuDQo+IA0KPiBJIHdvdWxkIGxpa2UgdGhlc2UgcmVhc29u cyB0byBiZSB3cml0dGVuIGluIHRoZSBjb21taXQgbWVzc2FnZS4gSSB3b3VsZA0KPiBhbHNvIGxp a2UgdG8gZGV0ZWN0IGFuZCBwcmludCBhIGNsZWFyIHdhcm5pbmcgd2hlbiBTTU1VcyBhcmUgdXNp bmcNCj4gbWlzbWF0Y2hlZCBiaW5kaW5ncy4NCj4gDQoNCk9rLg0KDQo+IA0KPiA+ID4NCj4gPiA+ ID4gIHN0YXRpYyBzdHJ1Y3QgYXJtX3NtbXVfb3B0aW9uX3Byb3AgYXJtX3NtbXVfb3B0aW9uc1td ID0gew0KPiA+ID4gPiAgCXsgQVJNX1NNTVVfT1BUX1NFQ1VSRV9DRkdfQUNDRVNTLCAiY2FseGVk YSxzbW11LXNlY3VyZS1jb25maWctDQo+IGFjY2VzcyIgfSwNCj4gPiA+ID4gIAl7IDAsIE5VTEx9 LA0KPiA+ID4gPiBAQCAtMjI4OSw2ICsyMjkzLDI1IEBAIHN0YXRpYyBpbnQgYXJtX3NtbXVfZGV2 aWNlX2R0X3Byb2JlKHN0cnVjdA0KPiA+ID4gcGxhdGZvcm1fZGV2aWNlICpwZGV2KQ0KPiA+ID4g PiAgCXN0cnVjdCByYl9ub2RlICpub2RlOw0KPiA+ID4gPiAgCXN0cnVjdCBvZl9waGFuZGxlX2Fy Z3MgbWFzdGVyc3BlYzsNCj4gPiA+ID4gIAlpbnQgbnVtX2lycXMsIGksIGVycjsNCj4gPiA+ID4g Kwlib29sIGxlZ2FjeV9iaW5kaW5nOw0KPiA+ID4gPiArDQo+ID4gPiA+ICsJLyoNCj4gPiA+ID4g KwkgKiBYZW46IERvIHRoZSBzYW1lIGNoZWNrIGFzIExpbnV4LiBDaGVja2luZyB0aGUgU01NVSBk ZXZpY2UgdHJlZQ0KPiA+ID4gYmluZGluZ3MNCj4gPiA+ICAgICAgICAgICAgIF4gZG8gICAgICAg ICAgICAgICAgICAgICAgICBeIENoZWNrIHRoYXQNCj4gPiA+DQo+ID4gPg0KPiA+ID4gPiArCSAq IGFyZSBlaXRoZXIgdXNpbmcgZ2VuZXJpYyBvciBsZWdhY3kgb25lLg0KPiA+ID4gICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgXiBiaW5kaW5ncw0KPiA+ID4NCj4gPiA+ ID4gKwkgKg0KPiA+ID4gPiArCSAqIFRoZSAibW11LW1hc3RlcnMiIHByb3BlcnR5IGlzIG9ubHkg ZXhpc3RlZCBpbiBsZWdhY3kgYmluZGluZ3MuDQo+ID4gPiAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgXiBvbmx5IGV4aXN0cyBpbiB0aGUgbGVnYWN5IGJpbmRpbmdzDQo+ID4gPg0K PiA+DQo+ID4gVGhhbmtzLCBJIHdpbGwgZml4IGFib3ZlIHR5cG9zLg0KPiA+DQo+ID4gPiA+ICsJ ICovDQo+ID4gPiA+ICsJbGVnYWN5X2JpbmRpbmcgPSBkdF9maW5kX3Byb3BlcnR5KGRldi0+b2Zf bm9kZSwgIm1tdS1tYXN0ZXJzIiwNCj4gTlVMTCk7DQo+ID4gPiA+ICsJaWYgKGxlZ2FjeV9iaW5k aW5nICYmICF1c2luZ19nZW5lcmljX2JpbmRpbmcpIHsNCj4gPiA+ID4gKwkJaWYgKCF1c2luZ19s ZWdhY3lfYmluZGluZykNCj4gPiA+ID4gKwkJCXByX25vdGljZSgiZGVwcmVjYXRlZCBcIm1tdS1t YXN0ZXJzXCIgRFQgcHJvcGVydHkgaW4NCj4gdXNlXG4iKTsNCj4gPiA+ID4gKwkJdXNpbmdfbGVn YWN5X2JpbmRpbmcgPSB0cnVlOw0KPiA+ID4gPiArCX0gZWxzZSBpZiAoIWxlZ2FjeV9iaW5kaW5n ICYmICF1c2luZ19sZWdhY3lfYmluZGluZykgew0KPiA+ID4gPiArCQl1c2luZ19nZW5lcmljX2Jp bmRpbmcgPSB0cnVlOw0KPiA+ID4NCj4gPiA+IFBsZWFzZSBzaW1wbGlmeSB0aGlzIHNlcmllcyBv ZiBpZi9lbHNlLg0KPiA+ID4NCj4gPg0KPiA+IFRoaXMgY29kZSBpcyB0aGUgc2FtZSBhcyBMaW51 eCBTTU1VIGRyaXZlci4gSWYgd2UgYWdyZWUgb24gZW5mb3JjaW5nIGFsbA0KPiBzbW11cw0KPiA+ IGFyZSB1c2luZyB0aGUgc2FtZSBiaW5kaW5nLCBJIHByZWZlciB0byBrZWVwIHRoZSBjb2RlIHRo ZSBzYW1lLg0KPiANCj4gSXMgaXQ/ISBXb3cuLi4gQWxsIHJpZ2h0IHRoZW4sIGJ1dCBJIHdvdWxk IHN0aWxsIGxpa2UgYSB3YXJuaW5nIHRvIGJlDQo+IHByaW50ZWQgd2hlbiB3ZSBmaW5kIG91dCB0 aGF0IGFuIFNNTVUgaXMgdXNpbmcgbGVnYWN5IGJpbmRpbmdzIGFuZA0KPiBvdGhlcnMgYXJlIHVz aW5nIGdlbmVyaWMgYmluZGluZ3MuDQo+IA0KDQpPaywgSSB3aWxsIGFkZCB0aGlzIHdhcm5pbmcg bWVzc2FnZS4NCg0KPiANCj4gPiA+DQo+ID4gPiA+ICsJfSBlbHNlIHsNCj4gPiA+ID4gKwkJZGV2 X2VycihkZXYsICJub3QgcHJvYmluZyBkdWUgdG8gbWlzbWF0Y2hlZCBEVA0KPiBwcm9wZXJ0aWVz XG4iKTsNCj4gPiA+ID4gKwkJcmV0dXJuIC1FTk9ERVY7DQo+ID4gPiA+ICsJfQ0KPiA+ID4NCj4g PiA+DQo+ID4gPg0KPiA+ID4NCj4gPiA+ID4gIAlzbW11ID0gZGV2bV9remFsbG9jKGRldiwgc2l6 ZW9mKCpzbW11KSwgR0ZQX0tFUk5FTCk7DQo+ID4gPiA+ICAJaWYgKCFzbW11KSB7DQo+ID4gPiA+ IC0tDQo+ID4gPiA+IDIuNy40DQo+ID4gPiA+DQo+ID4gPiA+DQo+ID4gPiA+IF9fX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fDQo+ID4gPiA+IFhlbi1kZXZlbCBt YWlsaW5nIGxpc3QNCj4gPiA+ID4gWGVuLWRldmVsQGxpc3RzLnhlbi5vcmcNCj4gPiA+ID4gaHR0 cHM6Ly9saXN0cy54ZW4ub3JnL3hlbi1kZXZlbA0KPiA+ID4gPg0KPiA+DQo+ID4gX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX18NCj4gPiBYZW4tZGV2ZWwgbWFp bGluZyBsaXN0DQo+ID4gWGVuLWRldmVsQGxpc3RzLnhlbi5vcmcNCj4gPiBodHRwczovL2xpc3Rz Lnhlbi5vcmcveGVuLWRldmVsDQo+ID4NCl9fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fClhlbi1kZXZlbCBtYWlsaW5nIGxpc3QKWGVuLWRldmVsQGxpc3RzLnhl bi5vcmcKaHR0cHM6Ly9saXN0cy54ZW4ub3JnL3hlbi1kZXZlbAo=