1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
1101
1102
1103
1104
1105
1106
1107
1108
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
1124
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148
1149
1150
1151
1152
1153
1154
1155
1156
1157
1158
1159
1160
1161
1162
1163
1164
1165
1166
1167
1168
1169
1170
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
1196
1197
1198
1199
1200
1201
1202
1203
1204
1205
1206
1207
1208
1209
1210
1211
1212
1213
1214
1215
1216
1217
1218
1219
1220
1221
1222
1223
1224
1225
1226
1227
1228
1229
1230
1231
1232
1233
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243
1244
1245
1246
1247
1248
1249
1250
1251
1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
1270
1271
1272
1273
1274
1275
1276
1277
1278
1279
1280
1281
1282
1283
1284
1285
1286
1287
1288
1289
1290
1291
1292
1293
1294
1295
1296
1297
1298
1299
1300
1301
1302
1303
1304
1305
1306
1307
1308
1309
1310
1311
1312
1313
1314
1315
1316
1317
1318
1319
1320
1321
1322
1323
1324
1325
1326
1327
1328
1329
1330
1331
1332
1333
1334
1335
1336
1337
1338
1339
1340
1341
1342
1343
1344
1345
1346
1347
1348
1349
1350
1351
1352
1353
1354
1355
1356
1357
1358
1359
1360
1361
1362
1363
1364
1365
1366
1367
1368
1369
1370
1371
1372
1373
1374
1375
1376
1377
1378
1379
1380
1381
1382
1383
1384
1385
1386
1387
1388
1389
1390
1391
1392
1393
1394
1395
1396
1397
1398
1399
1400
1401
1402
1403
1404
1405
1406
1407
1408
1409
1410
1411
1412
1413
1414
1415
1416
1417
1418
1419
1420
1421
1422
1423
1424
1425
1426
1427
1428
1429
1430
1431
1432
1433
1434
1435
1436
1437
1438
1439
1440
1441
1442
1443
1444
1445
1446
1447
1448
1449
1450
1451
1452
1453
1454
1455
1456
1457
1458
1459
1460
1461
1462
1463
1464
1465
1466
1467
1468
1469
1470
1471
1472
1473
1474
1475
1476
1477
1478
1479
1480
1481
1482
1483
1484
1485
1486
1487
1488
1489
1490
1491
1492
1493
1494
1495
1496
1497
1498
1499
1500
1501
1502
1503
1504
1505
1506
1507
1508
1509
1510
1511
1512
1513
1514
1515
1516
1517
1518
1519
1520
1521
1522
1523
1524
1525
1526
1527
1528
1529
1530
1531
1532
1533
1534
1535
1536
1537
1538
1539
1540
1541
1542
1543
1544
1545
1546
1547
1548
1549
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560
1561
1562
1563
1564
1565
1566
1567
1568
1569
1570
1571
1572
1573
1574
1575
1576
1577
1578
1579
1580
1581
1582
1583
1584
1585
1586
1587
1588
1589
1590
1591
1592
1593
1594
1595
1596
1597
1598
1599
1600
1601
1602
1603
1604
1605
1606
1607
1608
1609
1610
1611
1612
1613
1614
1615
1616
1617
1618
1619
1620
1621
1622
1623
1624
1625
1626
1627
1628
1629
1630
1631
1632
1633
1634
1635
1636
1637
1638
1639
1640
1641
1642
1643
1644
1645
1646
1647
1648
1649
1650
1651
1652
1653
1654
1655
1656
1657
1658
1659
1660
1661
1662
1663
1664
1665
1666
1667
1668
1669
1670
1671
1672
1673
1674
1675
1676
1677
1678
1679
1680
1681
1682
1683
1684
1685
1686
1687
1688
1689
1690
1691
1692
1693
1694
1695
1696
1697
1698
1699
1700
1701
1702
1703
1704
1705
1706
1707
1708
1709
1710
1711
1712
1713
1714
1715
1716
1717
1718
1719
1720
1721
1722
1723
1724
1725
1726
1727
1728
1729
1730
1731
1732
1733
1734
1735
1736
1737
1738
1739
1740
1741
1742
1743
1744
1745
1746
1747
1748
1749
1750
1751
1752
1753
1754
1755
1756
1757
1758
1759
1760
1761
1762
1763
1764
1765
1766
1767
1768
1769
1770
1771
1772
1773
1774
1775
1776
1777
1778
1779
1780
1781
1782
1783
1784
1785
1786
1787
1788
1789
1790
1791
1792
1793
1794
1795
1796
1797
1798
1799
1800
1801
1802
1803
1804
1805
1806
1807
1808
1809
1810
1811
1812
1813
1814
1815
1816
1817
1818
1819
1820
1821
1822
1823
1824
1825
1826
1827
1828
1829
1830
1831
1832
1833
1834
1835
1836
1837
1838
1839
1840
1841
1842
1843
1844
1845
1846
1847
1848
1849
1850
1851
1852
1853
1854
1855
1856
1857
1858
1859
1860
1861
1862
1863
1864
1865
1866
1867
1868
1869
1870
1871
1872
1873
1874
1875
1876
1877
1878
1879
1880
1881
1882
1883
1884
1885
1886
1887
1888
1889
1890
1891
1892
1893
1894
1895
1896
1897
1898
1899
1900
1901
1902
1903
1904
1905
1906
1907
1908
1909
1910
1911
1912
1913
1914
1915
1916
1917
1918
1919
1920
1921
1922
1923
1924
1925
1926
1927
1928
1929
1930
1931
1932
1933
1934
1935
1936
1937
1938
1939
1940
1941
1942
1943
1944
1945
1946
1947
1948
1949
1950
1951
1952
1953
1954
1955
1956
1957
1958
1959
1960
1961
1962
1963
1964
1965
1966
1967
1968
1969
1970
1971
1972
1973
1974
1975
1976
1977
1978
1979
1980
1981
1982
1983
1984
1985
1986
1987
1988
1989
1990
1991
1992
1993
1994
1995
1996
1997
1998
1999
2000
2001
2002
2003
2004
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
2026
2027
2028
2029
2030
2031
2032
2033
2034
2035
2036
2037
2038
2039
2040
2041
2042
2043
2044
2045
2046
2047
2048
2049
2050
2051
2052
2053
2054
2055
2056
2057
2058
2059
2060
2061
2062
2063
2064
2065
2066
2067
2068
2069
2070
2071
2072
2073
2074
2075
2076
2077
2078
2079
2080
2081
2082
2083
2084
2085
2086
2087
2088
2089
2090
2091
2092
2093
2094
2095
2096
2097
2098
|
ARM GAS /tmp/ccRWo4B1.s page 1
1 .cpu cortex-m0
2 .eabi_attribute 20, 1
3 .eabi_attribute 21, 1
4 .eabi_attribute 23, 3
5 .eabi_attribute 24, 1
6 .eabi_attribute 25, 1
7 .eabi_attribute 26, 1
8 .eabi_attribute 30, 1
9 .eabi_attribute 34, 0
10 .eabi_attribute 18, 4
11 .file "main.c"
12 .text
13 .Ltext0:
14 .cfi_sections .debug_frame
15 .section .text.MX_GPIO_Init,"ax",%progbits
16 .align 1
17 .syntax unified
18 .code 16
19 .thumb_func
20 .fpu softvfp
22 MX_GPIO_Init:
23 .LFB52:
24 .file 1 "Src/main.c"
1:Src/main.c ****
2:Src/main.c **** #include "main.h"
3:Src/main.c **** #include "usb_device.h"
4:Src/main.c **** #include "usbd_hid.h"
5:Src/main.c ****
6:Src/main.c **** #define HID_MEDIA_REPORT 2
7:Src/main.c **** #define HYSTERESIS 200
8:Src/main.c **** ADC_HandleTypeDef hadc;
9:Src/main.c **** DMA_HandleTypeDef hdma_adc;
10:Src/main.c ****
11:Src/main.c **** PCD_HandleTypeDef hpcd_USB_FS;
12:Src/main.c ****
13:Src/main.c **** void SystemClock_Config(void);
14:Src/main.c **** static void MX_GPIO_Init(void);
15:Src/main.c **** static void MX_DMA_Init(void);
16:Src/main.c **** static void MX_ADC_Init(void);
17:Src/main.c **** static void MX_USB_PCD_Init(void);
18:Src/main.c ****
19:Src/main.c **** void sendVolDown(void);
20:Src/main.c **** void sendVolUp(void);
21:Src/main.c ****
22:Src/main.c **** struct keyboard_report_t
23:Src/main.c **** {
24:Src/main.c ****
25:Src/main.c **** uint8_t id;
26:Src/main.c ****
27:Src/main.c **** uint8_t modifier;
28:Src/main.c **** uint8_t reserved;
29:Src/main.c **** uint8_t keycode[6];
30:Src/main.c **** } kbd_report;
31:Src/main.c ****
32:Src/main.c **** uint16_t ADCreg[8];
33:Src/main.c **** uint16_t ADCval[8];
34:Src/main.c **** uint16_t ADClast[8];
ARM GAS /tmp/ccRWo4B1.s page 2
35:Src/main.c ****
36:Src/main.c **** int main(void)
37:Src/main.c **** {
38:Src/main.c **** HAL_Init();
39:Src/main.c ****
40:Src/main.c **** SystemClock_Config();
41:Src/main.c ****
42:Src/main.c **** MX_GPIO_Init();
43:Src/main.c **** MX_DMA_Init();
44:Src/main.c **** MX_ADC_Init();
45:Src/main.c **** MX_USB_HID_INIT();
46:Src/main.c ****
47:Src/main.c **** HAL_ADC_Start_DMA(&hadc, ADCreg, 8);
48:Src/main.c ****
49:Src/main.c **** while (1)
50:Src/main.c **** {
51:Src/main.c ****
52:Src/main.c ****
53:Src/main.c **** for(int i = 0; i < 8; i++){
54:Src/main.c **** ADCval[i] = ADCreg[i];
55:Src/main.c **** if(ADCval[i] - ADClast[i] > 2000 || ADClast[i] - ADCval[i] > 2000 ) ADClast[i] = ADCval[i];
56:Src/main.c **** }
57:Src/main.c ****
58:Src/main.c **** // Volume Dial 8
59:Src/main.c **** if(ADCval[0] >= ADClast[0] + HYSTERESIS){
60:Src/main.c **** sendVolUp();
61:Src/main.c **** ADClast[0] = ADCval[0];
62:Src/main.c **** } else if(ADCval[0] <= ADClast[0] - HYSTERESIS){
63:Src/main.c **** sendVolDown();
64:Src/main.c **** ADClast[0] = ADCval[0];
65:Src/main.c **** }
66:Src/main.c ****
67:Src/main.c **** // Dial 1
68:Src/main.c **** if(ADCval[1] >= ADClast[1] + HYSTERESIS){
69:Src/main.c **** } else if(ADCval[1] <= ADClast[1] - HYSTERESIS){
70:Src/main.c **** }
71:Src/main.c ****
72:Src/main.c **** // SwitchLayer
73:Src/main.c **** if(ADCval[2] >= ADClast[2] + HYSTERESIS){
74:Src/main.c **** kbd_send_ch('v');
75:Src/main.c **** ADClast[2] = ADCval[2];
76:Src/main.c **** } else if(ADCval[2] <= ADClast[2] - HYSTERESIS){
77:Src/main.c **** kbd_send_ch('v');
78:Src/main.c **** ADClast[2] = ADCval[2];
79:Src/main.c **** }
80:Src/main.c ****
81:Src/main.c **** // RotatePart Dial 3
82:Src/main.c **** if(ADCval[3] >= ADClast[3] + HYSTERESIS){
83:Src/main.c **** kbd_send_ch('R');
84:Src/main.c **** ADClast[3] = ADCval[3];
85:Src/main.c **** } else if(ADCval[3] <= ADClast[3] - HYSTERESIS){
86:Src/main.c **** kbd_send_ch('r');
87:Src/main.c **** ADClast[3] = ADCval[3];
88:Src/main.c **** }
89:Src/main.c ****
90:Src/main.c **** // Grid Dial 4
91:Src/main.c **** if(ADCval[4] >= ADClast[4] + HYSTERESIS){
ARM GAS /tmp/ccRWo4B1.s page 3
92:Src/main.c **** kbd_send_ch('n');
93:Src/main.c **** ADClast[4] = ADCval[4];
94:Src/main.c **** } else if(ADCval[4] <= ADClast[4] - HYSTERESIS){
95:Src/main.c **** kbd_send_ch('N');
96:Src/main.c **** ADClast[4] = ADCval[4];
97:Src/main.c **** }
98:Src/main.c ****
99:Src/main.c **** // via
100:Src/main.c **** if(ADCval[5] >= ADClast[5] + HYSTERESIS){
101:Src/main.c **** } else if(ADCval[5] <= ADClast[5] - HYSTERESIS){
102:Src/main.c **** }
103:Src/main.c ****
104:Src/main.c **** // Trackwidth Dial 6
105:Src/main.c **** if(ADCval[6] >= ADClast[6] + HYSTERESIS){
106:Src/main.c **** kbd_send_ch('w');
107:Src/main.c **** ADClast[6] = ADCval[6];
108:Src/main.c **** } else if(ADCval[6] <= ADClast[6] - HYSTERESIS){
109:Src/main.c **** kbd_send_ch('W');
110:Src/main.c **** ADClast[6] = ADCval[6];
111:Src/main.c **** }
112:Src/main.c ****
113:Src/main.c **** // zoom
114:Src/main.c **** if(ADCval[7] >= ADClast[7] + HYSTERESIS){
115:Src/main.c **** kbd_send_raw(0x3a);
116:Src/main.c **** ADClast[7] = ADCval[7];
117:Src/main.c **** } else if(ADCval[7] <= ADClast[7] - HYSTERESIS){
118:Src/main.c **** kbd_send_raw(0x3b);
119:Src/main.c **** ADClast[7] = ADCval[7];
120:Src/main.c **** }
121:Src/main.c ****
122:Src/main.c ****
123:Src/main.c **** //for(int i = 0; i < 8; i++){
124:Src/main.c **** // ADClast[i] = ADCval[i];
125:Src/main.c **** //}
126:Src/main.c **** HAL_Delay(10);
127:Src/main.c **** }
128:Src/main.c **** }
129:Src/main.c ****
130:Src/main.c ****
131:Src/main.c **** #define SHIFT 0x80
132:Src/main.c **** const uint8_t _asciimap[128] =
133:Src/main.c **** {
134:Src/main.c **** 0x00, // NUL
135:Src/main.c **** 0x00, // SOH
136:Src/main.c **** 0x00, // STX
137:Src/main.c **** 0x00, // ETX
138:Src/main.c **** 0x00, // EOT
139:Src/main.c **** 0x00, // ENQ
140:Src/main.c **** 0x00, // ACK
141:Src/main.c **** 0x00, // BEL
142:Src/main.c **** 0x2a, // BS Backspace
143:Src/main.c **** 0x2b, // TAB Tab
144:Src/main.c **** 0x28, // LF Enter
145:Src/main.c **** 0x00, // VT
146:Src/main.c **** 0x00, // FF
147:Src/main.c **** 0x00, // CR
148:Src/main.c **** 0x00, // SO
ARM GAS /tmp/ccRWo4B1.s page 4
149:Src/main.c **** 0x00, // SI
150:Src/main.c **** 0x00, // DEL
151:Src/main.c **** 0x00, // DC1
152:Src/main.c **** 0x00, // DC2
153:Src/main.c **** 0x00, // DC3
154:Src/main.c **** 0x00, // DC4
155:Src/main.c **** 0x00, // NAK
156:Src/main.c **** 0x00, // SYN
157:Src/main.c **** 0x00, // ETB
158:Src/main.c **** 0x00, // CAN
159:Src/main.c **** 0x00, // EM
160:Src/main.c **** 0x00, // SUB
161:Src/main.c **** 0x00, // ESC
162:Src/main.c **** 0x00, // FS
163:Src/main.c **** 0x00, // GS
164:Src/main.c **** 0x00, // RS
165:Src/main.c **** 0x00, // US
166:Src/main.c ****
167:Src/main.c **** 0x2c, // ' '
168:Src/main.c **** 0x1e|SHIFT, // !
169:Src/main.c **** 0x34|SHIFT, // "
170:Src/main.c **** 0x20|SHIFT, // #
171:Src/main.c **** 0x21|SHIFT, // $
172:Src/main.c **** 0x22|SHIFT, // %
173:Src/main.c **** 0x24|SHIFT, // &
174:Src/main.c **** 0x34, // '
175:Src/main.c **** 0x26|SHIFT, // (
176:Src/main.c **** 0x27|SHIFT, // )
177:Src/main.c **** 0x25|SHIFT, // *
178:Src/main.c **** 0x2e|SHIFT, // +
179:Src/main.c **** 0x36, // ,
180:Src/main.c **** 0x2d, // -
181:Src/main.c **** 0x37, // .
182:Src/main.c **** 0x38, // /
183:Src/main.c **** 0x27, // 0
184:Src/main.c **** 0x1e, // 1
185:Src/main.c **** 0x1f, // 2
186:Src/main.c **** 0x20, // 3
187:Src/main.c **** 0x21, // 4
188:Src/main.c **** 0x22, // 5
189:Src/main.c **** 0x23, // 6
190:Src/main.c **** 0x24, // 7
191:Src/main.c **** 0x25, // 8
192:Src/main.c **** 0x26, // 9
193:Src/main.c **** 0x33|SHIFT, // :
194:Src/main.c **** 0x33, // ;
195:Src/main.c **** 0x36|SHIFT, // <
196:Src/main.c **** 0x2e, // =
197:Src/main.c **** 0x37|SHIFT, // >
198:Src/main.c **** 0x38|SHIFT, // ?
199:Src/main.c **** 0x1f|SHIFT, // @
200:Src/main.c **** 0x04|SHIFT, // A
201:Src/main.c **** 0x05|SHIFT, // B
202:Src/main.c **** 0x06|SHIFT, // C
203:Src/main.c **** 0x07|SHIFT, // D
204:Src/main.c **** 0x08|SHIFT, // E
205:Src/main.c **** 0x09|SHIFT, // F
ARM GAS /tmp/ccRWo4B1.s page 5
206:Src/main.c **** 0x0a|SHIFT, // G
207:Src/main.c **** 0x0b|SHIFT, // H
208:Src/main.c **** 0x0c|SHIFT, // I
209:Src/main.c **** 0x0d|SHIFT, // J
210:Src/main.c **** 0x0e|SHIFT, // K
211:Src/main.c **** 0x0f|SHIFT, // L
212:Src/main.c **** 0x10|SHIFT, // M
213:Src/main.c **** 0x11|SHIFT, // N
214:Src/main.c **** 0x12|SHIFT, // O
215:Src/main.c **** 0x13|SHIFT, // P
216:Src/main.c **** 0x14|SHIFT, // Q
217:Src/main.c **** 0x15|SHIFT, // R
218:Src/main.c **** 0x16|SHIFT, // S
219:Src/main.c **** 0x17|SHIFT, // T
220:Src/main.c **** 0x18|SHIFT, // U
221:Src/main.c **** 0x19|SHIFT, // V
222:Src/main.c **** 0x1a|SHIFT, // W
223:Src/main.c **** 0x1b|SHIFT, // X
224:Src/main.c **** 0x1c|SHIFT, // Y
225:Src/main.c **** 0x1d|SHIFT, // Z
226:Src/main.c **** 0x2f, // [
227:Src/main.c **** 0x31, // bslash
228:Src/main.c **** 0x30, // ]
229:Src/main.c **** 0x23|SHIFT, // ^
230:Src/main.c **** 0x2d|SHIFT, // _
231:Src/main.c **** 0x35, // `
232:Src/main.c **** 0x04, // a
233:Src/main.c **** 0x05, // b
234:Src/main.c **** 0x06, // c
235:Src/main.c **** 0x07, // d
236:Src/main.c **** 0x08, // e
237:Src/main.c **** 0x09, // f
238:Src/main.c **** 0x0a, // g
239:Src/main.c **** 0x0b, // h
240:Src/main.c **** 0x0c, // i
241:Src/main.c **** 0x0d, // j
242:Src/main.c **** 0x0e, // k
243:Src/main.c **** 0x0f, // l
244:Src/main.c **** 0x10, // m
245:Src/main.c **** 0x11, // n
246:Src/main.c **** 0x12, // o
247:Src/main.c **** 0x13, // p
248:Src/main.c **** 0x14, // q
249:Src/main.c **** 0x15, // r
250:Src/main.c **** 0x16, // s
251:Src/main.c **** 0x17, // t
252:Src/main.c **** 0x18, // u
253:Src/main.c **** 0x19, // v
254:Src/main.c **** 0x1a, // w
255:Src/main.c **** 0x1b, // x
256:Src/main.c **** 0x1c, // y
257:Src/main.c **** 0x1d, // z
258:Src/main.c **** 0x2f|SHIFT, // {
259:Src/main.c **** 0x31|SHIFT, // |
260:Src/main.c **** 0x30|SHIFT, // }
261:Src/main.c **** 0x35|SHIFT, // ~
262:Src/main.c **** 0 // DEL
ARM GAS /tmp/ccRWo4B1.s page 6
263:Src/main.c **** };
264:Src/main.c ****
265:Src/main.c ****
266:Src/main.c **** int scan_cvt=1;
267:Src/main.c **** void kbd_send_ch(uint8_t ch){
268:Src/main.c **** int code;
269:Src/main.c **** int i;
270:Src/main.c **** if( scan_cvt ){
271:Src/main.c **** if( ch > 128 ) ch -=128;
272:Src/main.c **** code = _asciimap[ch];
273:Src/main.c **** }
274:Src/main.c **** else
275:Src/main.c **** code = ch;
276:Src/main.c ****
277:Src/main.c ****
278:Src/main.c **** //id set here must be consistent with the one in Hid report descriptor
279:Src/main.c **** // 0x85, 0x01, // Report ID (1)
280:Src/main.c **** kbd_report.id = 1;
281:Src/main.c ****
282:Src/main.c **** kbd_report.keycode[0]=code&0x7F;
283:Src/main.c **** kbd_report.keycode[1]=0;
284:Src/main.c **** if ( code & 0x80) { // it's a capital letter or other character reached with s
285:Src/main.c **** kbd_report.modifier |= 0x02; // the left shift modifier
286:Src/main.c **** }
287:Src/main.c **** for( i=0; i< 4;i++){
288:Src/main.c **** USBD_HID_SendReport(&hUsbDeviceFS, (uint8_t *)&kbd_report, sizeof(kbd_report));
289:Src/main.c **** HAL_Delay(10);
290:Src/main.c **** }
291:Src/main.c **** memset(kbd_report.keycode, 0 , sizeof(kbd_report.keycode));
292:Src/main.c **** kbd_report.modifier = 0;
293:Src/main.c **** USBD_HID_SendReport(&hUsbDeviceFS, (uint8_t *)&kbd_report, sizeof(kbd_report));
294:Src/main.c **** HAL_Delay(10);
295:Src/main.c **** }
296:Src/main.c ****
297:Src/main.c **** void kbd_send_raw(uint8_t ch){
298:Src/main.c **** int code;
299:Src/main.c **** int i;
300:Src/main.c **** code = ch;
301:Src/main.c ****
302:Src/main.c ****
303:Src/main.c **** //id set here must be consistent with the one in Hid report descriptor
304:Src/main.c **** // 0x85, 0x01, // Report ID (1)
305:Src/main.c **** kbd_report.id = 1;
306:Src/main.c ****
307:Src/main.c **** kbd_report.keycode[0]=ch&0x7F;
308:Src/main.c **** kbd_report.keycode[1]=0;
309:Src/main.c **** if ( code & 0x80) { // it's a capital letter or other character reached with s
310:Src/main.c **** kbd_report.modifier |= 0x02; // the left shift modifier
311:Src/main.c **** }
312:Src/main.c **** for( i=0; i< 4;i++){
313:Src/main.c **** USBD_HID_SendReport(&hUsbDeviceFS, (uint8_t *)&kbd_report, sizeof(kbd_report));
314:Src/main.c **** HAL_Delay(10);
315:Src/main.c **** }
316:Src/main.c **** memset(kbd_report.keycode, 0 , sizeof(kbd_report.keycode));
317:Src/main.c **** kbd_report.modifier = 0;
318:Src/main.c **** USBD_HID_SendReport(&hUsbDeviceFS, (uint8_t *)&kbd_report, sizeof(kbd_report));
319:Src/main.c **** HAL_Delay(10);
ARM GAS /tmp/ccRWo4B1.s page 7
320:Src/main.c **** }
321:Src/main.c ****
322:Src/main.c **** void sendVolUp(){
323:Src/main.c **** uint8_t report[3];
324:Src/main.c **** report[0]= HID_MEDIA_REPORT;
325:Src/main.c **** report[1]= 0xE9;
326:Src/main.c **** report[2]= 0x00;
327:Src/main.c **** USBD_HID_SendReport(&hUsbDeviceFS, report, 3);
328:Src/main.c **** HAL_Delay(10);
329:Src/main.c ****
330:Src/main.c **** report[0]= HID_MEDIA_REPORT;
331:Src/main.c **** report[1]= 0x00;
332:Src/main.c **** report[2]= 0x00;
333:Src/main.c **** USBD_HID_SendReport(&hUsbDeviceFS, report, 3);
334:Src/main.c **** }
335:Src/main.c ****
336:Src/main.c **** void sendVolDown(){
337:Src/main.c **** uint8_t report[3];
338:Src/main.c **** report[0]= HID_MEDIA_REPORT;
339:Src/main.c **** report[1]= 0xEA;
340:Src/main.c **** report[2]= 0x00;
341:Src/main.c **** USBD_HID_SendReport(&hUsbDeviceFS, report, 3);
342:Src/main.c **** HAL_Delay(10);
343:Src/main.c ****
344:Src/main.c **** report[0]= HID_MEDIA_REPORT;
345:Src/main.c **** report[1]= 0x00;
346:Src/main.c **** report[2]= 0x00;
347:Src/main.c **** USBD_HID_SendReport(&hUsbDeviceFS, report, 3);
348:Src/main.c **** }
349:Src/main.c ****
350:Src/main.c **** void SystemClock_Config(void)
351:Src/main.c **** {
352:Src/main.c **** RCC_OscInitTypeDef RCC_OscInitStruct = {0};
353:Src/main.c **** RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
354:Src/main.c **** RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
355:Src/main.c ****
356:Src/main.c **** RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI14|RCC_OSCILLATORTYPE_HSI48;
357:Src/main.c **** RCC_OscInitStruct.HSI48State = RCC_HSI48_ON;
358:Src/main.c **** RCC_OscInitStruct.HSI14State = RCC_HSI14_ON;
359:Src/main.c **** RCC_OscInitStruct.HSI14CalibrationValue = 16;
360:Src/main.c **** RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE;
361:Src/main.c **** HAL_RCC_OscConfig(&RCC_OscInitStruct);
362:Src/main.c ****
363:Src/main.c **** RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
364:Src/main.c **** |RCC_CLOCKTYPE_PCLK1;
365:Src/main.c **** RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_HSI48;
366:Src/main.c **** RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
367:Src/main.c **** RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;
368:Src/main.c **** HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_1);
369:Src/main.c ****
370:Src/main.c **** PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_USB;
371:Src/main.c **** PeriphClkInit.UsbClockSelection = RCC_USBCLKSOURCE_HSI48;
372:Src/main.c **** HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit);
373:Src/main.c ****
374:Src/main.c **** }
375:Src/main.c ****
376:Src/main.c **** static void MX_ADC_Init(void)
ARM GAS /tmp/ccRWo4B1.s page 8
377:Src/main.c **** {
378:Src/main.c ****
379:Src/main.c **** ADC_ChannelConfTypeDef sConfig = {0};
380:Src/main.c ****
381:Src/main.c **** hadc.Instance = ADC1;
382:Src/main.c **** hadc.Init.ClockPrescaler = ADC_CLOCK_ASYNC_DIV1;
383:Src/main.c **** hadc.Init.Resolution = ADC_RESOLUTION_12B;
384:Src/main.c **** hadc.Init.DataAlign = ADC_DATAALIGN_RIGHT;
385:Src/main.c **** hadc.Init.ScanConvMode = ADC_SCAN_DIRECTION_FORWARD;
386:Src/main.c **** hadc.Init.EOCSelection = ADC_EOC_SEQ_CONV;
387:Src/main.c **** hadc.Init.LowPowerAutoWait = DISABLE;
388:Src/main.c **** hadc.Init.LowPowerAutoPowerOff = DISABLE;
389:Src/main.c **** hadc.Init.ContinuousConvMode = ENABLE;
390:Src/main.c **** hadc.Init.DiscontinuousConvMode = DISABLE;
391:Src/main.c **** hadc.Init.ExternalTrigConv = ADC_SOFTWARE_START;
392:Src/main.c **** hadc.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;
393:Src/main.c **** hadc.Init.DMAContinuousRequests = ENABLE;
394:Src/main.c **** hadc.Init.Overrun = ADC_OVR_DATA_PRESERVED;
395:Src/main.c **** HAL_ADC_Init(&hadc);
396:Src/main.c ****
397:Src/main.c **** sConfig.Rank = ADC_RANK_CHANNEL_NUMBER;
398:Src/main.c **** sConfig.SamplingTime = ADC_SAMPLETIME_71CYCLES_5;
399:Src/main.c **** sConfig.Channel = ADC_CHANNEL_1;
400:Src/main.c **** HAL_ADC_ConfigChannel(&hadc, &sConfig);
401:Src/main.c ****
402:Src/main.c **** sConfig.Channel = ADC_CHANNEL_2;
403:Src/main.c **** HAL_ADC_ConfigChannel(&hadc, &sConfig);
404:Src/main.c ****
405:Src/main.c **** sConfig.Channel = ADC_CHANNEL_3;
406:Src/main.c **** HAL_ADC_ConfigChannel(&hadc, &sConfig);
407:Src/main.c ****
408:Src/main.c **** sConfig.Channel = ADC_CHANNEL_4;
409:Src/main.c **** HAL_ADC_ConfigChannel(&hadc, &sConfig);
410:Src/main.c ****
411:Src/main.c **** sConfig.Channel = ADC_CHANNEL_5;
412:Src/main.c **** HAL_ADC_ConfigChannel(&hadc, &sConfig);
413:Src/main.c ****
414:Src/main.c **** sConfig.Channel = ADC_CHANNEL_6;
415:Src/main.c **** HAL_ADC_ConfigChannel(&hadc, &sConfig);
416:Src/main.c ****
417:Src/main.c **** sConfig.Channel = ADC_CHANNEL_7;
418:Src/main.c **** HAL_ADC_ConfigChannel(&hadc, &sConfig);
419:Src/main.c ****
420:Src/main.c **** sConfig.Channel = ADC_CHANNEL_8;
421:Src/main.c **** HAL_ADC_ConfigChannel(&hadc, &sConfig);
422:Src/main.c **** }
423:Src/main.c ****
424:Src/main.c **** static void MX_USB_PCD_Init(void)
425:Src/main.c **** {
426:Src/main.c ****
427:Src/main.c **** hpcd_USB_FS.Instance = USB;
428:Src/main.c **** hpcd_USB_FS.Init.dev_endpoints = 8;
429:Src/main.c **** hpcd_USB_FS.Init.speed = PCD_SPEED_FULL;
430:Src/main.c **** hpcd_USB_FS.Init.phy_itface = PCD_PHY_EMBEDDED;
431:Src/main.c **** hpcd_USB_FS.Init.low_power_enable = DISABLE;
432:Src/main.c **** hpcd_USB_FS.Init.lpm_enable = DISABLE;
433:Src/main.c **** hpcd_USB_FS.Init.battery_charging_enable = DISABLE;
ARM GAS /tmp/ccRWo4B1.s page 9
434:Src/main.c **** HAL_PCD_Init(&hpcd_USB_FS);
435:Src/main.c **** }
436:Src/main.c ****
437:Src/main.c ****
438:Src/main.c **** static void MX_DMA_Init(void)
439:Src/main.c **** {
440:Src/main.c **** __HAL_RCC_DMA1_CLK_ENABLE();
441:Src/main.c ****
442:Src/main.c **** HAL_NVIC_SetPriority(DMA1_Channel1_IRQn, 0, 0);
443:Src/main.c **** HAL_NVIC_EnableIRQ(DMA1_Channel1_IRQn);
444:Src/main.c **** }
445:Src/main.c ****
446:Src/main.c ****
447:Src/main.c **** static void MX_GPIO_Init(void)
448:Src/main.c **** {
25 .loc 1 448 0
26 .cfi_startproc
27 @ args = 0, pretend = 0, frame = 32
28 @ frame_needed = 0, uses_anonymous_args = 0
29 0000 30B5 push {r4, r5, lr}
30 .LCFI0:
31 .cfi_def_cfa_offset 12
32 .cfi_offset 4, -12
33 .cfi_offset 5, -8
34 .cfi_offset 14, -4
35 0002 89B0 sub sp, sp, #36
36 .LCFI1:
37 .cfi_def_cfa_offset 48
449:Src/main.c ****
450:Src/main.c **** GPIO_InitTypeDef GPIO_InitStruct = {0};
38 .loc 1 450 0
39 0004 1422 movs r2, #20
40 0006 0021 movs r1, #0
41 0008 03A8 add r0, sp, #12
42 000a FFF7FEFF bl memset
43 .LVL0:
44 .LBB2:
451:Src/main.c ****
452:Src/main.c **** __HAL_RCC_GPIOB_CLK_ENABLE();
45 .loc 1 452 0
46 000e 134B ldr r3, .L2
47 0010 5969 ldr r1, [r3, #20]
48 0012 8020 movs r0, #128
49 0014 C002 lsls r0, r0, #11
50 0016 0143 orrs r1, r0
51 0018 5961 str r1, [r3, #20]
52 001a 5A69 ldr r2, [r3, #20]
53 001c 0240 ands r2, r0
54 001e 0192 str r2, [sp, #4]
55 0020 019A ldr r2, [sp, #4]
56 .LBE2:
57 .LBB3:
453:Src/main.c **** __HAL_RCC_GPIOA_CLK_ENABLE();
58 .loc 1 453 0
59 0022 5A69 ldr r2, [r3, #20]
60 0024 8021 movs r1, #128
61 0026 8902 lsls r1, r1, #10
ARM GAS /tmp/ccRWo4B1.s page 10
62 0028 0A43 orrs r2, r1
63 002a 5A61 str r2, [r3, #20]
64 002c 5B69 ldr r3, [r3, #20]
65 002e 0B40 ands r3, r1
66 0030 0293 str r3, [sp, #8]
67 0032 029B ldr r3, [sp, #8]
68 .LBE3:
454:Src/main.c ****
455:Src/main.c **** HAL_GPIO_WritePin(GPIOB, GPIO_PIN_13, GPIO_PIN_RESET);
69 .loc 1 455 0
70 0034 8025 movs r5, #128
71 0036 AD01 lsls r5, r5, #6
72 0038 094C ldr r4, .L2+4
73 003a 0022 movs r2, #0
74 003c 2900 movs r1, r5
75 003e 2000 movs r0, r4
76 0040 FFF7FEFF bl HAL_GPIO_WritePin
77 .LVL1:
456:Src/main.c ****
457:Src/main.c **** GPIO_InitStruct.Pin = GPIO_PIN_13;
78 .loc 1 457 0
79 0044 0395 str r5, [sp, #12]
458:Src/main.c **** GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
80 .loc 1 458 0
81 0046 0123 movs r3, #1
82 0048 0493 str r3, [sp, #16]
459:Src/main.c **** GPIO_InitStruct.Pull = GPIO_NOPULL;
83 .loc 1 459 0
84 004a 0023 movs r3, #0
85 004c 0593 str r3, [sp, #20]
460:Src/main.c **** GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
86 .loc 1 460 0
87 004e 0693 str r3, [sp, #24]
461:Src/main.c **** HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
88 .loc 1 461 0
89 0050 03A9 add r1, sp, #12
90 0052 2000 movs r0, r4
91 0054 FFF7FEFF bl HAL_GPIO_Init
92 .LVL2:
462:Src/main.c **** }
93 .loc 1 462 0
94 0058 09B0 add sp, sp, #36
95 @ sp needed
96 005a 30BD pop {r4, r5, pc}
97 .L3:
98 .align 2
99 .L2:
100 005c 00100240 .word 1073876992
101 0060 00040048 .word 1207960576
102 .cfi_endproc
103 .LFE52:
105 .section .text.MX_DMA_Init,"ax",%progbits
106 .align 1
107 .syntax unified
108 .code 16
109 .thumb_func
110 .fpu softvfp
ARM GAS /tmp/ccRWo4B1.s page 11
112 MX_DMA_Init:
113 .LFB51:
439:Src/main.c **** __HAL_RCC_DMA1_CLK_ENABLE();
114 .loc 1 439 0
115 .cfi_startproc
116 @ args = 0, pretend = 0, frame = 8
117 @ frame_needed = 0, uses_anonymous_args = 0
118 0000 00B5 push {lr}
119 .LCFI2:
120 .cfi_def_cfa_offset 4
121 .cfi_offset 14, -4
122 0002 83B0 sub sp, sp, #12
123 .LCFI3:
124 .cfi_def_cfa_offset 16
125 .LBB4:
440:Src/main.c ****
126 .loc 1 440 0
127 0004 094A ldr r2, .L5
128 0006 5169 ldr r1, [r2, #20]
129 0008 0123 movs r3, #1
130 000a 1943 orrs r1, r3
131 000c 5161 str r1, [r2, #20]
132 000e 5269 ldr r2, [r2, #20]
133 0010 1340 ands r3, r2
134 0012 0193 str r3, [sp, #4]
135 0014 019B ldr r3, [sp, #4]
136 .LBE4:
442:Src/main.c **** HAL_NVIC_EnableIRQ(DMA1_Channel1_IRQn);
137 .loc 1 442 0
138 0016 0022 movs r2, #0
139 0018 0021 movs r1, #0
140 001a 0920 movs r0, #9
141 001c FFF7FEFF bl HAL_NVIC_SetPriority
142 .LVL3:
443:Src/main.c **** }
143 .loc 1 443 0
144 0020 0920 movs r0, #9
145 0022 FFF7FEFF bl HAL_NVIC_EnableIRQ
146 .LVL4:
444:Src/main.c ****
147 .loc 1 444 0
148 0026 03B0 add sp, sp, #12
149 @ sp needed
150 0028 00BD pop {pc}
151 .L6:
152 002a C046 .align 2
153 .L5:
154 002c 00100240 .word 1073876992
155 .cfi_endproc
156 .LFE51:
158 .section .text.MX_ADC_Init,"ax",%progbits
159 .align 1
160 .syntax unified
161 .code 16
162 .thumb_func
163 .fpu softvfp
165 MX_ADC_Init:
ARM GAS /tmp/ccRWo4B1.s page 12
166 .LFB49:
377:Src/main.c ****
167 .loc 1 377 0
168 .cfi_startproc
169 @ args = 0, pretend = 0, frame = 16
170 @ frame_needed = 0, uses_anonymous_args = 0
171 0000 F0B5 push {r4, r5, r6, r7, lr}
172 .LCFI4:
173 .cfi_def_cfa_offset 20
174 .cfi_offset 4, -20
175 .cfi_offset 5, -16
176 .cfi_offset 6, -12
177 .cfi_offset 7, -8
178 .cfi_offset 14, -4
179 0002 85B0 sub sp, sp, #20
180 .LCFI5:
181 .cfi_def_cfa_offset 40
379:Src/main.c ****
182 .loc 1 379 0
183 0004 0C22 movs r2, #12
184 0006 0021 movs r1, #0
185 0008 01A8 add r0, sp, #4
186 000a FFF7FEFF bl memset
187 .LVL5:
381:Src/main.c **** hadc.Init.ClockPrescaler = ADC_CLOCK_ASYNC_DIV1;
188 .loc 1 381 0
189 000e 264C ldr r4, .L8
190 0010 264B ldr r3, .L8+4
191 0012 2360 str r3, [r4]
382:Src/main.c **** hadc.Init.Resolution = ADC_RESOLUTION_12B;
192 .loc 1 382 0
193 0014 0023 movs r3, #0
194 0016 6360 str r3, [r4, #4]
383:Src/main.c **** hadc.Init.DataAlign = ADC_DATAALIGN_RIGHT;
195 .loc 1 383 0
196 0018 A360 str r3, [r4, #8]
384:Src/main.c **** hadc.Init.ScanConvMode = ADC_SCAN_DIRECTION_FORWARD;
197 .loc 1 384 0
198 001a E360 str r3, [r4, #12]
385:Src/main.c **** hadc.Init.EOCSelection = ADC_EOC_SEQ_CONV;
199 .loc 1 385 0
200 001c 0125 movs r5, #1
201 001e 2561 str r5, [r4, #16]
386:Src/main.c **** hadc.Init.LowPowerAutoWait = DISABLE;
202 .loc 1 386 0
203 0020 0826 movs r6, #8
204 0022 6661 str r6, [r4, #20]
387:Src/main.c **** hadc.Init.LowPowerAutoPowerOff = DISABLE;
205 .loc 1 387 0
206 0024 2376 strb r3, [r4, #24]
388:Src/main.c **** hadc.Init.ContinuousConvMode = ENABLE;
207 .loc 1 388 0
208 0026 6376 strb r3, [r4, #25]
389:Src/main.c **** hadc.Init.DiscontinuousConvMode = DISABLE;
209 .loc 1 389 0
210 0028 A576 strb r5, [r4, #26]
390:Src/main.c **** hadc.Init.ExternalTrigConv = ADC_SOFTWARE_START;
ARM GAS /tmp/ccRWo4B1.s page 13
211 .loc 1 390 0
212 002a E376 strb r3, [r4, #27]
391:Src/main.c **** hadc.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;
213 .loc 1 391 0
214 002c C222 movs r2, #194
215 002e FF32 adds r2, r2, #255
216 0030 E261 str r2, [r4, #28]
392:Src/main.c **** hadc.Init.DMAContinuousRequests = ENABLE;
217 .loc 1 392 0
218 0032 2362 str r3, [r4, #32]
393:Src/main.c **** hadc.Init.Overrun = ADC_OVR_DATA_PRESERVED;
219 .loc 1 393 0
220 0034 2433 adds r3, r3, #36
221 0036 E554 strb r5, [r4, r3]
394:Src/main.c **** HAL_ADC_Init(&hadc);
222 .loc 1 394 0
223 0038 A562 str r5, [r4, #40]
395:Src/main.c ****
224 .loc 1 395 0
225 003a 2000 movs r0, r4
226 003c FFF7FEFF bl HAL_ADC_Init
227 .LVL6:
397:Src/main.c **** sConfig.SamplingTime = ADC_SAMPLETIME_71CYCLES_5;
228 .loc 1 397 0
229 0040 8023 movs r3, #128
230 0042 5B01 lsls r3, r3, #5
231 0044 0293 str r3, [sp, #8]
398:Src/main.c **** sConfig.Channel = ADC_CHANNEL_1;
232 .loc 1 398 0
233 0046 0627 movs r7, #6
234 0048 0397 str r7, [sp, #12]
399:Src/main.c **** HAL_ADC_ConfigChannel(&hadc, &sConfig);
235 .loc 1 399 0
236 004a 0195 str r5, [sp, #4]
400:Src/main.c ****
237 .loc 1 400 0
238 004c 01A9 add r1, sp, #4
239 004e 2000 movs r0, r4
240 0050 FFF7FEFF bl HAL_ADC_ConfigChannel
241 .LVL7:
402:Src/main.c **** HAL_ADC_ConfigChannel(&hadc, &sConfig);
242 .loc 1 402 0
243 0054 0223 movs r3, #2
244 0056 0193 str r3, [sp, #4]
403:Src/main.c ****
245 .loc 1 403 0
246 0058 01A9 add r1, sp, #4
247 005a 2000 movs r0, r4
248 005c FFF7FEFF bl HAL_ADC_ConfigChannel
249 .LVL8:
405:Src/main.c **** HAL_ADC_ConfigChannel(&hadc, &sConfig);
250 .loc 1 405 0
251 0060 0323 movs r3, #3
252 0062 0193 str r3, [sp, #4]
406:Src/main.c ****
253 .loc 1 406 0
254 0064 01A9 add r1, sp, #4
ARM GAS /tmp/ccRWo4B1.s page 14
255 0066 2000 movs r0, r4
256 0068 FFF7FEFF bl HAL_ADC_ConfigChannel
257 .LVL9:
408:Src/main.c **** HAL_ADC_ConfigChannel(&hadc, &sConfig);
258 .loc 1 408 0
259 006c 0423 movs r3, #4
260 006e 0193 str r3, [sp, #4]
409:Src/main.c ****
261 .loc 1 409 0
262 0070 01A9 add r1, sp, #4
263 0072 2000 movs r0, r4
264 0074 FFF7FEFF bl HAL_ADC_ConfigChannel
265 .LVL10:
411:Src/main.c **** HAL_ADC_ConfigChannel(&hadc, &sConfig);
266 .loc 1 411 0
267 0078 0523 movs r3, #5
268 007a 0193 str r3, [sp, #4]
412:Src/main.c ****
269 .loc 1 412 0
270 007c 01A9 add r1, sp, #4
271 007e 2000 movs r0, r4
272 0080 FFF7FEFF bl HAL_ADC_ConfigChannel
273 .LVL11:
414:Src/main.c **** HAL_ADC_ConfigChannel(&hadc, &sConfig);
274 .loc 1 414 0
275 0084 0197 str r7, [sp, #4]
415:Src/main.c ****
276 .loc 1 415 0
277 0086 01A9 add r1, sp, #4
278 0088 2000 movs r0, r4
279 008a FFF7FEFF bl HAL_ADC_ConfigChannel
280 .LVL12:
417:Src/main.c **** HAL_ADC_ConfigChannel(&hadc, &sConfig);
281 .loc 1 417 0
282 008e 0723 movs r3, #7
283 0090 0193 str r3, [sp, #4]
418:Src/main.c ****
284 .loc 1 418 0
285 0092 01A9 add r1, sp, #4
286 0094 2000 movs r0, r4
287 0096 FFF7FEFF bl HAL_ADC_ConfigChannel
288 .LVL13:
420:Src/main.c **** HAL_ADC_ConfigChannel(&hadc, &sConfig);
289 .loc 1 420 0
290 009a 0196 str r6, [sp, #4]
421:Src/main.c **** }
291 .loc 1 421 0
292 009c 01A9 add r1, sp, #4
293 009e 2000 movs r0, r4
294 00a0 FFF7FEFF bl HAL_ADC_ConfigChannel
295 .LVL14:
422:Src/main.c ****
296 .loc 1 422 0
297 00a4 05B0 add sp, sp, #20
298 @ sp needed
299 00a6 F0BD pop {r4, r5, r6, r7, pc}
300 .L9:
ARM GAS /tmp/ccRWo4B1.s page 15
301 .align 2
302 .L8:
303 00a8 00000000 .word hadc
304 00ac 00240140 .word 1073816576
305 .cfi_endproc
306 .LFE49:
308 .section .text.kbd_send_ch,"ax",%progbits
309 .align 1
310 .global kbd_send_ch
311 .syntax unified
312 .code 16
313 .thumb_func
314 .fpu softvfp
316 kbd_send_ch:
317 .LFB44:
267:Src/main.c **** int code;
318 .loc 1 267 0
319 .cfi_startproc
320 @ args = 0, pretend = 0, frame = 0
321 @ frame_needed = 0, uses_anonymous_args = 0
322 .LVL15:
323 0000 10B5 push {r4, lr}
324 .LCFI6:
325 .cfi_def_cfa_offset 8
326 .cfi_offset 4, -8
327 .cfi_offset 14, -4
270:Src/main.c **** if( ch > 128 ) ch -=128;
328 .loc 1 270 0
329 0002 1B4B ldr r3, .L17
330 0004 1B68 ldr r3, [r3]
331 0006 002B cmp r3, #0
332 0008 05D0 beq .L13
271:Src/main.c **** code = _asciimap[ch];
333 .loc 1 271 0
334 000a 8028 cmp r0, #128
335 000c 01D9 bls .L12
271:Src/main.c **** code = _asciimap[ch];
336 .loc 1 271 0 is_stmt 0 discriminator 1
337 000e 8038 subs r0, r0, #128
338 .LVL16:
339 0010 C0B2 uxtb r0, r0
340 .LVL17:
341 .L12:
272:Src/main.c **** }
342 .loc 1 272 0 is_stmt 1
343 0012 184B ldr r3, .L17+4
344 0014 185C ldrb r0, [r3, r0]
345 .LVL18:
346 .L13:
280:Src/main.c ****
347 .loc 1 280 0
348 0016 184B ldr r3, .L17+8
349 0018 0122 movs r2, #1
350 001a 1A70 strb r2, [r3]
282:Src/main.c **** kbd_report.keycode[1]=0;
351 .loc 1 282 0
352 001c 7E32 adds r2, r2, #126
ARM GAS /tmp/ccRWo4B1.s page 16
353 001e 0240 ands r2, r0
354 0020 DA70 strb r2, [r3, #3]
283:Src/main.c **** if ( code & 0x80) { // it's a capital letter or other character reached with s
355 .loc 1 283 0
356 0022 0022 movs r2, #0
357 0024 1A71 strb r2, [r3, #4]
284:Src/main.c **** kbd_report.modifier |= 0x02; // the left shift modifier
358 .loc 1 284 0
359 0026 0306 lsls r3, r0, #24
360 0028 04D5 bpl .L14
285:Src/main.c **** }
361 .loc 1 285 0
362 002a 134A ldr r2, .L17+8
363 002c 5378 ldrb r3, [r2, #1]
364 002e 0221 movs r1, #2
365 0030 0B43 orrs r3, r1
366 0032 5370 strb r3, [r2, #1]
367 .L14:
267:Src/main.c **** int code;
368 .loc 1 267 0 discriminator 1
369 0034 0024 movs r4, #0
370 0036 08E0 b .L15
371 .LVL19:
372 .L16:
288:Src/main.c **** HAL_Delay(10);
373 .loc 1 288 0 discriminator 3
374 0038 0922 movs r2, #9
375 003a 0F49 ldr r1, .L17+8
376 003c 0F48 ldr r0, .L17+12
377 003e FFF7FEFF bl USBD_HID_SendReport
378 .LVL20:
289:Src/main.c **** }
379 .loc 1 289 0 discriminator 3
380 0042 0A20 movs r0, #10
381 0044 FFF7FEFF bl HAL_Delay
382 .LVL21:
287:Src/main.c **** USBD_HID_SendReport(&hUsbDeviceFS, (uint8_t *)&kbd_report, sizeof(kbd_report));
383 .loc 1 287 0 discriminator 3
384 0048 0134 adds r4, r4, #1
385 .LVL22:
386 .L15:
287:Src/main.c **** USBD_HID_SendReport(&hUsbDeviceFS, (uint8_t *)&kbd_report, sizeof(kbd_report));
387 .loc 1 287 0 is_stmt 0 discriminator 1
388 004a 032C cmp r4, #3
389 004c F4DD ble .L16
291:Src/main.c **** kbd_report.modifier = 0;
390 .loc 1 291 0 is_stmt 1
391 004e 0C4C ldr r4, .L17+16
392 .LVL23:
393 0050 0622 movs r2, #6
394 0052 0021 movs r1, #0
395 0054 2000 movs r0, r4
396 0056 FFF7FEFF bl memset
397 .LVL24:
292:Src/main.c **** USBD_HID_SendReport(&hUsbDeviceFS, (uint8_t *)&kbd_report, sizeof(kbd_report));
398 .loc 1 292 0
399 005a E11E subs r1, r4, #3
ARM GAS /tmp/ccRWo4B1.s page 17
400 005c 0023 movs r3, #0
401 005e 4B70 strb r3, [r1, #1]
293:Src/main.c **** HAL_Delay(10);
402 .loc 1 293 0
403 0060 0922 movs r2, #9
404 0062 0648 ldr r0, .L17+12
405 0064 FFF7FEFF bl USBD_HID_SendReport
406 .LVL25:
294:Src/main.c **** }
407 .loc 1 294 0
408 0068 0A20 movs r0, #10
409 006a FFF7FEFF bl HAL_Delay
410 .LVL26:
295:Src/main.c ****
411 .loc 1 295 0
412 @ sp needed
413 006e 10BD pop {r4, pc}
414 .L18:
415 .align 2
416 .L17:
417 0070 00000000 .word .LANCHOR0
418 0074 00000000 .word _asciimap
419 0078 00000000 .word kbd_report
420 007c 00000000 .word hUsbDeviceFS
421 0080 03000000 .word kbd_report+3
422 .cfi_endproc
423 .LFE44:
425 .section .text.kbd_send_raw,"ax",%progbits
426 .align 1
427 .global kbd_send_raw
428 .syntax unified
429 .code 16
430 .thumb_func
431 .fpu softvfp
433 kbd_send_raw:
434 .LFB45:
297:Src/main.c **** int code;
435 .loc 1 297 0
436 .cfi_startproc
437 @ args = 0, pretend = 0, frame = 0
438 @ frame_needed = 0, uses_anonymous_args = 0
439 .LVL27:
440 0000 10B5 push {r4, lr}
441 .LCFI7:
442 .cfi_def_cfa_offset 8
443 .cfi_offset 4, -8
444 .cfi_offset 14, -4
445 .LVL28:
305:Src/main.c ****
446 .loc 1 305 0
447 0002 174B ldr r3, .L24
448 0004 0122 movs r2, #1
449 0006 1A70 strb r2, [r3]
307:Src/main.c **** kbd_report.keycode[1]=0;
450 .loc 1 307 0
451 0008 7E32 adds r2, r2, #126
452 000a 0240 ands r2, r0
ARM GAS /tmp/ccRWo4B1.s page 18
453 000c DA70 strb r2, [r3, #3]
308:Src/main.c **** if ( code & 0x80) { // it's a capital letter or other character reached with s
454 .loc 1 308 0
455 000e 0022 movs r2, #0
456 0010 1A71 strb r2, [r3, #4]
309:Src/main.c **** kbd_report.modifier |= 0x02; // the left shift modifier
457 .loc 1 309 0
458 0012 40B2 sxtb r0, r0
459 0014 0028 cmp r0, #0
460 0016 01DB blt .L23
461 .L20:
297:Src/main.c **** int code;
462 .loc 1 297 0 discriminator 1
463 0018 0024 movs r4, #0
464 001a 0EE0 b .L21
465 .L23:
310:Src/main.c **** }
466 .loc 1 310 0
467 001c 1A00 movs r2, r3
468 001e 5B78 ldrb r3, [r3, #1]
469 0020 0221 movs r1, #2
470 0022 0B43 orrs r3, r1
471 0024 5370 strb r3, [r2, #1]
472 0026 F7E7 b .L20
473 .LVL29:
474 .L22:
313:Src/main.c **** HAL_Delay(10);
475 .loc 1 313 0 discriminator 3
476 0028 0922 movs r2, #9
477 002a 0D49 ldr r1, .L24
478 002c 0D48 ldr r0, .L24+4
479 002e FFF7FEFF bl USBD_HID_SendReport
480 .LVL30:
314:Src/main.c **** }
481 .loc 1 314 0 discriminator 3
482 0032 0A20 movs r0, #10
483 0034 FFF7FEFF bl HAL_Delay
484 .LVL31:
312:Src/main.c **** USBD_HID_SendReport(&hUsbDeviceFS, (uint8_t *)&kbd_report, sizeof(kbd_report));
485 .loc 1 312 0 discriminator 3
486 0038 0134 adds r4, r4, #1
487 .LVL32:
488 .L21:
312:Src/main.c **** USBD_HID_SendReport(&hUsbDeviceFS, (uint8_t *)&kbd_report, sizeof(kbd_report));
489 .loc 1 312 0 is_stmt 0 discriminator 1
490 003a 032C cmp r4, #3
491 003c F4DD ble .L22
316:Src/main.c **** kbd_report.modifier = 0;
492 .loc 1 316 0 is_stmt 1
493 003e 0A4C ldr r4, .L24+8
494 .LVL33:
495 0040 0622 movs r2, #6
496 0042 0021 movs r1, #0
497 0044 2000 movs r0, r4
498 0046 FFF7FEFF bl memset
499 .LVL34:
317:Src/main.c **** USBD_HID_SendReport(&hUsbDeviceFS, (uint8_t *)&kbd_report, sizeof(kbd_report));
ARM GAS /tmp/ccRWo4B1.s page 19
500 .loc 1 317 0
501 004a E11E subs r1, r4, #3
502 004c 0023 movs r3, #0
503 004e 4B70 strb r3, [r1, #1]
318:Src/main.c **** HAL_Delay(10);
504 .loc 1 318 0
505 0050 0922 movs r2, #9
506 0052 0448 ldr r0, .L24+4
507 0054 FFF7FEFF bl USBD_HID_SendReport
508 .LVL35:
319:Src/main.c **** }
509 .loc 1 319 0
510 0058 0A20 movs r0, #10
511 005a FFF7FEFF bl HAL_Delay
512 .LVL36:
320:Src/main.c ****
513 .loc 1 320 0
514 @ sp needed
515 005e 10BD pop {r4, pc}
516 .L25:
517 .align 2
518 .L24:
519 0060 00000000 .word kbd_report
520 0064 00000000 .word hUsbDeviceFS
521 0068 03000000 .word kbd_report+3
522 .cfi_endproc
523 .LFE45:
525 .section .text.sendVolUp,"ax",%progbits
526 .align 1
527 .global sendVolUp
528 .syntax unified
529 .code 16
530 .thumb_func
531 .fpu softvfp
533 sendVolUp:
534 .LFB46:
322:Src/main.c **** uint8_t report[3];
535 .loc 1 322 0
536 .cfi_startproc
537 @ args = 0, pretend = 0, frame = 8
538 @ frame_needed = 0, uses_anonymous_args = 0
539 0000 F0B5 push {r4, r5, r6, r7, lr}
540 .LCFI8:
541 .cfi_def_cfa_offset 20
542 .cfi_offset 4, -20
543 .cfi_offset 5, -16
544 .cfi_offset 6, -12
545 .cfi_offset 7, -8
546 .cfi_offset 14, -4
547 0002 83B0 sub sp, sp, #12
548 .LCFI9:
549 .cfi_def_cfa_offset 32
324:Src/main.c **** report[1]= 0xE9;
550 .loc 1 324 0
551 0004 01AC add r4, sp, #4
552 0006 0227 movs r7, #2
553 0008 2770 strb r7, [r4]
ARM GAS /tmp/ccRWo4B1.s page 20
325:Src/main.c **** report[2]= 0x00;
554 .loc 1 325 0
555 000a E923 movs r3, #233
556 000c 6370 strb r3, [r4, #1]
326:Src/main.c **** USBD_HID_SendReport(&hUsbDeviceFS, report, 3);
557 .loc 1 326 0
558 000e 0025 movs r5, #0
559 0010 A570 strb r5, [r4, #2]
327:Src/main.c **** HAL_Delay(10);
560 .loc 1 327 0
561 0012 094E ldr r6, .L27
562 0014 0322 movs r2, #3
563 0016 2100 movs r1, r4
564 0018 3000 movs r0, r6
565 001a FFF7FEFF bl USBD_HID_SendReport
566 .LVL37:
328:Src/main.c ****
567 .loc 1 328 0
568 001e 0A20 movs r0, #10
569 0020 FFF7FEFF bl HAL_Delay
570 .LVL38:
330:Src/main.c **** report[1]= 0x00;
571 .loc 1 330 0
572 0024 2770 strb r7, [r4]
331:Src/main.c **** report[2]= 0x00;
573 .loc 1 331 0
574 0026 6570 strb r5, [r4, #1]
332:Src/main.c **** USBD_HID_SendReport(&hUsbDeviceFS, report, 3);
575 .loc 1 332 0
576 0028 A570 strb r5, [r4, #2]
333:Src/main.c **** }
577 .loc 1 333 0
578 002a 0322 movs r2, #3
579 002c 2100 movs r1, r4
580 002e 3000 movs r0, r6
581 0030 FFF7FEFF bl USBD_HID_SendReport
582 .LVL39:
334:Src/main.c ****
583 .loc 1 334 0
584 0034 03B0 add sp, sp, #12
585 @ sp needed
586 0036 F0BD pop {r4, r5, r6, r7, pc}
587 .L28:
588 .align 2
589 .L27:
590 0038 00000000 .word hUsbDeviceFS
591 .cfi_endproc
592 .LFE46:
594 .section .text.sendVolDown,"ax",%progbits
595 .align 1
596 .global sendVolDown
597 .syntax unified
598 .code 16
599 .thumb_func
600 .fpu softvfp
602 sendVolDown:
603 .LFB47:
ARM GAS /tmp/ccRWo4B1.s page 21
336:Src/main.c **** uint8_t report[3];
604 .loc 1 336 0
605 .cfi_startproc
606 @ args = 0, pretend = 0, frame = 8
607 @ frame_needed = 0, uses_anonymous_args = 0
608 0000 F0B5 push {r4, r5, r6, r7, lr}
609 .LCFI10:
610 .cfi_def_cfa_offset 20
611 .cfi_offset 4, -20
612 .cfi_offset 5, -16
613 .cfi_offset 6, -12
614 .cfi_offset 7, -8
615 .cfi_offset 14, -4
616 0002 83B0 sub sp, sp, #12
617 .LCFI11:
618 .cfi_def_cfa_offset 32
338:Src/main.c **** report[1]= 0xEA;
619 .loc 1 338 0
620 0004 01AC add r4, sp, #4
621 0006 0227 movs r7, #2
622 0008 2770 strb r7, [r4]
339:Src/main.c **** report[2]= 0x00;
623 .loc 1 339 0
624 000a EA23 movs r3, #234
625 000c 6370 strb r3, [r4, #1]
340:Src/main.c **** USBD_HID_SendReport(&hUsbDeviceFS, report, 3);
626 .loc 1 340 0
627 000e 0025 movs r5, #0
628 0010 A570 strb r5, [r4, #2]
341:Src/main.c **** HAL_Delay(10);
629 .loc 1 341 0
630 0012 094E ldr r6, .L30
631 0014 0322 movs r2, #3
632 0016 2100 movs r1, r4
633 0018 3000 movs r0, r6
634 001a FFF7FEFF bl USBD_HID_SendReport
635 .LVL40:
342:Src/main.c ****
636 .loc 1 342 0
637 001e 0A20 movs r0, #10
638 0020 FFF7FEFF bl HAL_Delay
639 .LVL41:
344:Src/main.c **** report[1]= 0x00;
640 .loc 1 344 0
641 0024 2770 strb r7, [r4]
345:Src/main.c **** report[2]= 0x00;
642 .loc 1 345 0
643 0026 6570 strb r5, [r4, #1]
346:Src/main.c **** USBD_HID_SendReport(&hUsbDeviceFS, report, 3);
644 .loc 1 346 0
645 0028 A570 strb r5, [r4, #2]
347:Src/main.c **** }
646 .loc 1 347 0
647 002a 0322 movs r2, #3
648 002c 2100 movs r1, r4
649 002e 3000 movs r0, r6
650 0030 FFF7FEFF bl USBD_HID_SendReport
ARM GAS /tmp/ccRWo4B1.s page 22
651 .LVL42:
348:Src/main.c ****
652 .loc 1 348 0
653 0034 03B0 add sp, sp, #12
654 @ sp needed
655 0036 F0BD pop {r4, r5, r6, r7, pc}
656 .L31:
657 .align 2
658 .L30:
659 0038 00000000 .word hUsbDeviceFS
660 .cfi_endproc
661 .LFE47:
663 .section .text.SystemClock_Config,"ax",%progbits
664 .align 1
665 .global SystemClock_Config
666 .syntax unified
667 .code 16
668 .thumb_func
669 .fpu softvfp
671 SystemClock_Config:
672 .LFB48:
351:Src/main.c **** RCC_OscInitTypeDef RCC_OscInitStruct = {0};
673 .loc 1 351 0
674 .cfi_startproc
675 @ args = 0, pretend = 0, frame = 96
676 @ frame_needed = 0, uses_anonymous_args = 0
677 0000 10B5 push {r4, lr}
678 .LCFI12:
679 .cfi_def_cfa_offset 8
680 .cfi_offset 4, -8
681 .cfi_offset 14, -4
682 0002 98B0 sub sp, sp, #96
683 .LCFI13:
684 .cfi_def_cfa_offset 104
352:Src/main.c **** RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
685 .loc 1 352 0
686 0004 3022 movs r2, #48
687 0006 0021 movs r1, #0
688 0008 0CA8 add r0, sp, #48
689 000a FFF7FEFF bl memset
690 .LVL43:
353:Src/main.c **** RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
691 .loc 1 353 0
692 000e 1022 movs r2, #16
693 0010 0021 movs r1, #0
694 0012 07A8 add r0, sp, #28
695 0014 FFF7FEFF bl memset
696 .LVL44:
354:Src/main.c ****
697 .loc 1 354 0
698 0018 1C22 movs r2, #28
699 001a 0021 movs r1, #0
700 001c 6846 mov r0, sp
701 001e FFF7FEFF bl memset
702 .LVL45:
356:Src/main.c **** RCC_OscInitStruct.HSI48State = RCC_HSI48_ON;
703 .loc 1 356 0
ARM GAS /tmp/ccRWo4B1.s page 23
704 0022 3023 movs r3, #48
705 0024 0B93 str r3, [sp, #44]
357:Src/main.c **** RCC_OscInitStruct.HSI14State = RCC_HSI14_ON;
706 .loc 1 357 0
707 0026 2F3B subs r3, r3, #47
708 0028 1393 str r3, [sp, #76]
358:Src/main.c **** RCC_OscInitStruct.HSI14CalibrationValue = 16;
709 .loc 1 358 0
710 002a 1093 str r3, [sp, #64]
359:Src/main.c **** RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE;
711 .loc 1 359 0
712 002c 0F33 adds r3, r3, #15
713 002e 1193 str r3, [sp, #68]
361:Src/main.c ****
714 .loc 1 361 0
715 0030 0BA8 add r0, sp, #44
716 0032 FFF7FEFF bl HAL_RCC_OscConfig
717 .LVL46:
363:Src/main.c **** |RCC_CLOCKTYPE_PCLK1;
718 .loc 1 363 0
719 0036 0723 movs r3, #7
720 0038 0793 str r3, [sp, #28]
365:Src/main.c **** RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
721 .loc 1 365 0
722 003a 043B subs r3, r3, #4
723 003c 0893 str r3, [sp, #32]
366:Src/main.c **** RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;
724 .loc 1 366 0
725 003e 0024 movs r4, #0
726 0040 0994 str r4, [sp, #36]
367:Src/main.c **** HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_1);
727 .loc 1 367 0
728 0042 0A94 str r4, [sp, #40]
368:Src/main.c ****
729 .loc 1 368 0
730 0044 0121 movs r1, #1
731 0046 07A8 add r0, sp, #28
732 0048 FFF7FEFF bl HAL_RCC_ClockConfig
733 .LVL47:
370:Src/main.c **** PeriphClkInit.UsbClockSelection = RCC_USBCLKSOURCE_HSI48;
734 .loc 1 370 0
735 004c 8023 movs r3, #128
736 004e 9B02 lsls r3, r3, #10
737 0050 0093 str r3, [sp]
371:Src/main.c **** HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit);
738 .loc 1 371 0
739 0052 0694 str r4, [sp, #24]
372:Src/main.c ****
740 .loc 1 372 0
741 0054 6846 mov r0, sp
742 0056 FFF7FEFF bl HAL_RCCEx_PeriphCLKConfig
743 .LVL48:
374:Src/main.c ****
744 .loc 1 374 0
745 005a 18B0 add sp, sp, #96
746 @ sp needed
747 005c 10BD pop {r4, pc}
ARM GAS /tmp/ccRWo4B1.s page 24
748 .cfi_endproc
749 .LFE48:
751 .section .text.main,"ax",%progbits
752 .align 1
753 .global main
754 .syntax unified
755 .code 16
756 .thumb_func
757 .fpu softvfp
759 main:
760 .LFB43:
37:Src/main.c **** HAL_Init();
761 .loc 1 37 0
762 .cfi_startproc
763 @ args = 0, pretend = 0, frame = 0
764 @ frame_needed = 0, uses_anonymous_args = 0
765 0000 10B5 push {r4, lr}
766 .LCFI14:
767 .cfi_def_cfa_offset 8
768 .cfi_offset 4, -8
769 .cfi_offset 14, -4
38:Src/main.c ****
770 .loc 1 38 0
771 0002 FFF7FEFF bl HAL_Init
772 .LVL49:
40:Src/main.c ****
773 .loc 1 40 0
774 0006 FFF7FEFF bl SystemClock_Config
775 .LVL50:
42:Src/main.c **** MX_DMA_Init();
776 .loc 1 42 0
777 000a FFF7FEFF bl MX_GPIO_Init
778 .LVL51:
43:Src/main.c **** MX_ADC_Init();
779 .loc 1 43 0
780 000e FFF7FEFF bl MX_DMA_Init
781 .LVL52:
44:Src/main.c **** MX_USB_HID_INIT();
782 .loc 1 44 0
783 0012 FFF7FEFF bl MX_ADC_Init
784 .LVL53:
45:Src/main.c ****
785 .loc 1 45 0
786 0016 FFF7FEFF bl MX_USB_HID_INIT
787 .LVL54:
47:Src/main.c ****
788 .loc 1 47 0
789 001a 0822 movs r2, #8
790 001c 5F49 ldr r1, .L64
791 001e 6048 ldr r0, .L64+4
792 0020 FFF7FEFF bl HAL_ADC_Start_DMA
793 .LVL55:
794 0024 5AE0 b .L50
795 .LVL56:
796 .L35:
797 .LBB5:
55:Src/main.c **** }
ARM GAS /tmp/ccRWo4B1.s page 25
798 .loc 1 55 0 discriminator 3
799 0026 5300 lsls r3, r2, #1
800 0028 5E48 ldr r0, .L64+8
801 002a 1952 strh r1, [r3, r0]
802 .L36:
53:Src/main.c **** ADCval[i] = ADCreg[i];
803 .loc 1 53 0 discriminator 2
804 002c 0132 adds r2, r2, #1
805 .LVL57:
806 .L34:
53:Src/main.c **** ADCval[i] = ADCreg[i];
807 .loc 1 53 0 is_stmt 0 discriminator 1
808 002e 072A cmp r2, #7
809 0030 0FDC bgt .L51
54:Src/main.c **** if(ADCval[i] - ADClast[i] > 2000 || ADClast[i] - ADCval[i] > 2000 ) ADClast[i] = ADCval[i];
810 .loc 1 54 0 is_stmt 1
811 0032 5300 lsls r3, r2, #1
812 0034 5949 ldr r1, .L64
813 0036 595A ldrh r1, [r3, r1]
814 0038 5B48 ldr r0, .L64+12
815 003a 1952 strh r1, [r3, r0]
55:Src/main.c **** }
816 .loc 1 55 0
817 003c 5948 ldr r0, .L64+8
818 003e 1B5A ldrh r3, [r3, r0]
819 0040 CC1A subs r4, r1, r3
820 0042 FA20 movs r0, #250
821 0044 C000 lsls r0, r0, #3
822 0046 8442 cmp r4, r0
823 0048 EDDC bgt .L35
55:Src/main.c **** }
824 .loc 1 55 0 is_stmt 0 discriminator 2
825 004a 5B1A subs r3, r3, r1
826 004c 8342 cmp r3, r0
827 004e EDDD ble .L36
828 0050 E9E7 b .L35
829 .L51:
830 .LBE5:
59:Src/main.c **** sendVolUp();
831 .loc 1 59 0 is_stmt 1
832 0052 554B ldr r3, .L64+12
833 0054 1A88 ldrh r2, [r3]
834 .LVL58:
835 0056 534B ldr r3, .L64+8
836 0058 1B88 ldrh r3, [r3]
837 005a 1900 movs r1, r3
838 005c C831 adds r1, r1, #200
839 005e 8A42 cmp r2, r1
840 0060 3EDA bge .L52
62:Src/main.c **** sendVolDown();
841 .loc 1 62 0
842 0062 C83B subs r3, r3, #200
843 0064 9A42 cmp r2, r3
844 0066 42DD ble .L53
845 .L39:
73:Src/main.c **** kbd_send_ch('v');
846 .loc 1 73 0
ARM GAS /tmp/ccRWo4B1.s page 26
847 0068 4F4B ldr r3, .L64+12
848 006a 9A88 ldrh r2, [r3, #4]
849 006c 4D4B ldr r3, .L64+8
850 006e 9B88 ldrh r3, [r3, #4]
851 0070 1900 movs r1, r3
852 0072 C831 adds r1, r1, #200
853 0074 8A42 cmp r2, r1
854 0076 41DA bge .L54
76:Src/main.c **** kbd_send_ch('v');
855 .loc 1 76 0
856 0078 C83B subs r3, r3, #200
857 007a 9A42 cmp r2, r3
858 007c 46DD ble .L55
859 .L41:
82:Src/main.c **** kbd_send_ch('R');
860 .loc 1 82 0
861 007e 4A4B ldr r3, .L64+12
862 0080 DA88 ldrh r2, [r3, #6]
863 0082 484B ldr r3, .L64+8
864 0084 DB88 ldrh r3, [r3, #6]
865 0086 1900 movs r1, r3
866 0088 C831 adds r1, r1, #200
867 008a 8A42 cmp r2, r1
868 008c 46DA bge .L56
85:Src/main.c **** kbd_send_ch('r');
869 .loc 1 85 0
870 008e C83B subs r3, r3, #200
871 0090 9A42 cmp r2, r3
872 0092 4BDD ble .L57
873 .L43:
91:Src/main.c **** kbd_send_ch('n');
874 .loc 1 91 0
875 0094 444B ldr r3, .L64+12
876 0096 1A89 ldrh r2, [r3, #8]
877 0098 424B ldr r3, .L64+8
878 009a 1B89 ldrh r3, [r3, #8]
879 009c 1900 movs r1, r3
880 009e C831 adds r1, r1, #200
881 00a0 8A42 cmp r2, r1
882 00a2 4BDA bge .L58
94:Src/main.c **** kbd_send_ch('N');
883 .loc 1 94 0
884 00a4 C83B subs r3, r3, #200
885 00a6 9A42 cmp r2, r3
886 00a8 50DD ble .L59
887 .L45:
105:Src/main.c **** kbd_send_ch('w');
888 .loc 1 105 0
889 00aa 3F4B ldr r3, .L64+12
890 00ac 9A89 ldrh r2, [r3, #12]
891 00ae 3D4B ldr r3, .L64+8
892 00b0 9B89 ldrh r3, [r3, #12]
893 00b2 1900 movs r1, r3
894 00b4 C831 adds r1, r1, #200
895 00b6 8A42 cmp r2, r1
896 00b8 50DA bge .L60
108:Src/main.c **** kbd_send_ch('W');
ARM GAS /tmp/ccRWo4B1.s page 27
897 .loc 1 108 0
898 00ba C83B subs r3, r3, #200
899 00bc 9A42 cmp r2, r3
900 00be 55DD ble .L61
901 .L47:
114:Src/main.c **** kbd_send_raw(0x3a);
902 .loc 1 114 0
903 00c0 394B ldr r3, .L64+12
904 00c2 DA89 ldrh r2, [r3, #14]
905 00c4 374B ldr r3, .L64+8
906 00c6 DB89 ldrh r3, [r3, #14]
907 00c8 1900 movs r1, r3
908 00ca C831 adds r1, r1, #200
909 00cc 8A42 cmp r2, r1
910 00ce 55DA bge .L62
117:Src/main.c **** kbd_send_raw(0x3b);
911 .loc 1 117 0
912 00d0 C83B subs r3, r3, #200
913 00d2 9A42 cmp r2, r3
914 00d4 5ADD ble .L63
915 .L49:
126:Src/main.c **** }
916 .loc 1 126 0
917 00d6 0A20 movs r0, #10
918 00d8 FFF7FEFF bl HAL_Delay
919 .LVL59:
920 .L50:
921 .LBB6:
53:Src/main.c **** ADCval[i] = ADCreg[i];
922 .loc 1 53 0
923 00dc 0022 movs r2, #0
924 00de A6E7 b .L34
925 .LVL60:
926 .L52:
927 .LBE6:
60:Src/main.c **** ADClast[0] = ADCval[0];
928 .loc 1 60 0
929 00e0 FFF7FEFF bl sendVolUp
930 .LVL61:
61:Src/main.c **** } else if(ADCval[0] <= ADClast[0] - HYSTERESIS){
931 .loc 1 61 0
932 00e4 304B ldr r3, .L64+12
933 00e6 1A88 ldrh r2, [r3]
934 00e8 2E4B ldr r3, .L64+8
935 00ea 1A80 strh r2, [r3]
936 00ec BCE7 b .L39
937 .L53:
63:Src/main.c **** ADClast[0] = ADCval[0];
938 .loc 1 63 0
939 00ee FFF7FEFF bl sendVolDown
940 .LVL62:
64:Src/main.c **** }
941 .loc 1 64 0
942 00f2 2D4B ldr r3, .L64+12
943 00f4 1A88 ldrh r2, [r3]
944 00f6 2B4B ldr r3, .L64+8
945 00f8 1A80 strh r2, [r3]
ARM GAS /tmp/ccRWo4B1.s page 28
946 00fa B5E7 b .L39
947 .L54:
948 .LBB7:
74:Src/main.c **** ADClast[2] = ADCval[2];
949 .loc 1 74 0
950 00fc 7620 movs r0, #118
951 00fe FFF7FEFF bl kbd_send_ch
952 .LVL63:
75:Src/main.c **** } else if(ADCval[2] <= ADClast[2] - HYSTERESIS){
953 .loc 1 75 0
954 0102 294B ldr r3, .L64+12
955 0104 9A88 ldrh r2, [r3, #4]
956 0106 274B ldr r3, .L64+8
957 0108 9A80 strh r2, [r3, #4]
958 .LBE7:
959 010a B8E7 b .L41
960 .L55:
961 .LBB8:
77:Src/main.c **** ADClast[2] = ADCval[2];
962 .loc 1 77 0
963 010c 7620 movs r0, #118
964 010e FFF7FEFF bl kbd_send_ch
965 .LVL64:
78:Src/main.c **** }
966 .loc 1 78 0
967 0112 254B ldr r3, .L64+12
968 0114 9A88 ldrh r2, [r3, #4]
969 0116 234B ldr r3, .L64+8
970 0118 9A80 strh r2, [r3, #4]
971 011a B0E7 b .L41
972 .L56:
973 .LBE8:
974 .LBB9:
83:Src/main.c **** ADClast[3] = ADCval[3];
975 .loc 1 83 0
976 011c 5220 movs r0, #82
977 011e FFF7FEFF bl kbd_send_ch
978 .LVL65:
84:Src/main.c **** } else if(ADCval[3] <= ADClast[3] - HYSTERESIS){
979 .loc 1 84 0
980 0122 214B ldr r3, .L64+12
981 0124 DA88 ldrh r2, [r3, #6]
982 0126 1F4B ldr r3, .L64+8
983 0128 DA80 strh r2, [r3, #6]
984 .LBE9:
985 012a B3E7 b .L43
986 .L57:
987 .LBB10:
86:Src/main.c **** ADClast[3] = ADCval[3];
988 .loc 1 86 0
989 012c 7220 movs r0, #114
990 012e FFF7FEFF bl kbd_send_ch
991 .LVL66:
87:Src/main.c **** }
992 .loc 1 87 0
993 0132 1D4B ldr r3, .L64+12
994 0134 DA88 ldrh r2, [r3, #6]
ARM GAS /tmp/ccRWo4B1.s page 29
995 0136 1B4B ldr r3, .L64+8
996 0138 DA80 strh r2, [r3, #6]
997 013a ABE7 b .L43
998 .L58:
999 .LBE10:
1000 .LBB11:
92:Src/main.c **** ADClast[4] = ADCval[4];
1001 .loc 1 92 0
1002 013c 6E20 movs r0, #110
1003 013e FFF7FEFF bl kbd_send_ch
1004 .LVL67:
93:Src/main.c **** } else if(ADCval[4] <= ADClast[4] - HYSTERESIS){
1005 .loc 1 93 0
1006 0142 194B ldr r3, .L64+12
1007 0144 1A89 ldrh r2, [r3, #8]
1008 0146 174B ldr r3, .L64+8
1009 0148 1A81 strh r2, [r3, #8]
1010 .LBE11:
1011 014a AEE7 b .L45
1012 .L59:
1013 .LBB12:
95:Src/main.c **** ADClast[4] = ADCval[4];
1014 .loc 1 95 0
1015 014c 4E20 movs r0, #78
1016 014e FFF7FEFF bl kbd_send_ch
1017 .LVL68:
96:Src/main.c **** }
1018 .loc 1 96 0
1019 0152 154B ldr r3, .L64+12
1020 0154 1A89 ldrh r2, [r3, #8]
1021 0156 134B ldr r3, .L64+8
1022 0158 1A81 strh r2, [r3, #8]
1023 015a A6E7 b .L45
1024 .L60:
1025 .LBE12:
1026 .LBB13:
106:Src/main.c **** ADClast[6] = ADCval[6];
1027 .loc 1 106 0
1028 015c 7720 movs r0, #119
1029 015e FFF7FEFF bl kbd_send_ch
1030 .LVL69:
107:Src/main.c **** } else if(ADCval[6] <= ADClast[6] - HYSTERESIS){
1031 .loc 1 107 0
1032 0162 114B ldr r3, .L64+12
1033 0164 9A89 ldrh r2, [r3, #12]
1034 0166 0F4B ldr r3, .L64+8
1035 0168 9A81 strh r2, [r3, #12]
1036 .LBE13:
1037 016a A9E7 b .L47
1038 .L61:
1039 .LBB14:
109:Src/main.c **** ADClast[6] = ADCval[6];
1040 .loc 1 109 0
1041 016c 5720 movs r0, #87
1042 016e FFF7FEFF bl kbd_send_ch
1043 .LVL70:
110:Src/main.c **** }
ARM GAS /tmp/ccRWo4B1.s page 30
1044 .loc 1 110 0
1045 0172 0D4B ldr r3, .L64+12
1046 0174 9A89 ldrh r2, [r3, #12]
1047 0176 0B4B ldr r3, .L64+8
1048 0178 9A81 strh r2, [r3, #12]
1049 017a A1E7 b .L47
1050 .L62:
1051 .LBE14:
1052 .LBB15:
115:Src/main.c **** ADClast[7] = ADCval[7];
1053 .loc 1 115 0
1054 017c 3A20 movs r0, #58
1055 017e FFF7FEFF bl kbd_send_raw
1056 .LVL71:
116:Src/main.c **** } else if(ADCval[7] <= ADClast[7] - HYSTERESIS){
1057 .loc 1 116 0
1058 0182 094B ldr r3, .L64+12
1059 0184 DA89 ldrh r2, [r3, #14]
1060 0186 074B ldr r3, .L64+8
1061 0188 DA81 strh r2, [r3, #14]
1062 .LBE15:
1063 018a A4E7 b .L49
1064 .L63:
1065 .LBB16:
118:Src/main.c **** ADClast[7] = ADCval[7];
1066 .loc 1 118 0
1067 018c 3B20 movs r0, #59
1068 018e FFF7FEFF bl kbd_send_raw
1069 .LVL72:
119:Src/main.c **** }
1070 .loc 1 119 0
1071 0192 054B ldr r3, .L64+12
1072 0194 DA89 ldrh r2, [r3, #14]
1073 0196 034B ldr r3, .L64+8
1074 0198 DA81 strh r2, [r3, #14]
1075 019a 9CE7 b .L49
1076 .L65:
1077 .align 2
1078 .L64:
1079 019c 00000000 .word ADCreg
1080 01a0 00000000 .word hadc
1081 01a4 00000000 .word ADClast
1082 01a8 00000000 .word ADCval
1083 .LBE16:
1084 .cfi_endproc
1085 .LFE43:
1087 .section .text.Error_Handler,"ax",%progbits
1088 .align 1
1089 .global Error_Handler
1090 .syntax unified
1091 .code 16
1092 .thumb_func
1093 .fpu softvfp
1095 Error_Handler:
1096 .LFB53:
463:Src/main.c ****
464:Src/main.c **** void Error_Handler(void)
ARM GAS /tmp/ccRWo4B1.s page 31
465:Src/main.c **** {
1097 .loc 1 465 0
1098 .cfi_startproc
1099 @ Volatile: function does not return.
1100 @ args = 0, pretend = 0, frame = 0
1101 @ frame_needed = 0, uses_anonymous_args = 0
1102 0000 70B5 push {r4, r5, r6, lr}
1103 .LCFI15:
1104 .cfi_def_cfa_offset 16
1105 .cfi_offset 4, -16
1106 .cfi_offset 5, -12
1107 .cfi_offset 6, -8
1108 .cfi_offset 14, -4
1109 .L67:
466:Src/main.c **** while(1){
467:Src/main.c **** HAL_GPIO_WritePin(GPIOB,GPIO_PIN_13,1);
1110 .loc 1 467 0 discriminator 1
1111 0002 8025 movs r5, #128
1112 0004 AD01 lsls r5, r5, #6
1113 0006 094C ldr r4, .L68
1114 0008 0122 movs r2, #1
1115 000a 2900 movs r1, r5
1116 000c 2000 movs r0, r4
1117 000e FFF7FEFF bl HAL_GPIO_WritePin
1118 .LVL73:
468:Src/main.c **** HAL_Delay(100);
1119 .loc 1 468 0 discriminator 1
1120 0012 6420 movs r0, #100
1121 0014 FFF7FEFF bl HAL_Delay
1122 .LVL74:
469:Src/main.c **** HAL_GPIO_WritePin(GPIOB,GPIO_PIN_13,0);
1123 .loc 1 469 0 discriminator 1
1124 0018 0022 movs r2, #0
1125 001a 2900 movs r1, r5
1126 001c 2000 movs r0, r4
1127 001e FFF7FEFF bl HAL_GPIO_WritePin
1128 .LVL75:
470:Src/main.c **** HAL_Delay(100);
1129 .loc 1 470 0 discriminator 1
1130 0022 6420 movs r0, #100
1131 0024 FFF7FEFF bl HAL_Delay
1132 .LVL76:
1133 0028 EBE7 b .L67
1134 .L69:
1135 002a C046 .align 2
1136 .L68:
1137 002c 00040048 .word 1207960576
1138 .cfi_endproc
1139 .LFE53:
1141 .global scan_cvt
1142 .global _asciimap
1143 .comm ADClast,16,4
1144 .comm ADCval,16,4
1145 .comm ADCreg,16,4
1146 .comm kbd_report,9,4
1147 .comm hpcd_USB_FS,628,4
1148 .comm hdma_adc,68,4
ARM GAS /tmp/ccRWo4B1.s page 32
1149 .comm hadc,64,4
1150 .section .data.scan_cvt,"aw",%progbits
1151 .align 2
1152 .set .LANCHOR0,. + 0
1155 scan_cvt:
1156 0000 01000000 .word 1
1157 .section .rodata._asciimap,"a",%progbits
1158 .align 2
1161 _asciimap:
1162 0000 00 .byte 0
1163 0001 00 .byte 0
1164 0002 00 .byte 0
1165 0003 00 .byte 0
1166 0004 00 .byte 0
1167 0005 00 .byte 0
1168 0006 00 .byte 0
1169 0007 00 .byte 0
1170 0008 2A .byte 42
1171 0009 2B .byte 43
1172 000a 28 .byte 40
1173 000b 00 .byte 0
1174 000c 00 .byte 0
1175 000d 00 .byte 0
1176 000e 00 .byte 0
1177 000f 00 .byte 0
1178 0010 00 .byte 0
1179 0011 00 .byte 0
1180 0012 00 .byte 0
1181 0013 00 .byte 0
1182 0014 00 .byte 0
1183 0015 00 .byte 0
1184 0016 00 .byte 0
1185 0017 00 .byte 0
1186 0018 00 .byte 0
1187 0019 00 .byte 0
1188 001a 00 .byte 0
1189 001b 00 .byte 0
1190 001c 00 .byte 0
1191 001d 00 .byte 0
1192 001e 00 .byte 0
1193 001f 00 .byte 0
1194 0020 2C .byte 44
1195 0021 9E .byte -98
1196 0022 B4 .byte -76
1197 0023 A0 .byte -96
1198 0024 A1 .byte -95
1199 0025 A2 .byte -94
1200 0026 A4 .byte -92
1201 0027 34 .byte 52
1202 0028 A6 .byte -90
1203 0029 A7 .byte -89
1204 002a A5 .byte -91
1205 002b AE .byte -82
1206 002c 36 .byte 54
1207 002d 2D .byte 45
1208 002e 37 .byte 55
1209 002f 38 .byte 56
ARM GAS /tmp/ccRWo4B1.s page 33
1210 0030 27 .byte 39
1211 0031 1E .byte 30
1212 0032 1F .byte 31
1213 0033 20 .byte 32
1214 0034 21 .byte 33
1215 0035 22 .byte 34
1216 0036 23 .byte 35
1217 0037 24 .byte 36
1218 0038 25 .byte 37
1219 0039 26 .byte 38
1220 003a B3 .byte -77
1221 003b 33 .byte 51
1222 003c B6 .byte -74
1223 003d 2E .byte 46
1224 003e B7 .byte -73
1225 003f B8 .byte -72
1226 0040 9F .byte -97
1227 0041 84 .byte -124
1228 0042 85 .byte -123
1229 0043 86 .byte -122
1230 0044 87 .byte -121
1231 0045 88 .byte -120
1232 0046 89 .byte -119
1233 0047 8A .byte -118
1234 0048 8B .byte -117
1235 0049 8C .byte -116
1236 004a 8D .byte -115
1237 004b 8E .byte -114
1238 004c 8F .byte -113
1239 004d 90 .byte -112
1240 004e 91 .byte -111
1241 004f 92 .byte -110
1242 0050 93 .byte -109
1243 0051 94 .byte -108
1244 0052 95 .byte -107
1245 0053 96 .byte -106
1246 0054 97 .byte -105
1247 0055 98 .byte -104
1248 0056 99 .byte -103
1249 0057 9A .byte -102
1250 0058 9B .byte -101
1251 0059 9C .byte -100
1252 005a 9D .byte -99
1253 005b 2F .byte 47
1254 005c 31 .byte 49
1255 005d 30 .byte 48
1256 005e A3 .byte -93
1257 005f AD .byte -83
1258 0060 35 .byte 53
1259 0061 04 .byte 4
1260 0062 05 .byte 5
1261 0063 06 .byte 6
1262 0064 07 .byte 7
1263 0065 08 .byte 8
1264 0066 09 .byte 9
1265 0067 0A .byte 10
1266 0068 0B .byte 11
ARM GAS /tmp/ccRWo4B1.s page 34
1267 0069 0C .byte 12
1268 006a 0D .byte 13
1269 006b 0E .byte 14
1270 006c 0F .byte 15
1271 006d 10 .byte 16
1272 006e 11 .byte 17
1273 006f 12 .byte 18
1274 0070 13 .byte 19
1275 0071 14 .byte 20
1276 0072 15 .byte 21
1277 0073 16 .byte 22
1278 0074 17 .byte 23
1279 0075 18 .byte 24
1280 0076 19 .byte 25
1281 0077 1A .byte 26
1282 0078 1B .byte 27
1283 0079 1C .byte 28
1284 007a 1D .byte 29
1285 007b AF .byte -81
1286 007c B1 .byte -79
1287 007d B0 .byte -80
1288 007e B5 .byte -75
1289 007f 00 .byte 0
1290 .text
1291 .Letext0:
1292 .file 2 "/home/janhenrik/programme/gcc-arm-none-eabi-7-2018-q2-update/arm-none-eabi/include/machin
1293 .file 3 "/home/janhenrik/programme/gcc-arm-none-eabi-7-2018-q2-update/arm-none-eabi/include/sys/_s
1294 .file 4 "Drivers/CMSIS/Device/ST/STM32F0xx/Include/system_stm32f0xx.h"
1295 .file 5 "Drivers/CMSIS/Device/ST/STM32F0xx/Include/stm32f072xb.h"
1296 .file 6 "Drivers/CMSIS/Device/ST/STM32F0xx/Include/stm32f0xx.h"
1297 .file 7 "Drivers/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_def.h"
1298 .file 8 "Drivers/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_rcc.h"
1299 .file 9 "Drivers/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_rcc_ex.h"
1300 .file 10 "Drivers/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_gpio.h"
1301 .file 11 "Drivers/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_dma.h"
1302 .file 12 "Drivers/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_adc.h"
1303 .file 13 "Drivers/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_usb.h"
1304 .file 14 "Drivers/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_pcd.h"
1305 .file 15 "Drivers/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal.h"
1306 .file 16 "/home/janhenrik/programme/gcc-arm-none-eabi-7-2018-q2-update/arm-none-eabi/include/sys/l
1307 .file 17 "/home/janhenrik/programme/gcc-arm-none-eabi-7-2018-q2-update/arm-none-eabi/include/sys/_
1308 .file 18 "/home/janhenrik/programme/gcc-arm-none-eabi-7-2018-q2-update/lib/gcc/arm-none-eabi/7.3.1
1309 .file 19 "/home/janhenrik/programme/gcc-arm-none-eabi-7-2018-q2-update/arm-none-eabi/include/sys/r
1310 .file 20 "/home/janhenrik/programme/gcc-arm-none-eabi-7-2018-q2-update/arm-none-eabi/include/stdli
1311 .file 21 "Middlewares/ST/STM32_USB_Device_Library/Core/Inc/usbd_def.h"
1312 .file 22 "Inc/usb_device.h"
1313 .file 23 "Inc/usbd_hid.h"
1314 .file 24 "Drivers/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_cortex.h"
1315 .file 25 "<built-in>"
ARM GAS /tmp/ccRWo4B1.s page 35
DEFINED SYMBOLS
*ABS*:0000000000000000 main.c
/tmp/ccRWo4B1.s:16 .text.MX_GPIO_Init:0000000000000000 $t
/tmp/ccRWo4B1.s:22 .text.MX_GPIO_Init:0000000000000000 MX_GPIO_Init
/tmp/ccRWo4B1.s:100 .text.MX_GPIO_Init:000000000000005c $d
/tmp/ccRWo4B1.s:106 .text.MX_DMA_Init:0000000000000000 $t
/tmp/ccRWo4B1.s:112 .text.MX_DMA_Init:0000000000000000 MX_DMA_Init
/tmp/ccRWo4B1.s:154 .text.MX_DMA_Init:000000000000002c $d
/tmp/ccRWo4B1.s:159 .text.MX_ADC_Init:0000000000000000 $t
/tmp/ccRWo4B1.s:165 .text.MX_ADC_Init:0000000000000000 MX_ADC_Init
/tmp/ccRWo4B1.s:303 .text.MX_ADC_Init:00000000000000a8 $d
*COM*:0000000000000040 hadc
/tmp/ccRWo4B1.s:309 .text.kbd_send_ch:0000000000000000 $t
/tmp/ccRWo4B1.s:316 .text.kbd_send_ch:0000000000000000 kbd_send_ch
/tmp/ccRWo4B1.s:417 .text.kbd_send_ch:0000000000000070 $d
/tmp/ccRWo4B1.s:1161 .rodata._asciimap:0000000000000000 _asciimap
*COM*:0000000000000009 kbd_report
/tmp/ccRWo4B1.s:426 .text.kbd_send_raw:0000000000000000 $t
/tmp/ccRWo4B1.s:433 .text.kbd_send_raw:0000000000000000 kbd_send_raw
/tmp/ccRWo4B1.s:519 .text.kbd_send_raw:0000000000000060 $d
/tmp/ccRWo4B1.s:526 .text.sendVolUp:0000000000000000 $t
/tmp/ccRWo4B1.s:533 .text.sendVolUp:0000000000000000 sendVolUp
/tmp/ccRWo4B1.s:590 .text.sendVolUp:0000000000000038 $d
/tmp/ccRWo4B1.s:595 .text.sendVolDown:0000000000000000 $t
/tmp/ccRWo4B1.s:602 .text.sendVolDown:0000000000000000 sendVolDown
/tmp/ccRWo4B1.s:659 .text.sendVolDown:0000000000000038 $d
/tmp/ccRWo4B1.s:664 .text.SystemClock_Config:0000000000000000 $t
/tmp/ccRWo4B1.s:671 .text.SystemClock_Config:0000000000000000 SystemClock_Config
/tmp/ccRWo4B1.s:752 .text.main:0000000000000000 $t
/tmp/ccRWo4B1.s:759 .text.main:0000000000000000 main
/tmp/ccRWo4B1.s:1079 .text.main:000000000000019c $d
*COM*:0000000000000010 ADCreg
*COM*:0000000000000010 ADClast
*COM*:0000000000000010 ADCval
/tmp/ccRWo4B1.s:1088 .text.Error_Handler:0000000000000000 $t
/tmp/ccRWo4B1.s:1095 .text.Error_Handler:0000000000000000 Error_Handler
/tmp/ccRWo4B1.s:1137 .text.Error_Handler:000000000000002c $d
/tmp/ccRWo4B1.s:1155 .data.scan_cvt:0000000000000000 scan_cvt
*COM*:0000000000000274 hpcd_USB_FS
*COM*:0000000000000044 hdma_adc
/tmp/ccRWo4B1.s:1151 .data.scan_cvt:0000000000000000 $d
/tmp/ccRWo4B1.s:1158 .rodata._asciimap:0000000000000000 $d
UNDEFINED SYMBOLS
memset
HAL_GPIO_WritePin
HAL_GPIO_Init
HAL_NVIC_SetPriority
HAL_NVIC_EnableIRQ
HAL_ADC_Init
HAL_ADC_ConfigChannel
USBD_HID_SendReport
HAL_Delay
hUsbDeviceFS
HAL_RCC_OscConfig
HAL_RCC_ClockConfig
HAL_RCCEx_PeriphCLKConfig
ARM GAS /tmp/ccRWo4B1.s page 36
HAL_Init
MX_USB_HID_INIT
HAL_ADC_Start_DMA
|