From owner-freebsd-performance@FreeBSD.ORG Fri Jan 2 14:09:35 2015 Return-Path: Delivered-To: freebsd-performance@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by hub.freebsd.org (Postfix) with ESMTPS id C888C124 for ; Fri, 2 Jan 2015 14:09:35 +0000 (UTC) Received: from mail-ob0-x22d.google.com (mail-ob0-x22d.google.com [IPv6:2607:f8b0:4003:c01::22d]) (using TLSv1 with cipher ECDHE-RSA-RC4-SHA (128/128 bits)) (Client CN "smtp.gmail.com", Issuer "Google Internet Authority G2" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 867ED1589 for ; Fri, 2 Jan 2015 14:09:35 +0000 (UTC) Received: by mail-ob0-f173.google.com with SMTP id uy5so53324213obc.4 for ; Fri, 02 Jan 2015 06:09:34 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=mime-version:in-reply-to:references:date:message-id:subject:from:to :content-type; bh=S6hTQBncp1217wlbhUyJOAvbveXUiCnZfhwP0zPgOgI=; b=AOy5RnowSd9eQ+iPJJ112xzScsRzgTG9CAs7Yaf1gYqh8GDulWb2MNQExSzLtl8hhB qtuqjFywhKeVSW9ysrhX3jstfuNiWlS3xNFP5W+wQcgGdnwFhtcUIa7bpcieuaGcs0KK m3VdJAzHIwnVZiGubaMWcCf6WqhwLUDeMmKC0cFTzau4EMVzpUI1OJHB+W3huYC4qeRr BeRIVVKupF/JVIIMwAH3Vb//ezzOq6NButBI9Q6ku89zJTBlzMNqfsP/uRykF20qm53D lsulCaP4+EAIChIo06XegopMeVLcIxJa+YRzzNT8U9uBBN/S1lAMTijSUhJscu70Q76y Vrkw== MIME-Version: 1.0 X-Received: by 10.202.178.87 with SMTP id b84mr33468911oif.64.1420207774806; Fri, 02 Jan 2015 06:09:34 -0800 (PST) Received: by 10.60.102.241 with HTTP; Fri, 2 Jan 2015 06:09:34 -0800 (PST) In-Reply-To: <20150102102036.0a52b072@schwanenlied.me> References: <54A43EC4.2030706@mykolab.com> <9BF461F5-D6B6-4287-BE8B-87B281FE93D0@gmail.com> <20150101033733.4b295d3b@schwanenlied.me> <54A621C2.2060408@mykolab.com> <20150102102036.0a52b072@schwanenlied.me> Date: Fri, 2 Jan 2015 09:09:34 -0500 Message-ID: Subject: Fwd: [tor-dev] gettimeofday() Syscall Issues From: grarpamp To: freebsd-performance@freebsd.org Content-Type: multipart/mixed; boundary=001a113b7a30ecd0d8050babe387 X-BeenThere: freebsd-performance@freebsd.org X-Mailman-Version: 2.1.18-1 Precedence: list List-Id: Performance/tuning List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Fri, 02 Jan 2015 14:09:35 -0000 --001a113b7a30ecd0d8050babe387 Content-Type: text/plain; charset=UTF-8 Some recent FreeBSD related questions in this app area. ---------- Forwarded message ---------- From: Yawning Angel Date: Fri, Jan 2, 2015 at 5:20 AM Subject: Re: [tor-dev] gettimeofday() Syscall Issues To: tor-dev@lists.torproject.org On Thu, 01 Jan 2015 23:42:42 -0500 Libertas wrote: > The first two account for the bulk of the calls, as they are in the > core data relaying logic. > > Ultimately, the problem seems to be that the caching is very weak. At > most, only half of the calls to tor_gettimeofday_cached_monotonic() > use the cache. It appears in the vomiting print statements that > loading a single simple HTML page > (http://www.openbsd.org/faq/ports/guide.html to be exact) will cause > >30 gettimeofday() syscalls. You can imagine how that would > >accumulate for an exit carrying 800 KB/s if the caching > doesn't improve much with additional circuits. So while optimization is cool and all, I'm not seeing why this specifically is the underlying issue. Each cell can contain 498 bytes of user payload. Looking at things simplistically this is 800 KiB/s -> 1644 cells/sec, leaving you with approximately 608 microseconds of processing time per cell. On my i5-4250U box, gettimeofday() takes 22 ns on Linux, and 2441 ns on FreeBSD. I'm not sure how accurate the FreeBSD results are as it was in a VirtualBox VM (getpid() on the same VM takes 124 ns). If someone has a OpenBSD box they should benchmark gettimeofday() and see how long the call takes. Taking the FreeBSD case (since we know that tor works fine on Linux), a single gettimeofday() call takes approximately, 0.39% of the per-cell processing budget. For reference (assuming gettimeofday() in *BSD really is this shit performance wise), 7000 calls to gettimeofday() is 17.09 ms worth of calls. The clock code in tor does need love, so I wouldn't object to cleanup, but I'm not sure it's in the state where it's causing the massive performance degradation that you are seeing. Regards, -- Yawning Angel _______________________________________________ tor-dev mailing list tor-dev@lists.torproject.org https://lists.torproject.org/cgi-bin/mailman/listinfo/tor-dev --001a113b7a30ecd0d8050babe387 Content-Type: application/pgp-signature Content-Disposition: attachment Content-Transfer-Encoding: base64 X-Attachment-Id: 70fb2bcf5a99c8fc_0.0.1 LS0tLS1CRUdJTiBQR1AgU0lHTkFUVVJFLS0tLS0NClZlcnNpb246IEdudVBHIHYyDQoNCmlRSWNC QUVCQ2dBR0JRSlVwbkQwQUFvSkVQNHZrRm9JQjhCb2JnWVAvMmdJRzd3Vy9BbFVUcmhpcnVLRGV1 ZXcNCkE1ZTVoWWNzaEphTm9FL2JpSmZ6MnlPU3hnVXNqZnIzUVNicFdUYjNVaXYzRlR3UC9xbDJB ZENMSHNXSFRYVVINClFkRjlJUWxnM1N4eXkrdVdJRzRicm5pRENrVFJVa2pEazVjcE1hOVJjTUZI MXNIWlhCY1luY0x0eWNHdE9NcEcNCnZTcHZTSk5sZ2gwc1ZGRHEvODZ4cDduNGgzUmFmQ05NOGhF d3ZnemdidVdzK2VuUTRFTG5HSExaZ0VjTG5STCsNCjZCalZZZXllMU11ZUlyQTFtTDRyamlVaFFZ bUI1aFhzWGhiaVNnNmVyS1pJbGkrbmlMS1JpcEwxektDRVdtZkUNCnFxdnFDc21jWXVtMEw5eEtP LzJVOXJaUUJxZEFwaU5xR1RxRzBGekVLTDJoa3hZSE0zZnBPWTZ1UTFEdzB1VTYNCk4wMGdxQUdT MXlReEpSVlJsNDRBdXkrSHNOMTFzczBSSWhaNURsVVpMRVVmek91VmhjV3VFalM4cFc0Z1ZNazIN CnEzdmZ0clI1UThNNmF6aUk3Mll5NnlwMU13cHJ1dDNJUkNBdStLeTFsVWVyZjB0aXBTcnl6QnQ1 WUNLL1M3SW0NCjMzMllCaHFiOHVINFVEZGFjZitXTHVCWUlnK0Y4ekpwY0JuMTYrano2WlFjK3ZV cUhSMnlZTFk1QjMxQ0x0Rm0NCnV5cEJpK0JSdHkveDdDOVNoNjV5LzVzUUFjemNWQ0hzM1I3VHNZ azZRTHVWVkhlMDBwV3k0RFlzVG0vRnNSUW8NClhnY3VoTXp2Z3FOcDF2WnV0dGFDOTJ6KzNHUG5I OU9hSmorL0RNWUY2Q2t3TjhIdE4vNGRaL3dyNk9BV3dPR2UNCm5lUmxQTDNId2ZFRHZmNjRvekZa DQo9MFZoRQ0KLS0tLS1FTkQgUEdQIFNJR05BVFVSRS0tLS0tDQo= --001a113b7a30ecd0d8050babe387--