Skip to content

Commit 8f951bd

Browse files
authored
Merge pull request #7407 from jepler/fix-unsigned-shift
Fix several mistakes discovered by clang scan-build
2 parents dc363e5 + ef8b297 commit 8f951bd

File tree

3 files changed

+9
-7
lines changed

3 files changed

+9
-7
lines changed

py/objtype.c

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -106,7 +106,9 @@ STATIC mp_obj_t native_base_init_wrapper(size_t n_args, const mp_obj_t *pos_args
106106
// copy in args
107107
memcpy(args2, pos_args, n_args * sizeof(mp_obj_t));
108108
// copy in kwargs
109-
memcpy(args2 + n_args, kw_args->table, 2 * n_kw * sizeof(mp_obj_t));
109+
if (n_kw) {
110+
memcpy(args2 + n_args, kw_args->table, 2 * n_kw * sizeof(mp_obj_t));
111+
}
110112
self->subobj[0] = native_base->make_new(native_base, n_args, n_kw, args2);
111113
m_del(mp_obj_t, args2, n_args + 2 * n_kw);
112114

shared-module/bitmaptools/__init__.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -689,7 +689,7 @@ STATIC void fill_row(displayio_bitmap_t *bitmap, int swap, int16_t *luminance_da
689689
static void write_pixels(displayio_bitmap_t *bitmap, int y, bool *data) {
690690
if (bitmap->bits_per_value == 1) {
691691
uint32_t *pixel_data = (uint32_t *)(bitmap->data + bitmap->stride * y);
692-
for (int i = 0; i < bitmap->stride; i++) {
692+
for (int i = 0; i < bitmap->width; i++) {
693693
uint32_t p = 0;
694694
for (int j = 0; j < 32; j++) {
695695
p = (p << 1);

shared-module/displayio/Bitmap.c

Lines changed: 5 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -30,12 +30,12 @@
3030

3131
#include "py/runtime.h"
3232

33-
enum { align_bits = 8 * sizeof(uint32_t) };
33+
enum { ALIGN_BITS = 8 * sizeof(uint32_t) };
3434

3535
static int stride(uint32_t width, uint32_t bits_per_value) {
3636
uint32_t row_width = width * bits_per_value;
3737
// align to uint32_t
38-
return (row_width + align_bits - 1) / align_bits;
38+
return (row_width + ALIGN_BITS - 1) / ALIGN_BITS;
3939
}
4040

4141
void common_hal_displayio_bitmap_construct(displayio_bitmap_t *self, uint32_t width,
@@ -66,12 +66,12 @@ void common_hal_displayio_bitmap_construct_from_buffer(displayio_bitmap_t *self,
6666
self->x_shift = 0; // Used to divide the index by the number of pixels per word. Its used in a
6767
// shift which effectively divides by 2 ** x_shift.
6868
uint32_t power_of_two = 1;
69-
while (power_of_two < align_bits / bits_per_value) {
69+
while (power_of_two < ALIGN_BITS / bits_per_value) {
7070
self->x_shift++;
7171
power_of_two <<= 1;
7272
}
73-
self->x_mask = (1 << self->x_shift) - 1; // Used as a modulus on the x value
74-
self->bitmask = (1 << bits_per_value) - 1;
73+
self->x_mask = (1u << self->x_shift) - 1u; // Used as a modulus on the x value
74+
self->bitmask = (1u << bits_per_value) - 1u;
7575

7676
self->dirty_area.x1 = 0;
7777
self->dirty_area.x2 = width;

0 commit comments

Comments
 (0)