質問編集履歴
3
誤字修正
title
CHANGED
File without changes
|
body
CHANGED
@@ -133,7 +133,7 @@
|
|
133
133
|
皆様、色々情報ありがとうございます。
|
134
134
|
|
135
135
|
7/28 追記
|
136
|
-
引き続き後試行錯誤してボードバージョン 2.0.0-rc1 (リリース予定版)だとサンプルそのままで
|
136
|
+
引き続き後試行錯誤してボードバージョン 2.0.0-rc1 (リリース予定版)だとサンプルそのままで動作する事を確認しました。
|
137
137
|
「Devices found:」も正しく件数が出ています。
|
138
138
|
```
|
139
139
|
Devices found: 57
|
2
バージョン変更により解決
title
CHANGED
File without changes
|
body
CHANGED
@@ -130,4 +130,32 @@
|
|
130
130
|
・・・
|
131
131
|
```
|
132
132
|
ずっと「Devices found: 0」なのが良く分かりませんがとりあえずだんまり現象は解決できました。
|
133
|
-
皆様、色々情報ありがとうございます。
|
133
|
+
皆様、色々情報ありがとうございます。
|
134
|
+
|
135
|
+
7/28 追記
|
136
|
+
引き続き後試行錯誤してボードバージョン 2.0.0-rc1 (リリース予定版)だとサンプルそのままで操作する事を確認しました。
|
137
|
+
「Devices found:」も正しく件数が出ています。
|
138
|
+
```
|
139
|
+
Devices found: 57
|
140
|
+
Scan done!
|
141
|
+
Advertised Device: Name: , Address: 0a:cd:d5:59:e0:ff, manufacturer data: 06000109200215843bdef33e24d0c4ef10afea45400eb0eff51827d36d
|
142
|
+
Advertised Device: Name: , Address: 7a:b0:91:0b:2d:b7, manufacturer data: 06000109200297ac09f696e93ebb30ad30e3a9a67ef8cc0791999b251c
|
143
|
+
```
|
144
|
+
また中国の開発元のサイト
|
145
|
+
https://m5stack.oss-cn-shenzhen.aliyuncs.com/resource/arduino/package_m5stack_index.json
|
146
|
+
を環境設定の追加のボードマネージャのURLに指定してダウンロードした 1.0.7 というバージョンでも動作する事を確認しました。
|
147
|
+
|
148
|
+
1.0.7 の方が安定している感じです。
|
149
|
+
|
150
|
+
開発元版だとボードマネージャの選択項目名が変わり以下の様になっています。
|
151
|
+
```ここに言語を入力
|
152
|
+
GitHub版
|
153
|
+
ESP32 Arduino
|
154
|
+
M5Stack-Core-ESP32
|
155
|
+
esp32 by Espressif System バージョン 2.0.0-rc1
|
156
|
+
開発元版
|
157
|
+
M5Stack Arduino
|
158
|
+
M5Stack-Core-ESP32
|
159
|
+
M5Stack by MSStack official バージョン1.0.7
|
160
|
+
|
161
|
+
```
|
1
Serial.printf の処理が重い
title
CHANGED
File without changes
|
body
CHANGED
@@ -49,4 +49,85 @@
|
|
49
49
|
delay(2000);
|
50
50
|
}
|
51
51
|
|
52
|
-
```
|
52
|
+
```
|
53
|
+
|
54
|
+
7/21 追記
|
55
|
+
その後いろいろ試してみて解決に至りました。
|
56
|
+
結論としては周辺にBLE機器多すぎて Serial.printf の処理が重くて処理が間に合わずハングアップしていたのが原因でした。
|
57
|
+
|
58
|
+
最初の状態でシリアルモニタは以下の様になります。
|
59
|
+
```
|
60
|
+
ets Jun 8 2016 00:22:57
|
61
|
+
|
62
|
+
rst:0x1 (POWERON_RESET),boot:0x17 (SPI_FAST_FLASH_BOOT)
|
63
|
+
configsip: 0, SPIWP:0xee
|
64
|
+
clk_drv:0x00,q_drv:0x00,d_drv:0x00,cs0_drv:0x00,hd_drv:0x00,wp_drv:0x00
|
65
|
+
mode:DIO, clock div:1
|
66
|
+
load:0x3fff0018,len:4
|
67
|
+
load:0x3fff001c,len:1216
|
68
|
+
ho 0 tail 12 room 4
|
69
|
+
load:0x40078000,len:10944
|
70
|
+
load:0x40080400,len:6388
|
71
|
+
entry 0x400806b4
|
72
|
+
Scanning...
|
73
|
+
Advertised Device: Name: , Address: 66:21:91:22:61:e5, manufacturer data: 060001092002ee2ebc0b680520079feaebf2a70a9621ef20155c55bcd6
|
74
|
+
Advertised Device: Name: , Address: 62:00:64:ce:af:4f, manufacturer data: 060001092002e000b6c55cf0e375d3c466f632382ef30c084e52ff9812
|
75
|
+
・・・
|
76
|
+
これが500件ほど続きその後だんまり
|
77
|
+
|
78
|
+
```
|
79
|
+
コールバック関数の Serial.printf をコメントにして実行
|
80
|
+
```
|
81
|
+
class MyAdvertisedDeviceCallbacks: public BLEAdvertisedDeviceCallbacks {
|
82
|
+
void onResult(BLEAdvertisedDevice advertisedDevice) {
|
83
|
+
//Serial.printf("Advertised Device: %s \n", advertisedDevice.toString().c_str());
|
84
|
+
}
|
85
|
+
};
|
86
|
+
```
|
87
|
+
すると
|
88
|
+
```
|
89
|
+
Scanning...
|
90
|
+
Devices found: 0
|
91
|
+
Scan done!
|
92
|
+
Devices found: 0
|
93
|
+
Scan done!
|
94
|
+
Devices found: 0
|
95
|
+
Scan done!
|
96
|
+
Devices found: 0
|
97
|
+
Scan done!
|
98
|
+
・・・
|
99
|
+
```
|
100
|
+
これは!
|
101
|
+
ということで以下の様に変更すると
|
102
|
+
```
|
103
|
+
std::map<std::string,int> addr_list;
|
104
|
+
|
105
|
+
class MyAdvertisedDeviceCallbacks: public BLEAdvertisedDeviceCallbacks {
|
106
|
+
void onResult(BLEAdvertisedDevice advertisedDevice) {
|
107
|
+
//Serial.printf("Advertised Device: %s \n", advertisedDevice.toString().c_str());
|
108
|
+
addr_list[advertisedDevice.toString()]++;
|
109
|
+
}
|
110
|
+
};
|
111
|
+
|
112
|
+
void loop() {
|
113
|
+
・・・
|
114
|
+
|
115
|
+
Serial.printf("addr_list counts: %d\n", (int)addr_list.size());
|
116
|
+
for(std::map<std::string,int>::iterator i=addr_list.begin(); i!=addr_list.end(); i++){
|
117
|
+
Serial.printf("%s %d\n", i->first.c_str(), i->second);
|
118
|
+
}
|
119
|
+
・・・
|
120
|
+
```
|
121
|
+
5秒間隔で定期的にメッセージが表示されました。
|
122
|
+
```
|
123
|
+
Devices found: 0
|
124
|
+
Scan done!
|
125
|
+
addr_list counts: 52
|
126
|
+
Name: , Address: 07:eb:bb:7b:fe:7a, manufacturer data: 060001092002dcdbf26eefcae892515b0091e34f109ea2d762d9f5d88a 5
|
127
|
+
Name: , Address: 0a:4a:ac:28:cf:e7, serviceUUID: 0000fd6f-0000-1000-8000-00805f9b34fb 1
|
128
|
+
Name: , Address: 10:55:c2:e3:a0:6d, serviceUUID: 0000fd6f-0000-1000-8000-00805f9b34fb 3
|
129
|
+
Name: , Address: 16:6f:7a:44:e7:da, serviceUUID: 0000fd6f-0000-1000-8000-00805f9b34fb 3
|
130
|
+
・・・
|
131
|
+
```
|
132
|
+
ずっと「Devices found: 0」なのが良く分かりませんがとりあえずだんまり現象は解決できました。
|
133
|
+
皆様、色々情報ありがとうございます。
|