RISCVDEBUG系列之三:RISCV的DM操作Jtag底层驱动实现

原创 嵌入式Lee 2025-03-11 22:36

一. 前言

前面我们介绍了Jtag的基本内容,以及RISCVDM操作数据流,基于以上我们现在开始就可以来实现RISCVDM底层操作的驱动了。

https://mp.weixin.qq.com/s/sx5uXW33MN3ELsxT-7TEZg

https://mp.weixin.qq.com/s/LJiMtDxwkwhXkywKlOoOrw?token=565259220&lang=zh_CN

二. JTAG操作接口

首先需要实现Jtag的操作, Jtag的时序参考前文介绍。Jtag的操作简单来说实际上就两个,一个是操作IR,一个是操作DR。所以底层接口实现也只需要提供这两个接口即可。

我这里考虑代码的可移植性,将Jtag的代码独立出来,只需要实现对应的IO操作即可移植。

Jtag.c/h完全可移植,Jtag_port.c/h实现IO操作接口。

JtagPport.h如下

#ifndef JTAG_PORT_H#define JTAG_PORT_H #ifdef __cplusplusextern "C" {#endif #include  void jtag_port_io_init(void);uint8_t jtag_port_get_tdo(void);void jtag_port_set_tdi(uint8_t tdi);void jtag_port_set_tck(void);void jtag_port_clr_tck(void);void jtag_port_set_tms(void);void jtag_port_clr_tms(void); #define JTAG_TDI_OUT(bit) jtag_port_set_tdi(bit)#define JTAG_TDO_IN()  jtag_port_get_tdo()#define JTAG_TCK_SET() jtag_port_set_tck()#define JTAG_TCK_CLR() jtag_port_clr_tck()#define JTAG_TMS_SET() jtag_port_set_tms()#define JTAG_TMS_CLR() jtag_port_clr_tms()#define JTAG_IO_DELAY()  #ifdef __cplusplus}#endif #endif

Jtag_port.c中实现对应的jtag_port_xxx接口。

这些接口后续优化速度时可以考虑再优化,比如使用汇编,使用宏替代函数调用,如果硬件支持IOSET,CLR则可以直接SETCLR而不需要读-修改-写的操作。

Jtag.h如下

#ifndef JTAG_H#define JTAG_H #ifdef __cplusplusextern "C" {#endif void jtag_reset_idle(void);void jtag_ir(uint32_t ir, int tckcnt);void jtag_dr(uint8_t* idr, uint8_t* odr, int tckcnt);void jtag_idle(int tckcnt);#ifdef __cplusplus}#endif #endif

Jtag.c实现如下

其中实现进入idle状态

/*  * \fn jtag_reset_idle * 复位到IDLE状态 * 任意状态保持TMS=1大于等于5个周期,进入RESET状态 * 然后一个周期TMS=0,进入IDLE状态 */void jtag_reset_idle(void){    int clk;    JTAG_TMS_SET(); /* TMS=1 */    /* 保持TMS=1 7个周期,确保进入RESET */    for(clk = 0; clk < 7; clk++){        JTAG_TCK_CLR();  /* 时钟默认为低,低部分 */        JTAG_IO_DELAY();        JTAG_TCK_SET();  /* 高部分 */        JTAG_IO_DELAY();    }    /* TMS=0 进入IDLE*/    JTAG_TMS_CLR();    JTAG_TCK_CLR();      JTAG_IO_DELAY();    JTAG_TCK_SET();     JTAG_IO_DELAY();}

操作之间的idle,DM操作之间,按照规范需要等待指定的idle个时钟

void jtag_idle(int tckcnt){        JTAG_TMS_CLR();        /* TMS=0 Idle */     while(tckcnt--){    JTAG_CYCLE_TCK();      }                                                                                                                              } 

不管时ir还是dr核心都是,tdi移入数据,tdo移出数据,如下

/** * \fn jtag_Sequence * TDI和TDO移入移出数据 * \param[in] tckcnt 需要移入移出的位数 * \param[in] tms 需要保持TMS的状态,1保持高,0保持低 * \param[in] tdi 需要TDI移入的数据 * \param[out] tdo 保存TDO移出的数据,可以为空 * \param[out] exit 1:最后一位执行EXIT1_DR/IR 0最后一位不执行EXIT1_DR/IR */static void jtag_sequence (uint32_t tckcnt, int tms, const uint8_t *tdi, uint8_t *tdo, int exit) {    uint8_t ibyte;    uint8_t obyte;    uint8_t ibit;    uint8_t obit;    uint32_t k;        if (0 == tms) {      JTAG_TMS_CLR();    } else {      JTAG_TMS_SET();    }      while (tckcnt) {      if(tdi != 0){        ibyte = *tdi++;      }else{        ibyte = 0xFF;      }      obyte = 0U;      for (k = 8U; k && tckcnt; k--, tckcnt--) {        /*         * tdi移入一位         * tdo移出一位         */        if((exit !=0) && (tckcnt == 1)){            JTAG_TMS_SET();  /* TMS=1 Set last DR/IR bit & Exit1-DR/IR */        }        ibit = ibyte & 0x01;        JTAG_TDI_OUT(ibit);                            JTAG_TCK_CLR();           JTAG_IO_DELAY();           obit = JTAG_TDO_IN();         JTAG_TCK_SET();                               JTAG_IO_DELAY();         /* 低位在前 */        ibyte >>= 1;        obyte >>= 1;        obyte |= obit << 7;      }      obyte >>= k;  /* 最后不足1字节处理 */      if (tdo != (uint8_t*)0) {        *tdo++ = (uint8_t)obyte;      }    }}

Ir的操作如下


/** * \fn jtag_ir * 选择IR并更新IR的值 * 假设当前位于IDLE状态 * \param[in] ir ir的值 * \param[in] tckcnt ir的位数 */void jtag_ir(uint32_t ir, int tckcnt){                                                                      JTAG_TMS_SET();                                                  JTAG_CYCLE_TCK();                         /* TMS=1 Select-DR-Scan */           JTAG_CYCLE_TCK();                         /* TMS=1 Select-IR-Scan */     JTAG_TMS_CLR();                                                                   JTAG_CYCLE_TCK();                         /* TMS=0 Capture-IR */                    JTAG_CYCLE_TCK();                         /* TMS=0 Shift-IR */                                                                                                         for (; tckcnt>1; tckcnt--) {       JTAG_CYCLE_TDI(ir&0x01);                /* TMS=0 Set IR bits (except last) */           ir >>= 1;                                                                       }                                                                                                                                            JTAG_TMS_SET();                                                                  JTAG_CYCLE_TDI(ir&0x01);                  /* TMS=1 Set last IR bit & Exit1-IR */                                                                                                                                                                JTAG_CYCLE_TCK();                         /* TMS=1 Update-IR */                        JTAG_TMS_CLR();                                                                   JTAG_CYCLE_TCK();                         /* TMS=0 Idle */                             JTAG_TDI_OUT(1U);                                                             }  

Dr的操作如下


/** * \fn jtag_dr * 选择DR并移入移出DR的值 * 假设当前位于IDLE状态 * \param[in] idr 待移入dr的值 * \param[in] odr 待移出dr的值 * \param[in] tckcnt dr的位数 */void jtag_dr(uint8_t* idr, uint8_t* odr, int tckcnt){          uint32_t n;                                                                    JTAG_TMS_SET();                                                  JTAG_CYCLE_TCK();                         /* TMS=1 Select-DR-Scan */            JTAG_TMS_CLR();                                                                   JTAG_CYCLE_TCK();                         /* TMS=0 Capture-DR */                    JTAG_CYCLE_TCK();                         /* TMS=0 Shift-DR */                                                           /* TMS=0 Set DR bits (except last) */           jtag_sequence (tckcnt, 0, idr, odr, 1); /* TMS=1 Set last DR bit & Exit1-DR */                                                                                                                                                                                                                        JTAG_CYCLE_TCK();                         /* TMS=1 Update-DR */      JTAG_TMS_CLR();                                                                   JTAG_CYCLE_TCK();                         /* TMS=0 Idle */         JTAG_TDI_OUT(1U);                                                             }

其中irdr的移入移出时需要注意,第一个进入shift状态时的CLK不是数据,后一个才是,最后EXIT1时是最后一位数据。

这里都是使用低位在前,默认CLK低,下降沿输出数据,上升沿采样。

后续也可以考虑上述参数可配置。

为了方便还定义了一些基本操作宏

#include #include "jtag.h"#include "jtag_port.h" #define JTAG_CYCLE_TCK()                \  JTAG_TCK_CLR();                       \  JTAG_IO_DELAY();                      \  JTAG_TCK_SET();                       \  JTAG_IO_DELAY() #define JTAG_CYCLE_TDI(tdi)             \  JTAG_TDI_OUT(tdi);                    \  JTAG_TCK_CLR();                       \  JTAG_IO_DELAY();                      \  JTAG_TCK_SET();                       \  JTAG_IO_DELAY()

以上irdr操作对照以下流程来即可。

三. RISCV-DEBUG操作接口

数据流参考前文。 简单来说就是选择ir寄存器,然后操作dr

这里实现见riscv_debug.c/h,依赖jtag.c/h完全可移植。

Riscv_debug.h如下,即对应riscv dm的几个寄存器的操作,其中ir=0x01dr表示IDCODEir=0x10dr表示dtmcsir=0x11dr表示dmi


#ifndef RISC_DEBUG_H#define RISC_DEBUG_H #ifdef __cplusplusextern "C" {#endif #include "jtag.h" #define RISCV_DEBUG_IDCODE 0x01#define RISCV_DEBUG_IDCODE_BITS 32 #define RISCV_DEBUG_DTMCS 0x10#define RISCV_DEBUG_DTMCS_BITS 32 #define RISCV_DEBUG_DMI 0x11 typedef struct{    uint32_t address;    uint32_t data;    uint8_t  op;    uint8_t abits;}riscv_debug_dmi_st; void riscv_debug_reset(void);uint32_t riscv_debug_get_idcode(void);uint32_t riscv_debug_get_dtmcs(void);void riscv_debug_dtmhardreset(void);void riscv_debug_dmireset(void);void riscv_debug_dmi(riscv_debug_dmi_st* in, riscv_debug_dmi_st* out, int idle); #ifdef __cplusplus}#endif #endif

riscv_debug.c实现如下,寄存器的定义可以参考riscv debug的规格书,这里实际上不需要每次都重新选择ir,只需要ir变化时才需要重新选择,这样可以优化速度,这里后面优化速度时再修改。


#include #include "riscv_debug.h" void riscv_debug_reset(void){  jtag_reset_idle();} /** * 31   28 |27      12 |11    1 | 0 * Version |PartNumber |ManufId | 1 *   4     |    16     |11      | 1 */uint32_t riscv_debug_get_idcode(void){  uint32_t idcode;  jtag_ir(RISCV_DEBUG_IDCODE, 5);  jtag_dr(0, (uint8_t*)&idcode, RISCV_DEBUG_IDCODE_BITS);  return idcode;} /** * 31 21 | 20   18 |     17      |  16     | 15 |14  12 | 11   10 | 9   4 | 3     0 *   0   | errinfo | dtmhardreset| dmireset| 0  | idle  | dmistat | abits | version *  11   |  3      |      1      |    1    | 1  |   3   |    2    |   6   |   4 */uint32_t riscv_debug_get_dtmcs(void){  uint32_t dtmcs;  jtag_ir(RISCV_DEBUG_DTMCS, 5);  jtag_dr(0, (uint8_t*)&dtmcs, RISCV_DEBUG_DTMCS_BITS);  return dtmcs;} void riscv_debug_dtmhardreset(void){  uint32_t dtmcs = 1u<<17;  jtag_ir(RISCV_DEBUG_DTMCS, 5);  jtag_dr((uint8_t*)&dtmcs, 0,RISCV_DEBUG_DTMCS_BITS);  return dtmcs;} void riscv_debug_dmireset(void){  uint32_t dtmcs = 1u<<16;  jtag_ir(RISCV_DEBUG_DTMCS, 5);  jtag_dr((uint8_t*)&dtmcs, 0,RISCV_DEBUG_DTMCS_BITS);  return dtmcs;} /** * abits+33 34 | 33 2 | 1 0 *   address   | data | op *   abits     |  32  | 2 *                    | 0(nop)  0(success) *                    | 1(read) 1(reserved) *                    | 2(write) 2(failed) *                    | 3(reserved) 3(busy) */void riscv_debug_dmi(riscv_debug_dmi_st* in, riscv_debug_dmi_st* out, int idle){  uint64_t tdi = 0;  uint64_t tdo = 0;  tdi = (uint64_t)in->op & 0x03;  tdi |= (uint64_t)(in->data)<<2;  tdi |= (uint64_t)(in->address)<<34;   jtag_ir(RISCV_DEBUG_DMI, 5);  jtag_dr((uint8_t*)&tdi, (uint8_t*)&tdo, in->abits + 34);  jtag_idle(idle);  out->op = tdo & 0x03;  out->data = (tdo >>2) & 0xFFFFFFFF;  out->address = (tdo >>34);}

四. 测试

这里在shell中实现一下命令,shell实现可以参考公众号前面对应的文章。

这里实现了以下命令


static void riscvdebugresetfunc(uint8_t* param);static void riscvdebugidcodefunc(uint8_t* param);static void riscvdebugdtmcsfunc(uint8_t* param);static void riscvdebugdtmhardresetfunc(uint8_t* param);static void riscvdebugdmiresetfunc(uint8_t* param);static void riscvdebugdmifunc(uint8_t* param);   { (uint8_t*)"rvd_reset",    riscvdebugresetfunc, (uint8_t*)"rvd_reset"},   { (uint8_t*)"rvd_idcode",   riscvdebugidcodefunc, (uint8_t*)"rvd_idcode"},   { (uint8_t*)"rvd_dtmcs",    riscvdebugdtmcsfunc, (uint8_t*)"rvd_dtmcs"},   { (uint8_t*)"rvd_dtmhardreset",    riscvdebugdtmhardresetfunc, (uint8_t*)"rvd_dtmhardreset"},   { (uint8_t*)"rvd_dmireset",    riscvdebugdmiresetfunc, (uint8_t*)"rvd_dmireset"},   { (uint8_t*)"rvd_dmi",    riscvdebugdmifunc, (uint8_t*)"rvd_dmi abits address[hex] data[hex] op idle"},   static void riscvdebugresetfunc(uint8_t* param){  (void)param;  riscv_debug_reset();} static void riscvdebugidcodefunc(uint8_t* param){  (void)param;  uint32_t idcode = riscv_debug_get_idcode();  xprintf("idcode:0x%x\r\n",idcode);} static void riscvdebugdtmcsfunc(uint8_t* param){  (void)param;  uint32_t dtmcs = riscv_debug_get_dtmcs();  xprintf("dtmcs:0x%x\r\n",dtmcs);} static void riscvdebugdtmhardresetfunc(uint8_t* param){  (void)param;  riscv_debug_dtmhardreset();} static void riscvdebugdmiresetfunc(uint8_t* param){  (void)param;  riscv_debug_dmireset();} static void riscvdebugdmifunc(uint8_t* param){  int abits;  uint32_t addr;  uint32_t data;  int op;  int idle;  riscv_debug_dmi_st in;  riscv_debug_dmi_st out;   if(5 == sscanf((const char*)param, "%*s %d %lx %lx %d %d", &abits, &addr, &data, &op, &idle))  {    xprintf("[in]:\r\n");    in.abits = abits;    in.address = addr;    in.data = data;    in.op = op;    xprintf("abits:%d,addr:0x%x,data:0x%x,op:%d,idle:%d\r\n",abits,addr,data,op,idle);    riscv_debug_dmi(&in, &out, idle);    xprintf("[out]:\r\n");    xprintf("addr:0x%x,data:0x%x,op:%d\r\n",out.address,out.data,out.op);  }}

然后注意测试上述命令,用逻辑分析仪住区对应的波形。

4.1进入IDLE状态

4.2IDCODE

4.3DTMCS操作接口

4.3.1dtmcs

4.3.2 Dtmhardreset

4.3.3Dmireset

rvd_dmireset

4.4 DMI寄存器读写(dmactive为例)

0x10 dmcontrol寄存器为例

需要先写bit00,查询等待该位为0

再写1,查询等待该位位1

4.4.1dmactive写为0查询等待回读0

WRITE-NOP-READ-NOP

0

Nop查看


0x10

此时还读不到值,需要nop一次回读值,看到确实变为了0

4.4.2dmactive写为1查询等待回读1

WRITE-NOP-READ-NOP

先写1

NOP

READ

NOP,此时可以看到bit1置位为了1

五.总结

以上实现了riacv debugjtag底层操作接口,驱动分为两层,最底层是jtag的操作接口,移植对应的io操作即可,主要是irdr的操作,这个是jtag标准,所以也可以移植适用于任何其他使用jtag的地方。然后在此之上,实现了riscv debug中规定的idcodedtmcsdmi操作的接口,基于此就可以实现任意的riscv debug操作了。

理论上基于此底层接口,我们只需要关注应用层,就可以实现我们自己的调试工具了。比如适配OpenOCD,甚至也可以自己做一套上位机调试工具。 























评论 (0)
  • 引言:老龄化社会的健康守护需求随着全球老龄化进程加速,老年人的健康管理与生活质量成为社会焦点。记忆衰退、用药混乱、日程遗漏等问题频发,催生了智能健康设备的市场需求。WTR096录音语音芯片,凭借其高度集成的录放音、计时时钟与计划管理功能,为老年人量身打造了一站式健康管理方案,重新定义智能语音时钟的价值。功能亮点:1. 用药安全守护:多维度提醒,拒绝遗忘多时段精准提醒:支持一天内设置多个用药时间(如早、中、晚),适配复杂用药需求。个性化语音定制:家属可录制专属提醒语音(如“上午9点,请服用降压药”
    广州唯创电子 2025-04-22 08:41 107浏览
  •   北京华盛恒辉机场保障能力评估系统软件深度解析   在航空运输业快速发展的背景下,机场保障任务愈发复杂,传统人工评估方式已无法满足高效精准的管理需求。机场保障能力评估系统软件作为提升机场运行效率、保障飞行安全的关键工具,其重要性日益凸显。   应用案例   目前,已有多个机场保障能力评估系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润机场保障能力评估系统。这些成功案例为机场保障能力评估系统的推广和应用提供了有力支持。   一、系统功能模块   数据采集与整合模块  
    华盛恒辉l58ll334744 2025-04-22 10:28 119浏览
  •   电磁干扰抑制系统平台深度解析   一、系统概述   北京华盛恒辉电磁干扰抑制系统在电子技术快速发展、电磁环境愈发复杂的背景下,电磁干扰(EMI)严重影响电子设备性能、稳定性与安全性。电磁干扰抑制系统平台作为综合性解决方案,通过整合多元技术手段,实现对电磁干扰的高效抑制,确保电子设备稳定运行。   应用案例   目前,已有多个电磁干扰抑制系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润电磁干扰抑制系统。这些成功案例为电磁干扰抑制系统的推广和应用提供了有力支持。   二
    华盛恒辉l58ll334744 2025-04-22 15:27 134浏览
  • 据国际精益六西格玛研究所(ILSSI)成员大卫·哈钦斯(David Hutchins)的回忆,在“六西格玛”名称出现前,摩托罗拉组建了约100个质量改进团队,接受朱兰博士制作的16盘录像带培训,名为《朱兰论质量改进》(Juran on Quality Improvement),为了推广这种严谨的分析方法(朱兰博士视频中的核心内容),摩托罗拉前首席执行官鲍勃·加尔文创造了“六西格玛”这一标签,用以表彰这种“最顶尖"的方法。大卫·哈钦斯(David Hutchins)是朱兰博士的好友,也为他的工作做
    优思学院 2025-04-22 12:03 102浏览
  •   电磁兼容故障诊断系统平台深度解析   北京华盛恒辉电磁兼容(EMC)故障诊断系统平台是解决电子设备在复杂电磁环境下性能异常的核心工具。随着电子设备集成度提升与电磁环境复杂化,EMC 问题直接影响设备可靠性与安全性。以下从平台架构、核心功能、技术实现、应用场景及发展趋势展开全面剖析。   应用案例   目前,已有多个电磁兼容故障诊断系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润电磁兼容故障诊断系统。这些成功案例为电磁兼容故障诊断系统的推广和应用提供了有力支持。  
    华盛恒辉l58ll334744 2025-04-22 14:29 144浏览
  •   电磁兼容(EMC)故障诊断系统软件解析   北京华盛恒辉电磁兼容故障诊断系统软件是攻克电子设备电磁干扰难题的专业利器。在电子设备复杂度攀升、电磁兼容问题频发的背景下,该软件于研发、测试、生产全流程中占据关键地位。以下为其详细介绍:   应用案例   目前,已有多个电磁兼容故障诊断系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润电磁兼容故障诊断系统。这些成功案例为电磁兼容故障诊断系统的推广和应用提供了有力支持。   一、软件核心功能   干扰与敏感分析:深度剖析电磁干
    华盛恒辉l58ll334744 2025-04-22 14:53 118浏览
  •   北京华盛恒辉基于GIS的电磁态势可视化系统软件是将地理空间信息与电磁态势数据相结合,通过图形化手段直观展示电磁环境态势的系统。这类软件在军事、通信、无线电管理等领域具有广泛应用,能够辅助用户进行电磁频谱分析、干扰监测、态势研判和决策支持。以下是关于此类系统的详细介绍:   应用案例   目前,已有多个电磁态势可视化系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润电磁态势可视化系统。这些成功案例为电磁态势可视化系统的推广和应用提供了有力支持。   一、系统功能   电磁
    华盛恒辉l58ll334744 2025-04-22 11:44 94浏览
  • 引言:工业安全与智能化需求的双重驱动在工业安全、环境保护及家庭安防领域,气体泄漏引发的安全事故始终是重大隐患。随着传感器技术、物联网及语音交互的快速发展,气体检测报警器正朝着智能化、低成本、高可靠的方向演进。WT588F02B-8S语音芯片,以“离在线语音更换+多协议通信”为核心优势,为气体检测报警器提供了一套高效、灵活的低成本语音解决方案,助力开发者快速响应市场需求。产品功能与市场需求1. 核心功能:从监测到预警的全流程覆盖实时气体监测:支持一氧化碳、臭氧、硫化氢等多种气体浓度检测,精度可达p
    广州唯创电子 2025-04-22 09:14 92浏览
  • 在汽车行业的变革浪潮中,智界汽车的诞生备受瞩目。作为华为与奇瑞两大巨头携手合作的结晶,智界汽车自孕育之初便承载着众人的期待,被视为融合前沿科技与卓越制造的典范,有望在竞争激烈的新能源汽车市场中开辟出一片新天地。2024年,智界品牌首款车型智界S7正式上市,凭借华为的技术赋能,如先进的鸿蒙智能座舱、强大的HUAWEI ADS高阶智能驾驶辅助系统,以及奇瑞多年积累的深厚造车底蕴,在上市前赚足了眼球。智界S7的亮相,犹如一颗投入平静湖面的石子,激起了层层涟漪,消费者对其充满了好奇与期待,行业内也纷纷将
    用户1742991715177 2025-04-21 20:28 107浏览
  • 近期,金融界消息称,江西万年芯微电子有限公司申请一项名为“基于预真空腔体注塑的芯片塑封方法及芯片”的专利。此项创新工艺的申请,标志着万年芯在高端芯片封装领域取得重要突破,为半导体产业链提升注入了新动能。专利摘要显示,本发明公开了一种基于预真空腔体注塑的芯片塑封方法,方法包括将待塑封的大尺寸芯片平铺于下模盒腔体内的基板并将大尺寸芯片的背向表面直接放置于基板上以进行基板吸附;将上模盒盖合于下模盒形成塑封腔,根据基板将塑封腔分为上型腔以及下型腔;将下型腔内壁与大尺寸芯片间的空隙进行树脂填充;通过设置于
    万年芯 2025-04-22 13:28 86浏览
  • 4 月 19 日,“增长无界・智领未来” 第十六届牛商大会暨电子商务十大牛商成果报告会在深圳凤凰大厦盛大举行。河南业之峰科技股份有限公司总经理段利强——誉峰变频器强哥凭借在变频器领域的卓越成就,荣膺第十六届电子商务十大牛商,携誉峰变频器品牌惊艳亮相,以十几年如一日的深耕与创新,书写着行业传奇。图 1:誉峰变频器强哥在牛商大会领奖现场,荣耀时刻定格牛商大会现场,誉峰变频器强哥接受了多家媒体的专访。面对镜头,他从容分享了自己在变频器行业二十年的奋斗历程与心路感悟。谈及全域营销战略的成功,誉峰变频器强
    电子与消费 2025-04-22 13:22 121浏览
  •   卫星通信效能评估系统平台全面解析   北京华盛恒辉卫星通信效能评估系统平台是衡量卫星通信系统性能、优化资源配置、保障通信服务质量的关键技术工具。随着卫星通信技术的快速发展,特别是低轨卫星星座、高通量卫星和软件定义卫星的广泛应用,效能评估系统平台的重要性日益凸显。以下从技术架构、评估指标、关键技术、应用场景及发展趋势五个维度进行全面解析。   应用案例   目前,已有多个卫星通信效能评估系统在实际应用中取得了显著成效。例如,北京华盛恒辉和北京五木恒润卫星通信效能评估系统。这些成功案例为卫
    华盛恒辉l58ll334744 2025-04-22 16:34 102浏览
  • 在消费金融的赛道上,马上消费曾是备受瞩目的明星企业。自2015年成立以来,它以年均 30% 的净利润增速一路狂奔,成为持牌消费金融公司的标杆,2023年更是斩获19.82亿元净利润,风光无限。然而,2024年却成了马上消费的一道分水岭。2024年上半年,其营收为77.38亿元,同比下降2.11%;净利润更是同比骤降20.66%,仅为10.68亿元,创下历史最大跌幅 。与此同时,不良贷款率攀升至2.5%,不良余额高达16.54亿元,核心资本充足率降至12.72%,融资
    用户1742991715177 2025-04-21 21:29 123浏览
我要评论
0
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦