summaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorDamien George <damien.p.george@gmail.com>2015-01-25 17:11:47 +0000
committerDamien George <damien.p.george@gmail.com>2015-01-25 17:11:47 +0000
commit4b35a5464cc815c1c09e036dd87c47f5f36fa211 (patch)
tree92735e24fc5674c184d1e79b06c513c77c7c56f1
parent552f7c40a0c98fdd3bbf89f7d4ebf23e342e0c01 (diff)
parent5fb775a0c059d187366525ff66be1c892a7b3302 (diff)
downloadmicropython-4b35a5464cc815c1c09e036dd87c47f5f36fa211.tar.gz
micropython-4b35a5464cc815c1c09e036dd87c47f5f36fa211.zip
Merge branch 'master' of github.com:micropython/micropython
-rw-r--r--esp8266/Makefile1
-rw-r--r--esp8266/modesp.c91
-rw-r--r--esp8266/mpconfigport.h2
-rw-r--r--esp8266/qstrdefsport.h3
4 files changed, 97 insertions, 0 deletions
diff --git a/esp8266/Makefile b/esp8266/Makefile
index 1654ec760b..c5f6231a19 100644
--- a/esp8266/Makefile
+++ b/esp8266/Makefile
@@ -48,6 +48,7 @@ SRC_C = \
pybstdio.c \
uart.c \
modpyb.c \
+ modesp.c \
STM_SRC_C = $(addprefix stmhal/,\
printf.c \
diff --git a/esp8266/modesp.c b/esp8266/modesp.c
new file mode 100644
index 0000000000..70df5ba360
--- /dev/null
+++ b/esp8266/modesp.c
@@ -0,0 +1,91 @@
+/*
+ * This file is part of the Micro Python project, http://micropython.org/
+ *
+ * The MIT License (MIT)
+ *
+ * Copyright (c) 2015 Paul Sokolovsky
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
+ * of this software and associated documentation files (the "Software"), to deal
+ * in the Software without restriction, including without limitation the rights
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ * copies of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+ * THE SOFTWARE.
+ */
+
+#include <stdio.h>
+#include <string.h>
+#include <stdbool.h>
+
+#include "py/nlr.h"
+#include "py/obj.h"
+#include "py/gc.h"
+#include "py/runtime.h"
+#include "py/pfenv.h"
+#include MICROPY_HAL_H
+#include "queue.h"
+#include "user_interface.h"
+
+// Singleton instance of scan callback, meaning that there can be only
+// one concurrent AP scan.
+STATIC mp_obj_t scan_cb_obj;
+
+mp_obj_t call_function_1_protected(mp_obj_t fun, mp_obj_t arg) {
+ nlr_buf_t nlr;
+ if (nlr_push(&nlr) == 0) {
+ return mp_call_function_1(fun, arg);
+ } else {
+ mp_obj_print_exception(printf_wrapper, NULL, (mp_obj_t)nlr.ret_val);
+ return (mp_obj_t)nlr.ret_val;
+ }
+}
+
+STATIC void esp_scan_cb(scaninfo *si, STATUS status) {
+ //printf("in pyb_scan_cb: %d, si=%p, si->pbss=%p\n", status, si, si->pbss);
+ struct bss_info *bs;
+ if (si->pbss) {
+ STAILQ_FOREACH(bs, si->pbss, next) {
+ mp_obj_tuple_t *t = mp_obj_new_tuple(6, NULL);
+ t->items[0] = mp_obj_new_bytes(bs->ssid, strlen((char*)bs->ssid));
+ t->items[1] = mp_obj_new_bytes(bs->bssid, sizeof(bs->bssid));
+ t->items[2] = MP_OBJ_NEW_SMALL_INT(bs->channel);
+ t->items[3] = MP_OBJ_NEW_SMALL_INT(bs->rssi);
+ t->items[4] = MP_OBJ_NEW_SMALL_INT(bs->authmode);
+ t->items[5] = MP_OBJ_NEW_SMALL_INT(bs->is_hidden);
+ call_function_1_protected(scan_cb_obj, t);
+ }
+ }
+}
+
+STATIC mp_obj_t esp_scan(mp_obj_t cb_in) {
+ scan_cb_obj = cb_in;
+ wifi_set_opmode(STATION_MODE);
+ wifi_station_scan(NULL, (scan_done_cb_t)esp_scan_cb);
+ return mp_const_none;
+}
+STATIC MP_DEFINE_CONST_FUN_OBJ_1(esp_scan_obj, esp_scan);
+
+STATIC const mp_map_elem_t esp_module_globals_table[] = {
+ { MP_OBJ_NEW_QSTR(MP_QSTR___name__), MP_OBJ_NEW_QSTR(MP_QSTR_esp) },
+
+ { MP_OBJ_NEW_QSTR(MP_QSTR_scan), (mp_obj_t)&esp_scan_obj },
+};
+
+STATIC MP_DEFINE_CONST_DICT(esp_module_globals, esp_module_globals_table);
+
+const mp_obj_module_t esp_module = {
+ .base = { &mp_type_module },
+ .name = MP_QSTR_esp,
+ .globals = (mp_obj_dict_t*)&esp_module_globals,
+};
diff --git a/esp8266/mpconfigport.h b/esp8266/mpconfigport.h
index c1cdcb3402..7e7f0fdbac 100644
--- a/esp8266/mpconfigport.h
+++ b/esp8266/mpconfigport.h
@@ -59,9 +59,11 @@ extern const struct _mp_obj_fun_builtin_t mp_builtin_open_obj;
// extra built in modules to add to the list of known ones
extern const struct _mp_obj_module_t pyb_module;
+extern const struct _mp_obj_module_t esp_module;
#define MICROPY_PORT_BUILTIN_MODULES \
{ MP_OBJ_NEW_QSTR(MP_QSTR_pyb), (mp_obj_t)&pyb_module }, \
+ { MP_OBJ_NEW_QSTR(MP_QSTR_esp), (mp_obj_t)&esp_module }, \
#define MP_STATE_PORT MP_STATE_VM
diff --git a/esp8266/qstrdefsport.h b/esp8266/qstrdefsport.h
index 41d6414380..d6c936bc2b 100644
--- a/esp8266/qstrdefsport.h
+++ b/esp8266/qstrdefsport.h
@@ -40,3 +40,6 @@ Q(delay)
Q(udelay)
Q(sync)
Q(hard_reset)
+
+Q(esp)
+Q(scan)