Return-Path: X-Original-To: apmail-couchdb-dev-archive@www.apache.org Delivered-To: apmail-couchdb-dev-archive@www.apache.org Received: from mail.apache.org (hermes.apache.org [140.211.11.3]) by minotaur.apache.org (Postfix) with SMTP id 1DB6C1C1A for ; Tue, 19 Apr 2011 14:45:44 +0000 (UTC) Received: (qmail 1698 invoked by uid 500); 18 Apr 2011 22:45:44 -0000 Delivered-To: apmail-couchdb-dev-archive@couchdb.apache.org Received: (qmail 1669 invoked by uid 500); 18 Apr 2011 22:45:44 -0000 Mailing-List: contact dev-help@couchdb.apache.org; run by ezmlm Precedence: bulk List-Help: List-Unsubscribe: List-Post: List-Id: Reply-To: dev@couchdb.apache.org Delivered-To: mailing list dev@couchdb.apache.org Received: (qmail 1661 invoked by uid 99); 18 Apr 2011 22:45:43 -0000 Received: from athena.apache.org (HELO athena.apache.org) (140.211.11.136) by apache.org (qpsmtpd/0.29) with ESMTP; Mon, 18 Apr 2011 22:45:43 +0000 X-ASF-Spam-Status: No, hits=-2000.0 required=5.0 tests=ALL_TRUSTED,T_RP_MATCHES_RCVD X-Spam-Check-By: apache.org Received: from [140.211.11.116] (HELO hel.zones.apache.org) (140.211.11.116) by apache.org (qpsmtpd/0.29) with ESMTP; Mon, 18 Apr 2011 22:45:42 +0000 Received: from hel.zones.apache.org (hel.zones.apache.org [140.211.11.116]) by hel.zones.apache.org (Postfix) with ESMTP id BD6B8A7464 for ; Mon, 18 Apr 2011 22:45:05 +0000 (UTC) Date: Mon, 18 Apr 2011 22:45:05 +0000 (UTC) From: "Paul Joseph Davis (JIRA)" To: dev@couchdb.apache.org Message-ID: <615197183.65829.1303166705772.JavaMail.tomcat@hel.zones.apache.org> In-Reply-To: <1096411398.65711.1303163885757.JavaMail.tomcat@hel.zones.apache.org> Subject: [jira] [Commented] (COUCHDB-1130) binary optimization in couch_file MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit X-JIRA-FingerPrint: 30527f35849b9dde25b450d4833f0394 [ https://issues.apache.org/jira/browse/COUCHDB-1130?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=13021321#comment-13021321 ] Paul Joseph Davis commented on COUCHDB-1130: -------------------------------------------- I'm not entirely certain about the match contexts as this is the first I've heard of them. I *think* we're getting away with sub binaries here though. The part about match contexts though doesn't worry me as we're only adding one for every 4K of data we read. I would point out that this isn't only being hit for reads longer than 4K, this will affect any read that crosses a 4K boundary which could be often enough to make a difference. > binary optimization in couch_file > --------------------------------- > > Key: COUCHDB-1130 > URL: https://issues.apache.org/jira/browse/COUCHDB-1130 > Project: CouchDB > Issue Type: Improvement > Components: Database Core > Affects Versions: 1.0.2 > Reporter: Randall Leeds > Priority: Minor > Attachments: 0001-refactor-remove_block_prefixes-2-for-optimization.patch > > > I've had this patch sitting around since January and kept forgetting to file the ticket. Hurray spring cleaning. > Just for fun I ran erlc with +bin_opt_info, which gives information about how the Erlang VM can optimize creating binary objects. > What follows is the commit message from my patch. > Even if I'm wrong about the last point, it can't hurt. > What think you all? > ------------------- > Running erlc with +bin_opt_info gives an INFO message stating that "matching > anything else but a plain variable to the left of a binary pattern will prevent > delayed sub binary optimization; SUGGEST changing argument order" > I guess matching 0 is triggering this. If I understand correctly, this change > will allow the compiler to skip creating a sub-binary that starts at the block > boundary in the third clause and delay creation until we strip the leading byte > in the 0 clause. This means one less 1-byte binary every time we read across a > block boundary. -- This message is automatically generated by JIRA. For more information on JIRA, see: http://www.atlassian.com/software/jira