Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp7044252imm; Tue, 24 Jul 2018 07:32:25 -0700 (PDT) X-Google-Smtp-Source: AAOMgpcgZM5Ud1wAMAJ3h6XNZaJj9c9nVpmT3ewGe8/bbamwf9xUEdmQqgcKM35PsvhLpEidAbc6 X-Received: by 2002:a62:5047:: with SMTP id e68-v6mr18211487pfb.157.1532442745239; Tue, 24 Jul 2018 07:32:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532442745; cv=none; d=google.com; s=arc-20160816; b=E8qGqhWvh9p28dkUkEkHtfZePvKMW87khkHc9GtfCgIre7KK9ZWhKQO4d6+iLmIQ9o ePpHdeE3A81rzKRfoFMW3oKAATI6tAAYw7080ITQ0Tt3Tu15gTG8i2Nj1Jtr/kiteHKo 8hIgGtxv3lD+dGbEs67lWkeFNKwMyyBdwkOZoAJYUzNs7vTkZdnGcauHIFqqZmhNs3Ib aQAaik+kt9tpIu0mwUe03NOjZRpLgi3YXnfjb80Srq/5OxjoUZ+MwVcUKSasfxlmAfvi NlpP0nhJc6q5vs7DSkfSCvZMEX2FJJlzTDlakfTRSL7TvUN65HFplQ03A3aMkZxtzs2n 0TgQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=CaJWhHoKz16D5DNfuGZ2O0dOEANoN5yNdLqI/CdUp3Y=; b=SeAoVOTfbgp0HlnaywqrINCGnlyOZ66sWDmvZ5Jnp+itwgTnlKNcV2k0Fx4NmtLD6x 4mbwnCe0bB6LmxMHf3LWcGJIQNRrwIGgj6c5flTdnl7RK3s7UNSfhcETBLBqy4NIbwVK 2VHOJSdcl7YU4/y2tM2lRzRmcQKCl7lwEgGcMYpDz8dyrShYmlfub2JEfAv1U+BEIh13 uJOWdrwsckUx1kqAtd9BBribKQbIk/fi8nl5UNmsjP7Vr5T+i6ZdcynAj41WttV5mY8e JRozIZD3CqIoI7/dL1I+HOaKpDH5I5fOK14lNwJcHjsR0Xv8MHYHdMqjP7bJ8B0OW5UJ VEfQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j189-v6si10763869pgd.498.2018.07.24.07.32.09; Tue, 24 Jul 2018 07:32:25 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388682AbeGXPgx (ORCPT + 99 others); Tue, 24 Jul 2018 11:36:53 -0400 Received: from mx3.molgen.mpg.de ([141.14.17.11]:38509 "EHLO mx1.molgen.mpg.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S2388518AbeGXPgx (ORCPT ); Tue, 24 Jul 2018 11:36:53 -0400 Received: from keineahnung.molgen.mpg.de (keineahnung.molgen.mpg.de [141.14.17.193]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: pmenzel) by mx.molgen.mpg.de (Postfix) with ESMTPSA id 80A592012BACB8; Tue, 24 Jul 2018 16:30:05 +0200 (CEST) Subject: Re: `ohci_rh_resume()` called during `usb_dev_suspend()` To: Alan Stern Cc: linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org References: From: Paul Menzel Message-ID: Date: Tue, 24 Jul 2018 16:30:05 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.8.0 MIME-Version: 1.0 In-Reply-To: Content-Type: multipart/signed; protocol="application/pkcs7-signature"; micalg=sha-256; boundary="------------ms090105080803090804080103" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This is a cryptographically signed message in MIME format. --------------ms090105080803090804080103 Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: quoted-printable Dear Alan, Thank you for your quick response. On 07/24/18 16:21, Alan Stern wrote: > On Tue, 24 Jul 2018, Paul Menzel wrote: >> Profiling the suspend to and resume/wake-up from ACPI S3 with=20 >> `sleepgraph.py` on an ASRock E350M1, I noticed that resume methods are= =20 >> called during suspend. >> >> Here is an excerpt from the callgraph. >> >>> 600.376906 | 0) kworker-81 | | /* device_pm_ca= llback_start: usb usb5, parent: 0000:00:14.5, type [suspend] */ >>> 600.376909 | 0) kworker-81 | | usb_dev_suspe= nd() { >>> 600.376911 | 0) kworker-81 | | usb_suspend= () { >>> 600.376913 | 0) kworker-81 | | __pm_runt= ime_resume() { >>> 600.376915 | 0) kworker-81 | | _cond_r= esched() { >>> 600.376917 | 0) kworker-81 | 0.565 us | rcu_a= ll_qs(); >>> 600.376921 | 0) kworker-81 | 4.034 us | } /* _c= ond_resched */ >>> 600.376922 | 0) kworker-81 | 0.505 us | _raw_sp= in_lock_irqsave(); >>> 600.376926 | 0) kworker-81 | | rpm_res= ume() { >>> 600.376928 | 0) kworker-81 | 0.573 us | _raw_= spin_lock(); >>> 600.376934 | 0) kworker-81 | 0.706 us | rpm_r= esume(); >>> 600.376937 | 0) kworker-81 | 0.556 us | _raw_= spin_lock(); >>> 600.376942 | 0) kworker-81 | 0.721 us | __rpm= _get_callback(); >>> 600.376946 | 0) kworker-81 | 0.564 us | dev_p= m_disable_wake_irq_check(); >>> 600.376949 | 0) kworker-81 | | rpm_c= allback() { >>> 600.376952 | 0) kworker-81 | | __r= pm_callback() { >>> 600.376954 | 0) kworker-81 | | u= sb_runtime_resume() { >>> 600.376956 | 0) kworker-81 | | = usb_resume_both() { >>> 600.376959 | 0) kworker-81 | | = generic_resume() { >>> 600.376960 | 0) kworker-81 | | = hcd_bus_resume() { >>> 600.376963 | 0) kworker-81 | | = ohci_bus_resume [ohci_hcd]() { >>> 600.376964 | 0) kworker-81 | 0.588 us | = _raw_spin_lock_irq(); >>> 600.376968 | 0) kworker-81 | | = ohci_rh_resume [ohci_hcd]() { >>> 600.377043 | 0) kworker-81 | | = msleep() { >> >> Please find the full callgraph and the HTML output attached. >> >> Is that expected? >=20 > I can't tell exactly what's happening from your callgraph and HTML, but= > yes, in general it is expected. >=20 > The reason is because some devices have different wakeup settings for > runtime suspend and system suspend: A device that is enabled for wakeup= > signalling during runtime suspend often is not enabled for wakeup > during system suspend. >=20 > As a result, the device's wakeup setting has to be changed when the=20 > system goes to sleep, and to do that, we have to wake the device up=20 > temporarily if it is already in runtime suspend. Understood. Thank you for the explanation. Sorry for being ignorant, but I have two more questions. 1. Should this also happen, if no USB device is connected to a hub? 2. If somebody point me to the code, how the callback(?) `pm_runtime_resume()` is hooked up in `usb_suspend()` that=E2=80=99d = help me to better understand, what is going on. Kind regards and thank you very much in advance, Paul --------------ms090105080803090804080103 Content-Type: application/pkcs7-signature; name="smime.p7s" Content-Transfer-Encoding: base64 Content-Disposition: attachment; filename="smime.p7s" Content-Description: S/MIME Cryptographic Signature MIAGCSqGSIb3DQEHAqCAMIACAQExDzANBglghkgBZQMEAgEFADCABgkqhkiG9w0BBwEAAKCC EFowggUSMIID+qADAgECAgkA4wvV+K8l2YEwDQYJKoZIhvcNAQELBQAwgYIxCzAJBgNVBAYT AkRFMSswKQYDVQQKDCJULVN5c3RlbXMgRW50ZXJwcmlzZSBTZXJ2aWNlcyBHbWJIMR8wHQYD VQQLDBZULVN5c3RlbXMgVHJ1c3QgQ2VudGVyMSUwIwYDVQQDDBxULVRlbGVTZWMgR2xvYmFs Um9vdCBDbGFzcyAyMB4XDTE2MDIyMjEzMzgyMloXDTMxMDIyMjIzNTk1OVowgZUxCzAJBgNV BAYTAkRFMUUwQwYDVQQKEzxWZXJlaW4genVyIEZvZXJkZXJ1bmcgZWluZXMgRGV1dHNjaGVu IEZvcnNjaHVuZ3NuZXR6ZXMgZS4gVi4xEDAOBgNVBAsTB0RGTi1QS0kxLTArBgNVBAMTJERG Ti1WZXJlaW4gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgMjCCASIwDQYJKoZIhvcNAQEBBQAD ggEPADCCAQoCggEBAMtg1/9moUHN0vqHl4pzq5lN6mc5WqFggEcVToyVsuXPztNXS43O+FZs FVV2B+pG/cgDRWM+cNSrVICxI5y+NyipCf8FXRgPxJiZN7Mg9mZ4F4fCnQ7MSjLnFp2uDo0p eQcAIFTcFV9Kltd4tjTTwXS1nem/wHdN6r1ZB+BaL2w8pQDcNb1lDY9/Mm3yWmpLYgHurDg0 WUU2SQXaeMpqbVvAgWsRzNI8qIv4cRrKO+KA3Ra0Z3qLNupOkSk9s1FcragMvp0049ENF4N1 xDkesJQLEvHVaY4l9Lg9K7/AjsMeO6W/VRCrKq4Xl14zzsjz9AkH4wKGMUZrAcUQDBHHWekC AwEAAaOCAXQwggFwMA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUk+PYMiba1fFKpZFK4OpL 4qIMz+EwHwYDVR0jBBgwFoAUv1kgNgB5oKAia4zV8mHSuCzLgkowEgYDVR0TAQH/BAgwBgEB /wIBAjAzBgNVHSAELDAqMA8GDSsGAQQBga0hgiwBAQQwDQYLKwYBBAGBrSGCLB4wCAYGZ4EM AQICMEwGA1UdHwRFMEMwQaA/oD2GO2h0dHA6Ly9wa2kwMzM2LnRlbGVzZWMuZGUvcmwvVGVs ZVNlY19HbG9iYWxSb290X0NsYXNzXzIuY3JsMIGGBggrBgEFBQcBAQR6MHgwLAYIKwYBBQUH MAGGIGh0dHA6Ly9vY3NwMDMzNi50ZWxlc2VjLmRlL29jc3ByMEgGCCsGAQUFBzAChjxodHRw Oi8vcGtpMDMzNi50ZWxlc2VjLmRlL2NydC9UZWxlU2VjX0dsb2JhbFJvb3RfQ2xhc3NfMi5j ZXIwDQYJKoZIhvcNAQELBQADggEBAIcL/z4Cm2XIVi3WO5qYi3FP2ropqiH5Ri71sqQPrhE4 eTizDnS6dl2e6BiClmLbTDPo3flq3zK9LExHYFV/53RrtCyD2HlrtrdNUAtmB7Xts5et6u5/ MOaZ/SLick0+hFvu+c+Z6n/XUjkurJgARH5pO7917tALOxrN5fcPImxHhPalR6D90Bo0fa3S PXez7vTXTf/D6OWST1k+kEcQSrCFWMBvf/iu7QhCnh7U3xQuTY+8npTD5+32GPg8SecmqKc2 2CzeIs2LgtjZeOJVEqM7h0S2EQvVDFKvaYwPBt/QolOLV5h7z/0HJPT8vcP9SpIClxvyt7bP ZYoaorVyGTkwggWNMIIEdaADAgECAgwcOtRQhH7u81j4jncwDQYJKoZIhvcNAQELBQAwgZUx CzAJBgNVBAYTAkRFMUUwQwYDVQQKEzxWZXJlaW4genVyIEZvZXJkZXJ1bmcgZWluZXMgRGV1 dHNjaGVuIEZvcnNjaHVuZ3NuZXR6ZXMgZS4gVi4xEDAOBgNVBAsTB0RGTi1QS0kxLTArBgNV BAMTJERGTi1WZXJlaW4gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgMjAeFw0xNjExMDMxNTI0 NDhaFw0zMTAyMjIyMzU5NTlaMGoxCzAJBgNVBAYTAkRFMQ8wDQYDVQQIDAZCYXllcm4xETAP BgNVBAcMCE11ZW5jaGVuMSAwHgYDVQQKDBdNYXgtUGxhbmNrLUdlc2VsbHNjaGFmdDEVMBMG A1UEAwwMTVBHIENBIC0gRzAyMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAnhx4 59Lh4WqgOs/Md04XxU2yFtfM15ZuJV0PZP7BmqSJKLLPyqmOrADfNdJ5PIGBto2JBhtRRBHd G0GROOvTRHjzOga95WOTeura79T21FWwwAwa29OFnD3ZplQs6HgdwQrZWNi1WHNJxn/4mA19 rNEBUc5urSIpZPvZi5XmlF3v3JHOlx3KWV7mUteB4pwEEfGTg4npPAJbp2o7arxQdoIq+Pu2 OsvqhD7Rk4QeaX+EM1QS4lqd1otW4hE70h/ODPy1xffgbZiuotWQLC6nIwa65Qv6byqlIX0q Zuu99Vsu+r3sWYsL5SBkgecNI7fMJ5tfHrjoxfrKl/ErTAt8GQIDAQABo4ICBTCCAgEwEgYD VR0TAQH/BAgwBgEB/wIBATAOBgNVHQ8BAf8EBAMCAQYwKQYDVR0gBCIwIDANBgsrBgEEAYGt IYIsHjAPBg0rBgEEAYGtIYIsAQEEMB0GA1UdDgQWBBTEiKUH7rh7qgwTv9opdGNSG0lwFjAf BgNVHSMEGDAWgBST49gyJtrV8UqlkUrg6kviogzP4TCBjwYDVR0fBIGHMIGEMECgPqA8hjpo dHRwOi8vY2RwMS5wY2EuZGZuLmRlL2dsb2JhbC1yb290LWcyLWNhL3B1Yi9jcmwvY2Fjcmwu Y3JsMECgPqA8hjpodHRwOi8vY2RwMi5wY2EuZGZuLmRlL2dsb2JhbC1yb290LWcyLWNhL3B1 Yi9jcmwvY2FjcmwuY3JsMIHdBggrBgEFBQcBAQSB0DCBzTAzBggrBgEFBQcwAYYnaHR0cDov L29jc3AucGNhLmRmbi5kZS9PQ1NQLVNlcnZlci9PQ1NQMEoGCCsGAQUFBzAChj5odHRwOi8v Y2RwMS5wY2EuZGZuLmRlL2dsb2JhbC1yb290LWcyLWNhL3B1Yi9jYWNlcnQvY2FjZXJ0LmNy dDBKBggrBgEFBQcwAoY+aHR0cDovL2NkcDIucGNhLmRmbi5kZS9nbG9iYWwtcm9vdC1nMi1j YS9wdWIvY2FjZXJ0L2NhY2VydC5jcnQwDQYJKoZIhvcNAQELBQADggEBABLpeD5FygzqOjj+ /lAOy20UQOGWlx0RMuPcI4nuyFT8SGmK9lD7QCg/HoaJlfU/r78ex+SEide326evlFAoJXIF jVyzNltDhpMKrPIDuh2N12zyn1EtagqPL6hu4pVRzcBpl/F2HCvtmMx5K4WN1L1fmHWLcSap dhXLvAZ9RG/B3rqyULLSNN8xHXYXpmtvG0VGJAndZ+lj+BH7uvd3nHWnXEHC2q7iQlDUqg0a wIqWJgdLlx1Q8Dg/sodv0m+LN0kOzGvVDRCmowBdWGhhusD+duKV66pBl+qhC+4LipariWaM qK5ppMQROATjYeNRvwI+nDcEXr2vDaKmdbxgDVwwggWvMIIEl6ADAgECAgweKlJIhfynPMVG /KIwDQYJKoZIhvcNAQELBQAwajELMAkGA1UEBhMCREUxDzANBgNVBAgMBkJheWVybjERMA8G A1UEBwwITXVlbmNoZW4xIDAeBgNVBAoMF01heC1QbGFuY2stR2VzZWxsc2NoYWZ0MRUwEwYD VQQDDAxNUEcgQ0EgLSBHMDIwHhcNMTcxMTE0MTEzNDE2WhcNMjAxMTEzMTEzNDE2WjCBizEL MAkGA1UEBhMCREUxIDAeBgNVBAoMF01heC1QbGFuY2stR2VzZWxsc2NoYWZ0MTQwMgYDVQQL DCtNYXgtUGxhbmNrLUluc3RpdHV0IGZ1ZXIgbW9sZWt1bGFyZSBHZW5ldGlrMQ4wDAYDVQQL DAVNUElNRzEUMBIGA1UEAwwLUGF1bCBNZW56ZWwwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAw ggEKAoIBAQDIh/UR/AX/YQ48VWWDMLTYtXjYJyhRHMc81ZHMMoaoG66lWB9MtKRTnB5lovLZ enTIUyPsCrMhTqV9CWzDf6v9gOTWVxHEYqrUwK5H1gx4XoK81nfV8oGV4EKuVmmikTXiztGz peyDmOY8o/EFNWP7YuRkY/lPQJQBeBHYq9AYIgX4StuXu83nusq4MDydygVOeZC15ts0tv3/ 6WmibmZd1OZRqxDOkoBbY3Djx6lERohs3IKS6RKiI7e90rCSy9rtidJBOvaQS9wvtOSKPx0a +2pAgJEVzZFjOAfBcXydXtqXhcpOi2VCyl+7+LnnTz016JJLsCBuWEcB3kP9nJYNAgMBAAGj ggIxMIICLTAJBgNVHRMEAjAAMA4GA1UdDwEB/wQEAwIF4DAdBgNVHSUEFjAUBggrBgEFBQcD AgYIKwYBBQUHAwQwHQYDVR0OBBYEFHM0Mc3XjMLlhWpp4JufRELL4A/qMB8GA1UdIwQYMBaA FMSIpQfuuHuqDBO/2il0Y1IbSXAWMCAGA1UdEQQZMBeBFXBtZW56ZWxAbW9sZ2VuLm1wZy5k ZTB9BgNVHR8EdjB0MDigNqA0hjJodHRwOi8vY2RwMS5wY2EuZGZuLmRlL21wZy1nMi1jYS9w dWIvY3JsL2NhY3JsLmNybDA4oDagNIYyaHR0cDovL2NkcDIucGNhLmRmbi5kZS9tcGctZzIt Y2EvcHViL2NybC9jYWNybC5jcmwwgc0GCCsGAQUFBwEBBIHAMIG9MDMGCCsGAQUFBzABhido dHRwOi8vb2NzcC5wY2EuZGZuLmRlL09DU1AtU2VydmVyL09DU1AwQgYIKwYBBQUHMAKGNmh0 dHA6Ly9jZHAxLnBjYS5kZm4uZGUvbXBnLWcyLWNhL3B1Yi9jYWNlcnQvY2FjZXJ0LmNydDBC BggrBgEFBQcwAoY2aHR0cDovL2NkcDIucGNhLmRmbi5kZS9tcGctZzItY2EvcHViL2NhY2Vy dC9jYWNlcnQuY3J0MEAGA1UdIAQ5MDcwDwYNKwYBBAGBrSGCLAEBBDARBg8rBgEEAYGtIYIs AQEEAwYwEQYPKwYBBAGBrSGCLAIBBAMGMA0GCSqGSIb3DQEBCwUAA4IBAQCQs6bUDROpFO2F Qz2FMgrdb39VEo8P3DhmpqkaIMC5ZurGbbAL/tAR6lpe4af682nEOJ7VW86ilsIJgm1j0ueY aOuL8jrN4X7IF/8KdZnnNnImW3QVni6TCcc+7+ggci9JHtt0IDCj5vPJBpP/dKXLCN4M+exl GXYpfHgxh8gclJPY1rquhQrihCzHfKB01w9h9tWZDVMtSoy9EUJFhCXw7mYUsvBeJwZesN2B fndPkrXx6XWDdU3S1LyKgHlLIFtarLFm2Hb5zAUR33h+26cN6ohcGqGEEzgIG8tXS8gztEaj 1s2RyzmKd4SXTkKR3GhkZNVWy+gM68J7jP6zzN+cMYIDmjCCA5YCAQEwejBqMQswCQYDVQQG EwJERTEPMA0GA1UECAwGQmF5ZXJuMREwDwYDVQQHDAhNdWVuY2hlbjEgMB4GA1UECgwXTWF4 LVBsYW5jay1HZXNlbGxzY2hhZnQxFTATBgNVBAMMDE1QRyBDQSAtIEcwMgIMHipSSIX8pzzF RvyiMA0GCWCGSAFlAwQCAQUAoIIB8TAYBgkqhkiG9w0BCQMxCwYJKoZIhvcNAQcBMBwGCSqG SIb3DQEJBTEPFw0xODA3MjQxNDMwMDVaMC8GCSqGSIb3DQEJBDEiBCBBqLTVh64mExcK+XgL WtIQ3+0lNHqZjrmCplyk/knwcDBsBgkqhkiG9w0BCQ8xXzBdMAsGCWCGSAFlAwQBKjALBglg hkgBZQMEAQIwCgYIKoZIhvcNAwcwDgYIKoZIhvcNAwICAgCAMA0GCCqGSIb3DQMCAgFAMAcG BSsOAwIHMA0GCCqGSIb3DQMCAgEoMIGJBgkrBgEEAYI3EAQxfDB6MGoxCzAJBgNVBAYTAkRF MQ8wDQYDVQQIDAZCYXllcm4xETAPBgNVBAcMCE11ZW5jaGVuMSAwHgYDVQQKDBdNYXgtUGxh bmNrLUdlc2VsbHNjaGFmdDEVMBMGA1UEAwwMTVBHIENBIC0gRzAyAgweKlJIhfynPMVG/KIw gYsGCyqGSIb3DQEJEAILMXygejBqMQswCQYDVQQGEwJERTEPMA0GA1UECAwGQmF5ZXJuMREw DwYDVQQHDAhNdWVuY2hlbjEgMB4GA1UECgwXTWF4LVBsYW5jay1HZXNlbGxzY2hhZnQxFTAT BgNVBAMMDE1QRyBDQSAtIEcwMgIMHipSSIX8pzzFRvyiMA0GCSqGSIb3DQEBAQUABIIBAFtd hjUSuBpd2tvXDCcTzxqa/owpvsEtFbCOT/rY0r/U3B7eMosDkpqyilmko5P5afv/BPgk6Bmz RFz/Jei3oLgso89HPnBxYNKl/uApR7aEdq4md9cAqv4mWznc+8VhXQDLrw0n1srubfvMBsbN INDFpoge7bu/qfcRypsULlpDRL7wcBBqwPBGQJQX/U5KMtZp90c8uzKtphN7h4+DWdnhR/z9 ZwQ+9llNDo/XnFBaCndvOJl5Jclykl87AbDo3KaE9hEeFv8dWiLAy7uiJQq7Ctn/vioWg7wQ KomMW9LDaa4W4kkfsjFKXQXVH7f341vnN2s7j4VpidwqYO8DdjEAAAAAAAA= --------------ms090105080803090804080103--