亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? sbc.c

?? BlueZ源碼
?? C
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):
	data[1] = (frame->frequency & 0x03) << 6;	data[1] |= (frame->block_mode & 0x03) << 4;	data[1] |= (frame->mode & 0x03) << 2;	data[1] |= (frame->allocation & 0x01) << 1;	switch (frame->subbands) {	case 4:		/* Nothing to do */		break;	case 8:		data[1] |= 0x01;		break;	default:		return -4;		break;	}	data[2] = frame->bitpool;	if ((frame->mode == MONO || frame->mode == DUAL_CHANNEL) &&			frame->bitpool > frame->subbands << 4)		return -5;	if ((frame->mode == STEREO || frame->mode == JOINT_STEREO) &&			frame->bitpool > frame->subbands << 5)		return -5;	/* Can't fill in crc yet */	produced = 32;	crc_header[0] = data[1];	crc_header[1] = data[2];	crc_pos = 16;	for (ch = 0; ch < frame->channels; ch++) {		for (sb = 0; sb < frame->subbands; sb++) {			frame->scale_factor[ch][sb] = 0;			scalefactor[ch][sb] = 2;			for (blk = 0; blk < frame->blocks; blk++) {				while (scalefactor[ch][sb] < fabs(frame->sb_sample_f[blk][ch][sb])) {					frame->scale_factor[ch][sb]++;					scalefactor[ch][sb] *= 2;				}			}		}	}	if (frame->mode == JOINT_STEREO) {		/* like frame->sb_sample but joint stereo */		int32_t sb_sample_j[16][2];		/* scalefactor and scale_factor in joint case */		u_int32_t scalefactor_j[2];		uint8_t scale_factor_j[2];		frame->joint = 0;		for (sb = 0; sb < frame->subbands - 1; sb++) {			scale_factor_j[0] = 0;			scalefactor_j[0] = 2;			scale_factor_j[1] = 0;			scalefactor_j[1] = 2;			for (blk = 0; blk < frame->blocks; blk++) {				/* Calculate joint stereo signal */				sb_sample_j[blk][0] =					(frame->sb_sample_f[blk][0][sb] +						frame->sb_sample_f[blk][1][sb]) >> 1;				sb_sample_j[blk][1] =					(frame->sb_sample_f[blk][0][sb] -						frame->sb_sample_f[blk][1][sb]) >> 1;				/* calculate scale_factor_j and scalefactor_j for joint case */				while (scalefactor_j[0] < fabs(sb_sample_j[blk][0])) {					scale_factor_j[0]++;					scalefactor_j[0] *= 2;				}				while (scalefactor_j[1] < fabs(sb_sample_j[blk][1])) {					scale_factor_j[1]++;					scalefactor_j[1] *= 2;				}			}			/* decide whether to join this subband */			if ((scalefactor[0][sb] + scalefactor[1][sb]) >					(scalefactor_j[0] + scalefactor_j[1]) ) {				/* use joint stereo for this subband */				frame->joint |= 1 << sb;				frame->scale_factor[0][sb] = scale_factor_j[0];				frame->scale_factor[1][sb] = scale_factor_j[1];				scalefactor[0][sb] = scalefactor_j[0];				scalefactor[1][sb] = scalefactor_j[1];				for (blk = 0; blk < frame->blocks; blk++) {					frame->sb_sample_f[blk][0][sb] =							sb_sample_j[blk][0];					frame->sb_sample_f[blk][1][sb] =							sb_sample_j[blk][1];				}			}		}		data[4] = 0;		for (sb = 0; sb < frame->subbands - 1; sb++)			data[4] |= ((frame->joint >> sb) & 0x01) << (frame->subbands - 1 - sb);		crc_header[crc_pos >> 3] = data[4];		produced += frame->subbands;		crc_pos += frame->subbands;	}	for (ch = 0; ch < frame->channels; ch++) {		for (sb = 0; sb < frame->subbands; sb++) {			data[produced >> 3] <<= 4;			crc_header[crc_pos >> 3] <<= 4;			data[produced >> 3] |= frame->scale_factor[ch][sb] & 0x0F;			crc_header[crc_pos >> 3] |= frame->scale_factor[ch][sb] & 0x0F;			produced += 4;			crc_pos += 4;		}	}	/* align the last crc byte */	if (crc_pos % 8)		crc_header[crc_pos >> 3] <<= 8 - (crc_pos % 8);	data[3] = sbc_crc8(crc_header, crc_pos);	sbc_calculate_bits(frame, bits);	for (ch = 0; ch < frame->channels; ch++) {		for (sb = 0; sb < frame->subbands; sb++)			levels[ch][sb] = (1 << bits[ch][sb]) - 1;	}	for (blk = 0; blk < frame->blocks; blk++) {		for (ch = 0; ch < frame->channels; ch++) {			for (sb = 0; sb < frame->subbands; sb++) {				if (levels[ch][sb] > 0) {					audio_sample =						(uint16_t) ((((frame->sb_sample_f[blk][ch][sb]*levels[ch][sb]) >>									(frame->scale_factor[ch][sb] + 1)) +								levels[ch][sb]) >> 1);					audio_sample <<= 16 - bits[ch][sb];					for (bit = 0; bit < bits[ch][sb]; bit++) {						data[produced >> 3] <<= 1;						if (audio_sample & 0x8000)							data[produced >> 3] |= 0x1;						audio_sample <<= 1;						produced++;					}				}			}		}	}	/* align the last byte */	if (produced % 8) {		data[produced >> 3] <<= 8 - (produced % 8);	}	return (produced + 7) >> 3;}struct sbc_priv {	int init;	struct sbc_frame frame;	struct sbc_decoder_state dec_state;	struct sbc_encoder_state enc_state;};static void sbc_set_defaults(sbc_t *sbc, unsigned long flags){	sbc->frequency = SBC_FREQ_44100;	sbc->mode = SBC_MODE_STEREO;	sbc->subbands = SBC_SB_8;	sbc->blocks = SBC_BLK_16;	sbc->bitpool = 32;#if __BYTE_ORDER == __LITTLE_ENDIAN	sbc->endian = SBC_LE;#elif __BYTE_ORDER == __BIG_ENDIAN	sbc->endian = SBC_BE;#else#error "Unknown byte order"#endif}int sbc_init(sbc_t *sbc, unsigned long flags){	if (!sbc)		return -EIO;	memset(sbc, 0, sizeof(sbc_t));	sbc->priv = malloc(sizeof(struct sbc_priv));	if (!sbc->priv)		return -ENOMEM;	memset(sbc->priv, 0, sizeof(struct sbc_priv));	sbc_set_defaults(sbc, flags);	return 0;}int sbc_parse(sbc_t *sbc, void *input, int input_len){	return sbc_decode(sbc, input, input_len, NULL, 0, NULL);}int sbc_decode(sbc_t *sbc, void *input, int input_len, void *output,		int output_len, int *written){	struct sbc_priv *priv;	char *ptr;	int i, ch, framelen, samples;	if (!sbc && !input)		return -EIO;	priv = sbc->priv;	framelen = sbc_unpack_frame(input, &priv->frame, input_len);	if (!priv->init) {		sbc_decoder_init(&priv->dec_state, &priv->frame);		priv->init = 1;		sbc->frequency = priv->frame.frequency;		sbc->mode = priv->frame.mode;		sbc->subbands = priv->frame.subband_mode;		sbc->blocks = priv->frame.block_mode;		sbc->allocation = priv->frame.allocation;		sbc->bitpool = priv->frame.bitpool;		priv->frame.codesize = sbc_get_codesize(sbc);		priv->frame.length = sbc_get_frame_length(sbc);	}	if (!output)		return framelen;	if (written)		*written = 0;	samples = sbc_synthesize_audio(&priv->dec_state, &priv->frame);	ptr = output;	if (output_len < samples * priv->frame.channels * 2)		samples = output_len / (priv->frame.channels * 2);	for (i = 0; i < samples; i++) {		for (ch = 0; ch < priv->frame.channels; ch++) {			int16_t s;			s = priv->frame.pcm_sample[ch][i];#if __BYTE_ORDER == __LITTLE_ENDIAN			if (sbc->endian == SBC_BE) {#elif __BYTE_ORDER == __BIG_ENDIAN			if (sbc->endian == SBC_LE) {#else#error "Unknown byte order"#endif				*ptr++ = (s & 0xff00) >> 8;				*ptr++ = (s & 0x00ff);			} else {				*ptr++ = (s & 0x00ff);				*ptr++ = (s & 0xff00) >> 8;			}		}	}	if (written)		*written = samples * priv->frame.channels * 2;	return framelen;}int sbc_encode(sbc_t *sbc, void *input, int input_len, void *output,		int output_len, int *written){	struct sbc_priv *priv;	char *ptr;	int i, ch, framelen, samples;	if (!sbc && !input)		return -EIO;	priv = sbc->priv;	if (written)		*written = 0;	if (!priv->init) {		priv->frame.frequency = sbc->frequency;		priv->frame.mode = sbc->mode;		priv->frame.channels = sbc->mode == SBC_MODE_MONO ? 1 : 2;		priv->frame.allocation = sbc->allocation;		priv->frame.subband_mode = sbc->subbands;		priv->frame.subbands = sbc->subbands ? 8 : 4;		priv->frame.block_mode = sbc->blocks;		priv->frame.blocks = 4 + (sbc->blocks * 4);		priv->frame.bitpool = sbc->bitpool;		priv->frame.codesize = sbc_get_codesize(sbc);		priv->frame.length = sbc_get_frame_length(sbc);		sbc_encoder_init(&priv->enc_state, &priv->frame);		priv->init = 1;	}	/* input must be large enough to encode a complete frame */	if (input_len < priv->frame.codesize)		return 0;	/* output must be large enough to receive the encoded frame */	if (!output || output_len < priv->frame.length)		return -ENOSPC;	ptr = input;	for (i = 0; i < priv->frame.subbands * priv->frame.blocks; i++) {		for (ch = 0; ch < priv->frame.channels; ch++) {			int16_t s;#if __BYTE_ORDER == __LITTLE_ENDIAN			if (sbc->endian == SBC_BE)#elif __BYTE_ORDER == __BIG_ENDIAN			if (sbc->endian == SBC_LE)#else#error "Unknown byte order"#endif				s = (ptr[0] & 0xff) << 8 | (ptr[1] & 0xff);			else				s = (ptr[0] & 0xff) | (ptr[1] & 0xff) << 8;			ptr += 2;			priv->frame.pcm_sample[ch][i] = s;		}	}	samples = sbc_analyze_audio(&priv->enc_state, &priv->frame);	framelen = sbc_pack_frame(output, &priv->frame, output_len);	if (written)		*written = framelen;	return samples * priv->frame.channels * 2;}void sbc_finish(sbc_t *sbc){	if (!sbc)		return;	if (sbc->priv)		free(sbc->priv);	memset(sbc, 0, sizeof(sbc_t));}int sbc_get_frame_length(sbc_t *sbc){	int ret;	uint8_t subbands, channels, blocks, joint;	struct sbc_priv *priv;	priv = sbc->priv;	if (!priv->init) {		subbands = sbc->subbands ? 8 : 4;		blocks = 4 + (sbc->blocks * 4);		channels = sbc->mode == SBC_MODE_MONO ? 1 : 2;		joint = sbc->mode == SBC_MODE_JOINT_STEREO ? 1 : 0;	} else {		subbands = priv->frame.subbands;		blocks = priv->frame.blocks;		channels = priv->frame.channels;		joint = priv->frame.joint;	}	ret = 4 + (4 * subbands * channels) / 8;	/* This term is not always evenly divide so we round it up */	if (channels == 1)		ret += ((blocks * channels * sbc->bitpool) + 7) / 8;	else		ret += (((joint ? subbands : 0) + blocks * sbc->bitpool) + 7)			/ 8;	return ret;}int sbc_get_frame_duration(sbc_t *sbc){	uint8_t subbands, blocks;	uint16_t frequency;	struct sbc_priv *priv;	priv = sbc->priv;	if (!priv->init) {		subbands = sbc->subbands ? 8 : 4;		blocks = 4 + (sbc->blocks * 4);	} else {		subbands = priv->frame.subbands;		blocks = priv->frame.blocks;	}	switch (sbc->frequency) {	case SBC_FREQ_16000:		frequency = 16000;		break;	case SBC_FREQ_32000:		frequency = 32000;		break;	case SBC_FREQ_44100:		frequency = 44100;		break;	case SBC_FREQ_48000:		frequency = 48000;		break;	default:		return 0;	}	return (1000000 * blocks * subbands) / frequency;}int sbc_get_codesize(sbc_t *sbc){	uint8_t subbands, channels, blocks;	struct sbc_priv *priv;	priv = sbc->priv;	if (!priv->init) {		subbands = sbc->subbands ? 8 : 4;		blocks = 4 + (sbc->blocks * 4);		channels = sbc->mode == SBC_MODE_MONO ? 1 : 2;	} else {		subbands = priv->frame.subbands;		blocks = priv->frame.blocks;		channels = priv->frame.channels;	}	return subbands * blocks * channels * 2;}int sbc_reinit(sbc_t *sbc, unsigned long flags){	struct sbc_priv *priv;	if (!sbc || !sbc->priv)		return -EIO;	priv = sbc->priv;	if (priv->init == 1)		memset(sbc->priv, 0, sizeof(struct sbc_priv));	sbc_set_defaults(sbc, flags);	return 0;}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久精品免费看国产| 午夜国产不卡在线观看视频| 国产一区二区三区在线观看免费视频 | 国产欧美一区二区三区在线老狼| 美女视频免费一区| 久久新电视剧免费观看| 丁香婷婷深情五月亚洲| 午夜av区久久| 日韩欧美成人一区二区| 国产精品资源在线观看| 1区2区3区精品视频| 欧美日韩在线播放三区四区| 日韩黄色片在线观看| 久久一区二区视频| 91视频精品在这里| 日本特黄久久久高潮| 久久精品视频一区| 欧美视频一区二区在线观看| 激情成人综合网| 亚洲视频在线一区| 制服.丝袜.亚洲.中文.综合| 国产精品中文欧美| 亚洲一区中文日韩| 久久日韩粉嫩一区二区三区| 色悠久久久久综合欧美99| 日韩高清欧美激情| 亚洲人午夜精品天堂一二香蕉| 欧美美女一区二区三区| 国产99精品视频| 亚洲成人免费在线观看| 久久蜜臀中文字幕| 欧美日韩成人综合在线一区二区| 国产乱人伦精品一区二区在线观看 | 国产精品久久久久久久岛一牛影视| 色欧美日韩亚洲| 国产主播一区二区| 亚洲高清视频在线| 国产欧美一区二区精品久导航| 67194成人在线观看| 99这里都是精品| 久久丁香综合五月国产三级网站| 亚洲视频在线一区二区| 久久九九久精品国产免费直播| 欧美人牲a欧美精品| 99久久99久久精品免费观看| 韩国精品一区二区| 日韩精品免费视频人成| 亚洲另类春色校园小说| 亚洲国产精品成人综合 | 中文字幕 久热精品 视频在线| 欧美电影一区二区| 91丝袜美腿高跟国产极品老师| 久久99精品久久只有精品| 亚洲一区二区不卡免费| 亚洲视频在线一区二区| 国产色综合一区| 久久综合色8888| 日韩情涩欧美日韩视频| 欧美日韩成人在线一区| 欧美午夜精品一区二区蜜桃| 一本色道**综合亚洲精品蜜桃冫| 国产成人精品影院| 国产精品综合网| 久久精品二区亚洲w码| 天堂va蜜桃一区二区三区漫画版 | 正在播放亚洲一区| 欧美日韩精品免费| 欧美中文字幕一区二区三区| 91麻豆精东视频| 一本色道久久综合亚洲aⅴ蜜桃 | 日本一区二区免费在线| 精品久久国产97色综合| 日韩欧美一级精品久久| 欧美一区二区三区喷汁尤物| 555夜色666亚洲国产免| 欧美一级艳片视频免费观看| 91精品视频网| 日韩一卡二卡三卡国产欧美| 91精品国模一区二区三区| 日韩一区二区三区电影在线观看| 欧美久久久久久蜜桃| 欧美一区二区不卡视频| 日韩欧美视频一区| 久久只精品国产| 国产免费久久精品| 日韩理论在线观看| 亚洲一区av在线| 日韩专区在线视频| 激情小说欧美图片| 春色校园综合激情亚洲| 91丨九色丨尤物| 欧美日韩精品是欧美日韩精品| 欧美日韩成人一区二区| 日韩精品一区二区三区老鸭窝| 欧美精品一区二区三区蜜桃视频 | 日本二三区不卡| 日韩一区二区在线看| 久久蜜桃一区二区| 国产精品久久夜| 亚洲午夜在线视频| 捆绑紧缚一区二区三区视频| 国产精品1区2区3区在线观看| jiyouzz国产精品久久| 欧美中文一区二区三区| 日韩一区二区三区四区| 国产精品美女一区二区| 亚洲一区二区三区四区五区中文| 日韩国产欧美在线视频| 成人小视频在线| 欧美偷拍一区二区| 2022国产精品视频| 亚洲精品欧美专区| 久久成人综合网| 97久久久精品综合88久久| 日韩一区二区三区观看| 国产精品护士白丝一区av| 日韩国产一二三区| 91尤物视频在线观看| 日韩一区二区三区av| 中文字幕在线不卡一区 | 亚洲精品乱码久久久久| 秋霞电影网一区二区| va亚洲va日韩不卡在线观看| 7777精品伊人久久久大香线蕉最新版| 中文字幕不卡的av| 欧美a一区二区| 色诱亚洲精品久久久久久| 精品国产伦一区二区三区观看体验| 中文字幕字幕中文在线中不卡视频| 卡一卡二国产精品| 欧美日韩国产另类一区| 久久九九全国免费| 日本强好片久久久久久aaa| www.久久久久久久久| 久久久亚洲午夜电影| 欧美a级理论片| 欧美三区在线视频| 亚洲视频免费在线| 国产999精品久久| 亚洲精品一区二区三区在线观看| 午夜精品久久久| 在线亚洲免费视频| 亚洲欧洲www| 国产福利一区二区三区在线视频| 69堂亚洲精品首页| 亚洲成人免费影院| 欧美优质美女网站| 最新国产成人在线观看| 国产成人a级片| 久久久久久综合| 激情av综合网| 精品国产亚洲在线| 久久精品久久综合| 欧美一区二区播放| 日韩精品视频网| 在线播放91灌醉迷j高跟美女| 一区二区三区不卡视频 | yourporn久久国产精品| 久久青草欧美一区二区三区| 狠狠狠色丁香婷婷综合久久五月| 日韩视频中午一区| 日本中文字幕一区二区视频| 777奇米四色成人影色区| 日韩黄色小视频| 欧美一区二区三区视频在线| 蜜臀va亚洲va欧美va天堂| 91精品国产高清一区二区三区蜜臀 | 日韩专区在线视频| 在线播放日韩导航| 美女视频黄久久| 欧美大片顶级少妇| 国产精品羞羞答答xxdd| 国产欧美一区二区三区鸳鸯浴| 风间由美性色一区二区三区| 中文字幕av免费专区久久| 成人av在线电影| 亚洲欧美国产毛片在线| 欧美日韩亚洲综合一区二区三区| 亚洲第一主播视频| 欧美一级日韩不卡播放免费| 美女爽到高潮91| 国产亚洲一本大道中文在线| 成人精品亚洲人成在线| 一区二区三区久久| 7777精品伊人久久久大香线蕉完整版 | 国产精品盗摄一区二区三区| 91在线你懂得| 亚洲18色成人| 精品国产凹凸成av人导航| 成人免费看的视频| 亚洲国产精品久久不卡毛片| 日韩三级精品电影久久久| 国产成人在线网站| 亚洲精品乱码久久久久久| 91精品国产综合久久精品app| 国产一区二区精品久久91| 国产精品国产自产拍高清av王其 | 99久久精品国产观看| 天天做天天摸天天爽国产一区| 精品国一区二区三区|