专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
STM32
谁有 mp3的解码库啊 ?
2019-12-27 19:04
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
STM32/STM8
8058
28
28
谁有 mp3的解码库啊 ?
28条回答
mowin
2019-12-30 08:58
#elif defined(EWARM) /* mowin add */
#define __inline inline
/*
* MULSHIFT32(x, y) signed multiply of two 32-bit integers (x and y), returns top 32 bits of 64-bit result
* FASTABS(x) branchless absolute value of signed integer x
* CLZ(x) count leading zeros in x
* MADD64(sum, x, y) (Windows only) sum [64-bit] += x [32-bit] * y [32-bit]
* SHL64(sum, x, y) (Windows only) 64-bit left shift using __int64
* SAR64(sum, x, y) (Windows only) 64-bit right shift using __int64 */
/* 1 MULSHIFT32 */
static long MULSHIFT32(long x, long y)
{
Word64 r = (Word64)x * y;
return (r >> 32);
}
/* 2 FASTABS */
static __inline int FASTABS(int x)
{
int sign;
sign = x >> (sizeof(int) * 8 - 1);
x ^= sign;
x -= sign;
return x;
}
/* 3 CLZ */
#include "stm32f4xx.h" /* mowin 2016-12-12 */
static __inline int CLZ(int x)
{
return __CLZ(x);
}
/* 4 MADD64 */
static __inline Word64 MADD64(Word64 sum64, int x, int y)
{
return (Word64)x * y + sum64;
}
/* 5 SHL64 */
/* 6 SAR64 */
static __inline Word64 SAR64(Word64 x, int n)
{
return x >> n;
}
复制代码
加载中...
查看其它28个回答
一周热门
更多
>
相关问题
STM32F4上I2C(在PROTEUS中模拟)调试不通的问题
6 个回答
芯片供应紧张,准备换个MCU,MM32L系列替换STM32L系列的怎么样?
7 个回答
STM32同时使用两个串口进行数据收发时数据丢包的问题
5 个回答
STM32F103串口通信死机问题
4 个回答
STM32WLE5CC连接SX1268在LoRa模式下能与 SX1278互通吗?
2 个回答
相关文章
ST公司第一款无线低功耗单片机模块有效提高物联网设计生产效率
0个评论
如何实现对单片机寄存器的访问
0个评论
通过USB用STM32片内自带Bootloader下载程序及注意事项
0个评论
欲练此功必先自宫之STM32汇编启动,放慢是为了更好的前行
0个评论
×
关闭
采纳回答
向帮助了您的知道网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
STM32
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
×
付费偷看金额在0.1-10元之间
确定
×
关闭
您已邀请
0
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
- #elif defined(EWARM) /* mowin add */
- #define __inline inline
- /*
- * MULSHIFT32(x, y) signed multiply of two 32-bit integers (x and y), returns top 32 bits of 64-bit result
- * FASTABS(x) branchless absolute value of signed integer x
- * CLZ(x) count leading zeros in x
- * MADD64(sum, x, y) (Windows only) sum [64-bit] += x [32-bit] * y [32-bit]
- * SHL64(sum, x, y) (Windows only) 64-bit left shift using __int64
- * SAR64(sum, x, y) (Windows only) 64-bit right shift using __int64 */
- /* 1 MULSHIFT32 */
- static long MULSHIFT32(long x, long y)
- {
- Word64 r = (Word64)x * y;
- return (r >> 32);
- }
- /* 2 FASTABS */
- static __inline int FASTABS(int x)
- {
- int sign;
- sign = x >> (sizeof(int) * 8 - 1);
- x ^= sign;
- x -= sign;
- return x;
- }
- /* 3 CLZ */
- #include "stm32f4xx.h" /* mowin 2016-12-12 */
- static __inline int CLZ(int x)
- {
- return __CLZ(x);
- }
- /* 4 MADD64 */
- static __inline Word64 MADD64(Word64 sum64, int x, int y)
- {
- return (Word64)x * y + sum64;
- }
- /* 5 SHL64 */
- /* 6 SAR64 */
- static __inline Word64 SAR64(Word64 x, int n)
- {
- return x >> n;
- }
复制代码一周热门 更多>