All of lore.kernel.org
 help / color / mirror / Atom feed
From: "Frédéric Dalleau" <frederic.dalleau@linux.intel.com>
To: linux-bluetooth@vger.kernel.org
Cc: "Frédéric Dalleau" <frederic.dalleau@linux.intel.com>
Subject: [PATCH v5 02/16] sbc: Break 4 blocks processing to variable steps
Date: Fri, 14 Dec 2012 16:03:23 +0100	[thread overview]
Message-ID: <1355497417-10357-3-git-send-email-frederic.dalleau@linux.intel.com> (raw)
In-Reply-To: <1355497417-10357-1-git-send-email-frederic.dalleau@linux.intel.com>

Until now SBC processed 4 blocks at a time. If we want to process 15 blocks,
then we need to break this processing in one block steps. 4 blocks is still
default increment.
---
 sbc/sbc.c            |   19 +++++++++++--------
 sbc/sbc_primitives.h |    6 ++++--
 2 files changed, 15 insertions(+), 10 deletions(-)

diff --git a/sbc/sbc.c b/sbc/sbc.c
index e51ed57..4a7dd2e 100644
--- a/sbc/sbc.c
+++ b/sbc/sbc.c
@@ -688,30 +688,32 @@ static int sbc_analyze_audio(struct sbc_encoder_state *state,
 	switch (frame->subbands) {
 	case 4:
 		for (ch = 0; ch < frame->channels; ch++) {
-			x = &state->X[ch][state->position - 16 +
-							frame->blocks * 4];
-			for (blk = 0; blk < frame->blocks; blk += 4) {
+			x = &state->X[ch][state->position - 4 *
+					state->increment + frame->blocks * 4];
+			for (blk = 0; blk < frame->blocks;
+						blk += state->increment) {
 				state->sbc_analyze_4b_4s(
 					state, x,
 					frame->sb_sample_f[blk][ch],
 					frame->sb_sample_f[blk + 1][ch] -
 					frame->sb_sample_f[blk][ch]);
-				x -= 16;
+				x -= 4 * state->increment;
 			}
 		}
 		return frame->blocks * 4;
 
 	case 8:
 		for (ch = 0; ch < frame->channels; ch++) {
-			x = &state->X[ch][state->position - 32 +
-							frame->blocks * 8];
-			for (blk = 0; blk < frame->blocks; blk += 4) {
+			x = &state->X[ch][state->position - 8 *
+					state->increment + frame->blocks * 8];
+			for (blk = 0; blk < frame->blocks;
+						blk += state->increment) {
 				state->sbc_analyze_4b_8s(
 					state, x,
 					frame->sb_sample_f[blk][ch],
 					frame->sb_sample_f[blk + 1][ch] -
 					frame->sb_sample_f[blk][ch]);
-				x -= 32;
+				x -= 8 * state->increment;
 			}
 		}
 		return frame->blocks * 8;
@@ -906,6 +908,7 @@ static void sbc_encoder_init(struct sbc_encoder_state *state,
 {
 	memset(&state->X, 0, sizeof(state->X));
 	state->position = (SBC_X_BUFFER_SIZE - frame->subbands * 9) & ~7;
+	state->increment = 4;
 
 	sbc_init_primitives(state);
 }
diff --git a/sbc/sbc_primitives.h b/sbc/sbc_primitives.h
index a7bbef1..2a7d4a1 100644
--- a/sbc/sbc_primitives.h
+++ b/sbc/sbc_primitives.h
@@ -38,13 +38,15 @@
 
 struct sbc_encoder_state {
 	int position;
+	/* Number of consecutive blocks handled by the encoder */
+	int increment;
 	int16_t SBC_ALIGNED X[2][SBC_X_BUFFER_SIZE];
 	/* Polyphase analysis filter for 4 subbands configuration,
-	 * it handles 4 blocks at once */
+	 * it handles "increment" blocks at once */
 	void (*sbc_analyze_4b_4s)(struct sbc_encoder_state *state,
 			int16_t *x, int32_t *out, int out_stride);
 	/* Polyphase analysis filter for 8 subbands configuration,
-	 * it handles 4 blocks at once */
+	 * it handles "increment" blocks at once */
 	void (*sbc_analyze_4b_8s)(struct sbc_encoder_state *state,
 			int16_t *x, int32_t *out, int out_stride);
 	/* Process input data (deinterleave, endian conversion, reordering),
-- 
1.7.9.5


  parent reply	other threads:[~2012-12-14 15:03 UTC|newest]

Thread overview: 19+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-12-14 15:03 [PATCH v5 00/16] mSBC tests Frédéric Dalleau
2012-12-14 15:03 ` [PATCH v5 01/16] sbc: Add encoder_state to analysis functions Frédéric Dalleau
2012-12-14 15:03 ` Frédéric Dalleau [this message]
2012-12-14 15:03 ` [PATCH v5 03/16] sbc: Rename sbc_analyze_4b_xx to sbc_analyze_xx Frédéric Dalleau
2012-12-14 15:03 ` [PATCH v5 04/16] sbc: add odd member variable to sbc_encoder_state Frédéric Dalleau
2012-12-14 15:03 ` [PATCH v5 05/16] sbc: Add mmx primitive for 1b 8s analysis Frédéric Dalleau
2012-12-14 15:03 ` [PATCH v5 06/16] sbc: Add armv6 " Frédéric Dalleau
2012-12-14 15:03 ` [PATCH v5 07/16] sbc: Add iwmmxt primitive for 1b 8s encoding Frédéric Dalleau
2012-12-14 15:03 ` [PATCH v5 08/16] sbc: Add plain C primitive for 1b 8s analysis Frédéric Dalleau
2012-12-14 15:03 ` [PATCH v5 09/16] sbc: Use plain C primitive if doing msbc on neon Frédéric Dalleau
2012-12-14 15:03 ` [PATCH v5 10/16] sbc: Fix input reordering for 15 blocks case Frédéric Dalleau
2012-12-14 15:03 ` [PATCH v5 11/16] sbc: Add SBC_MSBC flag to enable 15 block encoding Frédéric Dalleau
2012-12-19 17:41   ` Marcel Holtmann
2012-12-14 15:03 ` [PATCH v5 12/16] sbc: Add support for mSBC frame header Frédéric Dalleau
2012-12-14 15:03 ` [PATCH v5 13/16] sbc: Update sbcdec for msbc Frédéric Dalleau
2012-12-14 15:03 ` [PATCH v5 14/16] sbc: Update sbcenc " Frédéric Dalleau
2012-12-14 15:03 ` [PATCH v5 15/16] sbc: Update sbcinfo " Frédéric Dalleau
2012-12-14 15:03 ` [PATCH v5 16/16] sbc: Update copyrights Frédéric Dalleau
2012-12-17  0:33 ` [PATCH v5 00/16] mSBC tests Siarhei Siamashka

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1355497417-10357-3-git-send-email-frederic.dalleau@linux.intel.com \
    --to=frederic.dalleau@linux.intel.com \
    --cc=linux-bluetooth@vger.kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.