本帖最后由 freeelectron 于 2018-8-22 17:26 编辑 ! h9 s5 r0 H: q 背景:前一阵在支持客户的一个项目,据他们自己说是主要搞嵌入式linux的,现在需要用到LoRa,用stm32做了LoRa的板子,在官方的驱动的基础上,只改了GPIO,但是stm32与LoRa就是一直有问题,让他们用我们的试了试,是没问题的,之后看了他们的原理图,发现LoRa芯片的几个中断GPIO与stm32的连接上有问题。 LoRa除了需要SPi通讯外,还需要6个GPIO配置成外部中断,来产生接收中断,发送超时中断,发送完成中断,cad中断等等,这几个外部中断非常非常非常重要,如下图: STM32的每一个GPIO都可以配置成外部中断,但是对于初次接触的人,或者说是硬件设计的人来说,这里就需要注意了:8 a, T$ G9 ?4 L' m4 D. _$ U: ^& X h; J6 H" H b: c PA0~PG0 对应的是外部中断0 PA1~PG1 对应的是外部中断1& o& p1 |, B2 |/ ~ PA2~PG2 对应的是外部中断2 PA3~PG3 对应的是外部中断3 PA4~PG4 对应的是外部中断4: `; ?- ^( L7 R" P: | …… PA15~PG15 对应的是外部中断15 . x3 k/ W {; }: t) {( n/ Q9 h8 s 以外部中断0为例来说:同一时刻PA0~PG0只能有一个配置为外部中断。换句话说,STM32只能同时支持16个外部中断。(题外话,LoRa需要六个外部中断是见过的比较多的了,应用需要的外部中断大于16个,可能就要另辟蹊径了); f" [, H; C. d4 I, P t w) j G' Q; X; y. K: p& A9 a 可以看到官方的设计," B% l* O r( Y1 p! ^# s, H4 v1 g DIO5<->PA15 DIO4<->PB3& E# j* ~; E: k# h DIO3<->PB4 DIO2<->PB9, u2 |' m: L( n1 J, H DIO1<->PC13 DIO0<->PB11) E& `* I- {1 G 如下图:) W/ ]$ o1 U6 ]+ t( S 附件,semtech官方的设计原理图: |
5-9 共用一个中断函数 10-15也是共用一个中断函数
1,2,3,4可独立配置中断函数
5-9共用一个中断函数* [2 [- _9 o5 h0 B0 G1 k) G
10-15共用一个中断函数
用的1276不错;