Skip to content

Commit afd6869

Browse files
authored
Merge pull request #5800 from tannewt/rpi_zero
Initial Pi Zero support
2 parents 513a954 + 5256748 commit afd6869

File tree

19 files changed

+260
-55
lines changed

19 files changed

+260
-55
lines changed

lib/sdmmc/sdmmc_io.c

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -420,7 +420,10 @@ static sdmmc_err_t cis_tuple_func_manfid(const void* p, uint8_t* data, FILE* fp)
420420
int size = *(data++);
421421
fprintf(fp, "TUPLE: %s, size: %d\n", tuple->name, size);
422422
CIS_CHECK_SIZE(size, 4);
423+
#pragma GCC diagnostic push
424+
#pragma GCC diagnostic ignored "-Wcast-align"
423425
fprintf(fp, " MANF: %04X, CARD: %04X\n", *(uint16_t*)(data), *(uint16_t*)(data+2));
426+
#pragma GCC diagnostic pop
424427
return SDMMC_OK;
425428
}
426429

@@ -480,7 +483,10 @@ static sdmmc_err_t cis_tuple_func_cftable_entry(const void* p, uint8_t* data, FI
480483
CIS_CHECK_SIZE(size, 2);
481484
size-=2;
482485
CIS_CHECK_UNSUPPORTED(mem_space==1); //other cases not handled yet
486+
#pragma GCC diagnostic push
487+
#pragma GCC diagnostic ignored "-Wcast-align"
483488
int len = *(uint16_t*)data;
489+
#pragma GCC diagnostic pop
484490
fprintf(fp, " LEN: %04X\n", len);
485491
data+=2;
486492
}

lib/tinyusb

Submodule tinyusb updated 156 files

main.c

Lines changed: 4 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -812,9 +812,10 @@ int __attribute__((used)) main(void) {
812812
// A power brownout here could make it appear as if there's
813813
// no SPI flash filesystem, and we might erase the existing one.
814814

815-
// Check whether CIRCUITPY is available. Don't check if it already hasn't been found.
816-
if ((safe_mode != NO_CIRCUITPY) && !filesystem_init(safe_mode == NO_SAFE_MODE, false)) {
817-
reset_into_safe_mode(NO_CIRCUITPY);
815+
// Check whether CIRCUITPY is available. No need to reset to get safe mode
816+
// since we haven't run user code yet.
817+
if (!filesystem_init(safe_mode == NO_SAFE_MODE, false)) {
818+
safe_mode = NO_CIRCUITPY;
818819
}
819820

820821
// displays init after filesystem, since they could share the flash SPI

ports/broadcom/Makefile

Lines changed: 23 additions & 19 deletions
Original file line numberDiff line numberDiff line change
@@ -31,7 +31,20 @@ include $(TOP)/supervisor/supervisor.mk
3131
# Include make rules and variables common across CircuitPython builds.
3232
include $(TOP)/py/circuitpy_defns.mk
3333

34-
HAL_DIR=hal/$(MCU_SERIES)
34+
ifeq ($(CHIP_VARIANT), "bcm2711")
35+
CFLAGS += -mcpu=cortex-a72 -DBCM_VERSION=2711
36+
CROSS_COMPILE = aarch64-none-elf-
37+
SUFFIX = 8
38+
else ifeq ($(CHIP_VARIANT), "bcm2837")
39+
CFLAGS += -mcpu=cortex-a53 -DBCM_VERSION=2837
40+
CROSS_COMPILE = aarch64-none-elf-
41+
SUFFIX = 8
42+
else ifeq ($(CHIP_VARIANT), "bcm2835")
43+
CFLAGS += -mcpu=arm1176jzf-s -DBCM_VERSION=2835
44+
CROSS_COMPILE = arm-none-eabi-
45+
SUFFIX =
46+
# TODO add 32-bit support for Cortex-A7 in 2836
47+
endif
3548

3649
INC += -I. \
3750
-I../.. \
@@ -69,6 +82,7 @@ SRC_C += bindings/videocore/__init__.c \
6982
peripherals/broadcom/mmu.c \
7083
peripherals/broadcom/vcmailbox.c
7184

85+
SRC_S = peripherals/broadcom/boot$(SUFFIX).s
7286

7387
SRC_COMMON_HAL_EXPANDED = $(addprefix shared-bindings/, $(SRC_COMMON_HAL)) \
7488
$(addprefix shared-bindings/, $(SRC_BINDINGS_ENUMS)) \
@@ -82,7 +96,6 @@ SRC_SHARED_MODULE_EXPANDED = $(addprefix shared-bindings/, $(SRC_SHARED_MODULE))
8296
# because a few modules have files both in common-hal/ and shared-modules/.
8397
# Doing a $(sort ...) removes duplicates as part of sorting.
8498
SRC_COMMON_HAL_SHARED_MODULE_EXPANDED = $(sort $(SRC_COMMON_HAL_EXPANDED) $(SRC_SHARED_MODULE_EXPANDED))
85-
SRC_S = peripherals/broadcom/boot8.s
8699

87100
OBJ = $(PY_O) $(SUPERVISOR_O) $(addprefix $(BUILD)/, $(SRC_C:.c=.o))
88101
OBJ += $(addprefix $(BUILD)/, $(SRC_COMMON_HAL_SHARED_MODULE_EXPANDED:.c=.o))
@@ -96,15 +109,6 @@ OBJ += $(addprefix $(BUILD)/, $(SRC_MOD:.c=.o))
96109
# BCM CLFAGS
97110
CFLAGS += -ffreestanding -nostartfiles -DMICROPY_HW_MCU_NAME="\"$(CHIP_VARIANT)\""
98111

99-
ifeq ($(CHIP_VARIANT), "bcm2711")
100-
CFLAGS += -mcpu=cortex-a72 -DBCM_VERSION=2711
101-
CROSS_COMPILE = aarch64-none-elf-
102-
else
103-
CFLAGS += -mcpu=cortex-a53 -DBCM_VERSION=2837
104-
CROSS_COMPILE = aarch64-none-elf-
105-
# TODO add 32-bit support for Cortex-A7 and ARM1176
106-
endif
107-
108112

109113
OPTIMIZATION_FLAGS ?= -O3
110114
CFLAGS += $(OPTIMIZATION_FLAGS)
@@ -134,40 +138,40 @@ CFLAGS += $(INC) -Wall -Werror -std=gnu11 $(BASE_CFLAGS) $(CFLAGS_MOD) $(COPT) $
134138

135139
SRC_QSTR += $(SRC_C) $(SRC_SUPERVISOR) $(SRC_COMMON_HAL_EXPANDED) $(SRC_SHARED_MODULE_EXPANDED)
136140

137-
LDFLAGS += $(CFLAGS) -T peripherals/broadcom/link8.ld -Wl,--gc-sections -Wl,-Map=$@.map # -Wl,--cref
141+
LDFLAGS += $(CFLAGS) -T peripherals/broadcom/link$(SUFFIX).ld -Wl,--gc-sections -Wl,-Map=$@.map # -Wl,--cref
138142

139143
# Use toolchain libm if we're not using our own.
140144
ifndef INTERNAL_LIBM
141145
LIBS += -lm
142146
endif
143147

144-
all: $(BUILD)/firmware.kernel8.img $(BUILD)/firmware.disk.img.zip
148+
all: $(BUILD)/firmware.kernel$(SUFFIX).img $(BUILD)/firmware.disk.img.zip
145149

146150
%.o: %.c
147151
$(CC) $(CFLAGS) -c $< -o $@
148152

149-
$(BUILD)/kernel8.elf: $(OBJ)
153+
$(BUILD)/kernel$(SUFFIX).elf: $(OBJ)
150154
$(STEPECHO) "LINK $@"
151155
$(Q)echo $(OBJ) > $(BUILD)/firmware.objs
152156
$(Q)$(CC) -o $@ $(LDFLAGS) @$(BUILD)/firmware.objs -Wl,--start-group $(LIBS) -Wl,--end-group
153157

154-
$(BUILD)/kernel8.img: $(BUILD)/kernel8.elf
158+
$(BUILD)/kernel$(SUFFIX).img: $(BUILD)/kernel$(SUFFIX).elf
155159
$(STEPECHO) "Create $@"
156-
$(OBJCOPY) -O binary $(BUILD)/kernel8.elf $@
160+
$(OBJCOPY) -O binary $(BUILD)/kernel$(SUFFIX).elf $@
157161

158-
$(BUILD)/firmware.kernel8.img: $(BUILD)/kernel8.img
162+
$(BUILD)/firmware.kernel$(SUFFIX).img: $(BUILD)/kernel$(SUFFIX).img
159163
$(STEPECHO) "Create $@"
160164
$(CP) $^ $@
161165

162-
$(BUILD)/firmware.disk.img.zip: $(BUILD)/kernel8.img
166+
$(BUILD)/firmware.disk.img.zip: $(BUILD)/kernel$(SUFFIX).img
163167
$(STEPECHO) "Create $@"
164168
$(Q)dd if=/dev/zero of=$(BUILD)/circuitpython-disk.img bs=1 count=0 seek=256M
165169
$(Q)parted -s $(BUILD)/circuitpython-disk.img mktable msdos
166170
$(Q)parted -s $(BUILD)/circuitpython-disk.img mkpart primary fat32 0% 100%
167171
$(Q)mkfs.fat -F 32 -n BOOT --offset=2048 $(BUILD)/circuitpython-disk.img
168172

169173
$(Q)mcopy -i $(BUILD)/circuitpython-disk.img@@1M config.txt firmware/bootcode.bin firmware/fixup* firmware/start* firmware/*.dtb ::
170-
$(Q)mcopy -i $(BUILD)/circuitpython-disk.img@@1M $(BUILD)/kernel8.img ::
174+
$(Q)mcopy -i $(BUILD)/circuitpython-disk.img@@1M $(BUILD)/kernel$(SUFFIX).img ::
171175
$(Q)zip $@ $(BUILD)/circuitpython-disk.img
172176
$(Q)rm $(BUILD)/circuitpython-disk.img
173177

Lines changed: 56 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,56 @@
1+
/*
2+
* This file is part of the MicroPython project, http://micropython.org/
3+
*
4+
* The MIT License (MIT)
5+
*
6+
* Copyright (c) 2021 Scott Shawcroft for Adafruit Industries
7+
*
8+
* Permission is hereby granted, free of charge, to any person obtaining a copy
9+
* of this software and associated documentation files (the "Software"), to deal
10+
* in the Software without restriction, including without limitation the rights
11+
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12+
* copies of the Software, and to permit persons to whom the Software is
13+
* furnished to do so, subject to the following conditions:
14+
*
15+
* The above copyright notice and this permission notice shall be included in
16+
* all copies or substantial portions of the Software.
17+
*
18+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24+
* THE SOFTWARE.
25+
*/
26+
27+
#include "supervisor/board.h"
28+
#include "mpconfigboard.h"
29+
30+
#include "bindings/videocore/Framebuffer.h"
31+
#include "shared-module/displayio/__init__.h"
32+
#include "shared-bindings/framebufferio/FramebufferDisplay.h"
33+
34+
void board_init(void) {
35+
videocore_framebuffer_obj_t *fb = &allocate_display_bus()->videocore;
36+
fb->base.type = &videocore_framebuffer_type;
37+
common_hal_videocore_framebuffer_construct(fb, 640, 480);
38+
39+
framebufferio_framebufferdisplay_obj_t *display = &displays[0].framebuffer_display;
40+
display->base.type = &framebufferio_framebufferdisplay_type;
41+
common_hal_framebufferio_framebufferdisplay_construct(
42+
display,
43+
MP_OBJ_FROM_PTR(fb),
44+
0,
45+
true);
46+
}
47+
48+
bool board_requests_safe_mode(void) {
49+
return false;
50+
}
51+
52+
void reset_board(void) {
53+
}
54+
55+
void board_deinit(void) {
56+
}
Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,6 @@
1+
#define MICROPY_HW_BOARD_NAME "Raspberry Pi Zero W"
2+
3+
#define DEFAULT_I2C_BUS_SCL (&pin_GPIO3)
4+
#define DEFAULT_I2C_BUS_SDA (&pin_GPIO2)
5+
6+
#define MICROPY_HW_LED_STATUS (&pin_GPIO47)
Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,6 @@
1+
USB_VID = 0x2E8A
2+
USB_PID = 0xf015
3+
USB_PRODUCT = "Raspberry Pi Zero"
4+
USB_MANUFACTURER = "Raspberry Pi"
5+
6+
CHIP_VARIANT = "bcm2835"
Lines changed: 62 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,62 @@
1+
#include "shared-bindings/board/__init__.h"
2+
3+
#include "shared-module/displayio/__init__.h"
4+
5+
STATIC const mp_rom_map_elem_t board_global_dict_table[] = {
6+
CIRCUITPYTHON_BOARD_DICT_STANDARD_ITEMS
7+
// These match the names used in Blinka
8+
{ MP_ROM_QSTR(MP_QSTR_D0), MP_ROM_PTR(&pin_GPIO0) },
9+
{ MP_ROM_QSTR(MP_QSTR_D1), MP_ROM_PTR(&pin_GPIO1) },
10+
11+
{ MP_ROM_QSTR(MP_QSTR_D2), MP_ROM_PTR(&pin_GPIO2) },
12+
{ MP_ROM_QSTR(MP_QSTR_SDA), MP_ROM_PTR(&pin_GPIO2) },
13+
{ MP_ROM_QSTR(MP_QSTR_D3), MP_ROM_PTR(&pin_GPIO3) },
14+
{ MP_ROM_QSTR(MP_QSTR_SCL), MP_ROM_PTR(&pin_GPIO3) },
15+
16+
{ MP_ROM_QSTR(MP_QSTR_D4), MP_ROM_PTR(&pin_GPIO4) },
17+
{ MP_ROM_QSTR(MP_QSTR_D5), MP_ROM_PTR(&pin_GPIO5) },
18+
{ MP_ROM_QSTR(MP_QSTR_D6), MP_ROM_PTR(&pin_GPIO6) },
19+
20+
{ MP_ROM_QSTR(MP_QSTR_D7), MP_ROM_PTR(&pin_GPIO7) },
21+
{ MP_ROM_QSTR(MP_QSTR_CE1), MP_ROM_PTR(&pin_GPIO7) },
22+
{ MP_ROM_QSTR(MP_QSTR_D8), MP_ROM_PTR(&pin_GPIO8) },
23+
{ MP_ROM_QSTR(MP_QSTR_CE0), MP_ROM_PTR(&pin_GPIO8) },
24+
{ MP_ROM_QSTR(MP_QSTR_D9), MP_ROM_PTR(&pin_GPIO9) },
25+
{ MP_ROM_QSTR(MP_QSTR_MISO), MP_ROM_PTR(&pin_GPIO9) },
26+
{ MP_ROM_QSTR(MP_QSTR_D10), MP_ROM_PTR(&pin_GPIO10) },
27+
{ MP_ROM_QSTR(MP_QSTR_MOSI), MP_ROM_PTR(&pin_GPIO10) },
28+
{ MP_ROM_QSTR(MP_QSTR_D11), MP_ROM_PTR(&pin_GPIO11) },
29+
{ MP_ROM_QSTR(MP_QSTR_SCLK), MP_ROM_PTR(&pin_GPIO11) },
30+
{ MP_ROM_QSTR(MP_QSTR_SCK), MP_ROM_PTR(&pin_GPIO11) },
31+
32+
{ MP_ROM_QSTR(MP_QSTR_D12), MP_ROM_PTR(&pin_GPIO12) },
33+
{ MP_ROM_QSTR(MP_QSTR_D13), MP_ROM_PTR(&pin_GPIO13) },
34+
35+
{ MP_ROM_QSTR(MP_QSTR_D14), MP_ROM_PTR(&pin_GPIO14) },
36+
{ MP_ROM_QSTR(MP_QSTR_TXD), MP_ROM_PTR(&pin_GPIO14) },
37+
{ MP_ROM_QSTR(MP_QSTR_D15), MP_ROM_PTR(&pin_GPIO15) },
38+
{ MP_ROM_QSTR(MP_QSTR_RXD), MP_ROM_PTR(&pin_GPIO15) },
39+
{ MP_ROM_QSTR(MP_QSTR_TX), MP_ROM_PTR(&pin_GPIO14) },
40+
{ MP_ROM_QSTR(MP_QSTR_RX), MP_ROM_PTR(&pin_GPIO15) },
41+
42+
{ MP_ROM_QSTR(MP_QSTR_D16), MP_ROM_PTR(&pin_GPIO16) },
43+
{ MP_ROM_QSTR(MP_QSTR_D17), MP_ROM_PTR(&pin_GPIO17) },
44+
{ MP_ROM_QSTR(MP_QSTR_D18), MP_ROM_PTR(&pin_GPIO18) },
45+
{ MP_ROM_QSTR(MP_QSTR_D19), MP_ROM_PTR(&pin_GPIO19) },
46+
{ MP_ROM_QSTR(MP_QSTR_MISO_1), MP_ROM_PTR(&pin_GPIO19) },
47+
{ MP_ROM_QSTR(MP_QSTR_D20), MP_ROM_PTR(&pin_GPIO20) },
48+
{ MP_ROM_QSTR(MP_QSTR_MOSI_1), MP_ROM_PTR(&pin_GPIO20) },
49+
{ MP_ROM_QSTR(MP_QSTR_D21), MP_ROM_PTR(&pin_GPIO21) },
50+
{ MP_ROM_QSTR(MP_QSTR_SCLK_1), MP_ROM_PTR(&pin_GPIO21) },
51+
{ MP_ROM_QSTR(MP_QSTR_SCK_1), MP_ROM_PTR(&pin_GPIO21) },
52+
{ MP_ROM_QSTR(MP_QSTR_D22), MP_ROM_PTR(&pin_GPIO22) },
53+
{ MP_ROM_QSTR(MP_QSTR_D23), MP_ROM_PTR(&pin_GPIO23) },
54+
{ MP_ROM_QSTR(MP_QSTR_D24), MP_ROM_PTR(&pin_GPIO24) },
55+
{ MP_ROM_QSTR(MP_QSTR_D25), MP_ROM_PTR(&pin_GPIO25) },
56+
{ MP_ROM_QSTR(MP_QSTR_D26), MP_ROM_PTR(&pin_GPIO26) },
57+
{ MP_ROM_QSTR(MP_QSTR_D27), MP_ROM_PTR(&pin_GPIO27) },
58+
59+
{ MP_ROM_QSTR(MP_QSTR_I2C), MP_ROM_PTR(&board_i2c_obj) },
60+
{ MP_ROM_QSTR(MP_QSTR_DISPLAY), MP_ROM_PTR(&displays[0].display)},
61+
};
62+
MP_DEFINE_CONST_DICT(board_module_globals, board_global_dict_table);

ports/broadcom/common-hal/neopixel_write/__init__.c

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -48,9 +48,9 @@ void common_hal_neopixel_write(const digitalio_digitalinout_obj_t *digitalinout,
4848
while (port_get_raw_ticks(NULL) < next_start_raw_ticks) {
4949
}
5050

51-
BP_Function_Enum alt_function;
52-
uint8_t index;
53-
uint8_t channel;
51+
BP_Function_Enum alt_function = GPIO_FUNCTION_OUTPUT;
52+
uint8_t index = 0;
53+
uint8_t channel = 0;
5454
bool found = false;
5555
for (size_t i = 0; i < NUM_ALT_FUNC; i++) {
5656
const pin_function_t *f = &digitalinout->pin->functions[i];

0 commit comments

Comments
 (0)