You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
456 lines
16 KiB
456 lines
16 KiB
#include <stdio.h>
|
|
#include <string.h>
|
|
|
|
#include "freertos/FreeRTOS.h"
|
|
#include "freertos/task.h"
|
|
#include "driver/gpio.h"
|
|
#include "soc/gpio_struct.h"
|
|
#include "soc/gpio_reg.h"
|
|
#include "rom/ets_sys.h"
|
|
|
|
#include "HUB75.h"
|
|
#include "Pines.h"
|
|
|
|
void HUB75_init(void)
|
|
{
|
|
gpio_reset_pin(HUB75_OE_Pin);
|
|
gpio_reset_pin(HUB75_LATCH_Pin);
|
|
gpio_reset_pin(HUB75_ADDR_C_Pin);
|
|
gpio_reset_pin(HUB75_ADDR_B_Pin);
|
|
gpio_reset_pin(HUB75_ADDR_A_Pin);
|
|
gpio_reset_pin(HUB75_CLK_Pin);
|
|
gpio_reset_pin(HUB75_U_R1_Pin);
|
|
gpio_reset_pin(HUB75_U_G1_Pin);
|
|
gpio_reset_pin(HUB75_U_B1_Pin);
|
|
gpio_reset_pin(HUB75_U_R2_Pin);
|
|
gpio_reset_pin(HUB75_U_G2_Pin);
|
|
gpio_reset_pin(HUB75_U_B2_Pin);
|
|
gpio_reset_pin(HUB75_D_R1_Pin);
|
|
gpio_reset_pin(HUB75_D_G1_Pin);
|
|
gpio_reset_pin(HUB75_D_B1_Pin);
|
|
gpio_reset_pin(HUB75_D_R2_Pin);
|
|
gpio_reset_pin(HUB75_D_G2_Pin);
|
|
gpio_reset_pin(HUB75_D_B2_Pin);
|
|
|
|
gpio_set_direction(HUB75_OE_Pin, GPIO_MODE_DEF_OUTPUT);
|
|
gpio_set_direction(HUB75_LATCH_Pin, GPIO_MODE_DEF_OUTPUT);
|
|
gpio_set_direction(HUB75_ADDR_C_Pin, GPIO_MODE_DEF_OUTPUT);
|
|
gpio_set_direction(HUB75_ADDR_B_Pin, GPIO_MODE_DEF_OUTPUT);
|
|
gpio_set_direction(HUB75_ADDR_A_Pin, GPIO_MODE_DEF_OUTPUT);
|
|
gpio_set_direction(HUB75_CLK_Pin, GPIO_MODE_DEF_OUTPUT);
|
|
gpio_set_direction(HUB75_U_R1_Pin, GPIO_MODE_DEF_OUTPUT);
|
|
gpio_set_direction(HUB75_U_G1_Pin, GPIO_MODE_DEF_OUTPUT);
|
|
gpio_set_direction(HUB75_U_B1_Pin, GPIO_MODE_DEF_OUTPUT);
|
|
gpio_set_direction(HUB75_U_R2_Pin, GPIO_MODE_DEF_OUTPUT);
|
|
gpio_set_direction(HUB75_U_G2_Pin, GPIO_MODE_DEF_OUTPUT);
|
|
gpio_set_direction(HUB75_U_B2_Pin, GPIO_MODE_DEF_OUTPUT);
|
|
gpio_set_direction(HUB75_D_R1_Pin, GPIO_MODE_DEF_OUTPUT);
|
|
gpio_set_direction(HUB75_D_G1_Pin, GPIO_MODE_DEF_OUTPUT);
|
|
gpio_set_direction(HUB75_D_B1_Pin, GPIO_MODE_DEF_OUTPUT);
|
|
gpio_set_direction(HUB75_D_R2_Pin, GPIO_MODE_DEF_OUTPUT);
|
|
gpio_set_direction(HUB75_D_G2_Pin, GPIO_MODE_DEF_OUTPUT);
|
|
gpio_set_direction(HUB75_D_B2_Pin, GPIO_MODE_DEF_OUTPUT);
|
|
|
|
gpio_set_level(HUB75_OE_Pin, 1);
|
|
gpio_set_level(HUB75_LATCH_Pin, 0);
|
|
gpio_set_level(HUB75_ADDR_A_Pin, 0);
|
|
gpio_set_level(HUB75_ADDR_B_Pin, 0);
|
|
gpio_set_level(HUB75_ADDR_C_Pin, 0);
|
|
gpio_set_level(HUB75_CLK_Pin, 0);
|
|
gpio_set_level(HUB75_U_R1_Pin, 0);
|
|
gpio_set_level(HUB75_U_G1_Pin, 0);
|
|
gpio_set_level(HUB75_U_B1_Pin, 0);
|
|
gpio_set_level(HUB75_U_R2_Pin, 0);
|
|
gpio_set_level(HUB75_U_G2_Pin, 0);
|
|
gpio_set_level(HUB75_U_B2_Pin, 0);
|
|
gpio_set_level(HUB75_D_R1_Pin, 0);
|
|
gpio_set_level(HUB75_D_G1_Pin, 0);
|
|
gpio_set_level(HUB75_D_B1_Pin, 0);
|
|
gpio_set_level(HUB75_D_R2_Pin, 0);
|
|
gpio_set_level(HUB75_D_G2_Pin, 0);
|
|
gpio_set_level(HUB75_D_B2_Pin, 0);
|
|
}
|
|
|
|
uint16_t NVT[] =
|
|
{
|
|
192, 193, 194, 195, 0, 1, 2, 3, 196, 197, 198, 199, 4, 5, 6, 7, 200, 201, 202, 203, 8, 9, 10, 11,
|
|
204, 205, 206, 207, 12, 13, 14, 15, 208, 209, 210, 211, 16, 17, 18, 19, 212, 213, 214, 215, 20, 21, 22, 23,
|
|
216, 217, 218, 219, 24, 25, 26, 27, 220, 221, 222, 223, 28, 29, 30, 31, 224, 225, 226, 227, 32, 33, 34, 35,
|
|
228, 229, 230, 231, 36, 37, 38, 39, 232, 233, 234, 235, 40, 41, 42, 43, 236, 237, 238, 239, 44, 45, 46, 47,
|
|
240, 241, 242, 243, 48, 49, 50, 51, 244, 245, 246, 247, 52, 53, 54, 55, 248, 249, 250, 251, 56, 57, 58, 59,
|
|
252, 253, 254, 255, 60, 61, 62, 63, 256, 257, 258, 259, 64, 65, 66, 67, 260, 261, 262, 263, 68, 69, 70, 71,
|
|
264, 265, 266, 267, 72, 73, 74, 75, 268, 269, 270, 271, 76, 77, 78, 79, 272, 273, 274, 275, 80, 81, 82, 83,
|
|
276, 277, 278, 279, 84, 85, 86, 87, 280, 281, 282, 283, 88, 89, 90, 91, 284, 285, 286, 287, 92, 93, 94, 95,
|
|
288, 289, 290, 291, 96, 97, 98, 99, 292, 293, 294, 295, 100, 101, 102, 103, 296, 297, 298, 299, 104, 105, 106, 107,
|
|
300, 301, 302, 303, 108, 109, 110, 111, 304, 305, 306, 307, 112, 113, 114, 115, 308, 309, 310, 311, 116, 117, 118, 119,
|
|
312, 313, 314, 315, 120, 121, 122, 123, 316, 317, 318, 319, 124, 125, 126, 127, 320, 321, 322, 323, 128, 129, 130, 131,
|
|
324, 325, 326, 327, 132, 133, 134, 135, 328, 329, 330, 331, 136, 137, 138, 139, 332, 333, 334, 335, 140, 141, 142, 143,
|
|
336, 337, 338, 339, 144, 145, 146, 147, 340, 341, 342, 343, 148, 149, 150, 151, 344, 345, 346, 347, 152, 153, 154, 155,
|
|
348, 349, 350, 351, 156, 157, 158, 159, 352, 353, 354, 355, 160, 161, 162, 163, 356, 357, 358, 359, 164, 165, 166, 167,
|
|
360, 361, 362, 363, 168, 169, 170, 171, 364, 365, 366, 367, 172, 173, 174, 175, 368, 369, 370, 371, 176, 177, 178, 179,
|
|
372, 373, 374, 375, 180, 181, 182, 183, 376, 377, 378, 379, 184, 185, 186, 187, 380, 381, 382, 383, 188, 189, 190, 191,
|
|
576, 577, 578, 579, 384, 385, 386, 387, 580, 581, 582, 583, 388, 389, 390, 391, 584, 585, 586, 587, 392, 393, 394, 395,
|
|
588, 589, 590, 591, 396, 397, 398, 399, 592, 593, 594, 595, 400, 401, 402, 403, 596, 597, 598, 599, 404, 405, 406, 407,
|
|
600, 601, 602, 603, 408, 409, 410, 411, 604, 605, 606, 607, 412, 413, 414, 415, 608, 609, 610, 611, 416, 417, 418, 419,
|
|
612, 613, 614, 615, 420, 421, 422, 423, 616, 617, 618, 619, 424, 425, 426, 427, 620, 621, 622, 623, 428, 429, 430, 431,
|
|
624, 625, 626, 627, 432, 433, 434, 435, 628, 629, 630, 631, 436, 437, 438, 439, 632, 633, 634, 635, 440, 441, 442, 443,
|
|
636, 637, 638, 639, 444, 445, 446, 447, 640, 641, 642, 643, 448, 449, 450, 451, 644, 645, 646, 647, 452, 453, 454, 455,
|
|
648, 649, 650, 651, 456, 457, 458, 459, 652, 653, 654, 655, 460, 461, 462, 463, 656, 657, 658, 659, 464, 465, 466, 467,
|
|
660, 661, 662, 663, 468, 469, 470, 471, 664, 665, 666, 667, 472, 473, 474, 475, 668, 669, 670, 671, 476, 477, 478, 479,
|
|
672, 673, 674, 675, 480, 481, 482, 483, 676, 677, 678, 679, 484, 485, 486, 487, 680, 681, 682, 683, 488, 489, 490, 491,
|
|
684, 685, 686, 687, 492, 493, 494, 495, 688, 689, 690, 691, 496, 497, 498, 499, 692, 693, 694, 695, 500, 501, 502, 503,
|
|
696, 697, 698, 699, 504, 505, 506, 507, 700, 701, 702, 703, 508, 509, 510, 511, 704, 705, 706, 707, 512, 513, 514, 515,
|
|
708, 709, 710, 711, 516, 517, 518, 519, 712, 713, 714, 715, 520, 521, 522, 523, 716, 717, 718, 719, 524, 525, 526, 527,
|
|
720, 721, 722, 723, 528, 529, 530, 531, 724, 725, 726, 727, 532, 533, 534, 535, 728, 729, 730, 731, 536, 537, 538, 539,
|
|
732, 733, 734, 735, 540, 541, 542, 543, 736, 737, 738, 739, 544, 545, 546, 547, 740, 741, 742, 743, 548, 549, 550, 551,
|
|
744, 745, 746, 747, 552, 553, 554, 555, 748, 749, 750, 751, 556, 557, 558, 559, 752, 753, 754, 755, 560, 561, 562, 563,
|
|
756, 757, 758, 759, 564, 565, 566, 567, 760, 761, 762, 763, 568, 569, 570, 571, 764, 765, 766, 767, 572, 573, 574, 575,
|
|
};
|
|
|
|
uint32_t vm[24] = {
|
|
0x40000000,
|
|
0x20000000,
|
|
0x10000000,
|
|
0x04000000,
|
|
0x02000000,
|
|
0x01000000,
|
|
0x00400000,
|
|
0x00200000,
|
|
0x00100000,
|
|
0x00040000,
|
|
0x00020000,
|
|
0x00010000,
|
|
0x00004000,
|
|
0x00002000,
|
|
0x00001000,
|
|
0x00000400,
|
|
0x00000200,
|
|
0x00000100,
|
|
0x00000040,
|
|
0x00000020,
|
|
0x00000010,
|
|
0x00000004,
|
|
0x00000002,
|
|
0x00000001,
|
|
};
|
|
|
|
#define AT_MIN 6
|
|
#define AT_MAX 42
|
|
|
|
void HUB75_displayBuffer_Color64(uint32_t *GUU, uint32_t *GUD, uint32_t *GDU, uint32_t *GDD)
|
|
{
|
|
uint32_t AA, BB, CC, DD;
|
|
|
|
uint8_t nnv = 7;
|
|
for(uint8_t nv = 0; nv < 8; nv++)
|
|
{
|
|
gpio_set_level(HUB75_OE_Pin, 0);
|
|
|
|
switch(nnv)
|
|
{
|
|
case 0:
|
|
gpio_set_level(HUB75_ADDR_A_Pin, 0);
|
|
gpio_set_level(HUB75_ADDR_B_Pin, 0);
|
|
gpio_set_level(HUB75_ADDR_C_Pin, 0);
|
|
break;
|
|
case 1:
|
|
gpio_set_level(HUB75_ADDR_A_Pin, 1);
|
|
gpio_set_level(HUB75_ADDR_B_Pin, 0);
|
|
gpio_set_level(HUB75_ADDR_C_Pin, 0);
|
|
break;
|
|
case 2:
|
|
gpio_set_level(HUB75_ADDR_A_Pin, 0);
|
|
gpio_set_level(HUB75_ADDR_B_Pin, 1);
|
|
gpio_set_level(HUB75_ADDR_C_Pin, 0);
|
|
break;
|
|
case 3:
|
|
gpio_set_level(HUB75_ADDR_A_Pin, 1);
|
|
gpio_set_level(HUB75_ADDR_B_Pin, 1);
|
|
gpio_set_level(HUB75_ADDR_C_Pin, 0);
|
|
break;
|
|
case 4:
|
|
gpio_set_level(HUB75_ADDR_A_Pin, 0);
|
|
gpio_set_level(HUB75_ADDR_B_Pin, 0);
|
|
gpio_set_level(HUB75_ADDR_C_Pin, 1);
|
|
break;
|
|
case 5:
|
|
gpio_set_level(HUB75_ADDR_A_Pin, 1);
|
|
gpio_set_level(HUB75_ADDR_B_Pin, 0);
|
|
gpio_set_level(HUB75_ADDR_C_Pin, 1);
|
|
break;
|
|
case 6:
|
|
gpio_set_level(HUB75_ADDR_A_Pin, 0);
|
|
gpio_set_level(HUB75_ADDR_B_Pin, 1);
|
|
gpio_set_level(HUB75_ADDR_C_Pin, 1);
|
|
break;
|
|
case 7:
|
|
gpio_set_level(HUB75_ADDR_A_Pin, 1);
|
|
gpio_set_level(HUB75_ADDR_B_Pin, 1);
|
|
gpio_set_level(HUB75_ADDR_C_Pin, 1);
|
|
break;
|
|
}
|
|
|
|
if(nnv == 7)
|
|
nnv = 0;
|
|
else
|
|
nnv++;
|
|
|
|
for(uint8_t p = 0; p < 48; p++)
|
|
{
|
|
if(p == AT_MIN) gpio_set_level(HUB75_OE_Pin, 0);
|
|
if(p == AT_MAX) gpio_set_level(HUB75_OE_Pin, 1);
|
|
|
|
AA = GUD[NVT[p + 0 + nnv * 48]];
|
|
BB = GUD[NVT[p + 384 + nnv * 48]];
|
|
CC = GDD[NVT[p + 0 + nnv * 48]];
|
|
DD = GDD[NVT[p + 384 + nnv * 48]];
|
|
|
|
for(int8_t k = 0; k < 8; k++)
|
|
{
|
|
uint32_t S1 = 0, R1 = 0;
|
|
uint8_t S2 = 0, R2 = 0;
|
|
|
|
//#define HUB75_U_R1_Pin 21
|
|
//#define HUB75_U_G1_Pin 22
|
|
//#define HUB75_U_B1_Pin 19
|
|
|
|
if(AA & vm[k*3 + 0])
|
|
// 33322222222221111111111000000000
|
|
// 21098765432109876543210987654321
|
|
S1 |= 0b00000000001000000000000000000000;
|
|
else
|
|
R1 |= 0b00000000001000000000000000000000;
|
|
|
|
if(AA & vm[k*3 + 1])
|
|
// 33322222222221111111111000000000
|
|
// 21098765432109876543210987654321
|
|
S1 |= 0b00000000010000000000000000000000;
|
|
else
|
|
R1 |= 0b00000000010000000000000000000000;
|
|
|
|
if(AA & vm[k*3 + 2])
|
|
// 33322222222221111111111000000000
|
|
// 21098765432109876543210987654321
|
|
S1 |= 0b00000000000010000000000000000000;
|
|
else
|
|
R1 |= 0b00000000000010000000000000000000;
|
|
|
|
//#define HUB75_U_R2_Pin 18
|
|
//#define HUB75_U_G2_Pin 23
|
|
//#define HUB75_U_B2_Pin 5
|
|
|
|
if(BB & vm[k*3 + 0])
|
|
// 33322222222221111111111000000000
|
|
// 21098765432109876543210987654321
|
|
S1 |= 0b00000000000001000000000000000000;
|
|
else
|
|
R1 |= 0b00000000000001000000000000000000;
|
|
|
|
if(BB & vm[k*3 + 1])
|
|
// 33322222222221111111111000000000
|
|
// 21098765432109876543210987654321
|
|
S1 |= 0b00000000100000000000000000000000;
|
|
else
|
|
R1 |= 0b00000000100000000000000000000000;
|
|
|
|
if(BB & vm[k*3 + 2])
|
|
// 33322222222221111111111000000000
|
|
// 21098765432109876543210987654321
|
|
S1 |= 0b00000000000000000000000000100000;
|
|
else
|
|
R1 |= 0b00000000000000000000000000100000;
|
|
|
|
|
|
//#define HUB75_D_R1_Pin 26
|
|
//#define HUB75_D_G1_Pin 27
|
|
//#define HUB75_D_B1_Pin 25
|
|
|
|
if(CC & vm[k*3 + 0])
|
|
// 33322222222221111111111000000000
|
|
// 21098765432109876543210987654321
|
|
S1 |= 0b00000100000000000000000000000000;
|
|
else
|
|
R1 |= 0b00000100000000000000000000000000;
|
|
|
|
if(CC & vm[k*3 + 1])
|
|
// 33322222222221111111111000000000
|
|
// 21098765432109876543210987654321
|
|
S1 |= 0b00001000000000000000000000000000;
|
|
else
|
|
R1 |= 0b00001000000000000000000000000000;
|
|
|
|
if(CC & vm[k*3 + 2])
|
|
// 33322222222221111111111000000000
|
|
// 21098765432109876543210987654321
|
|
S1 |= 0b00000010000000000000000000000000;
|
|
else
|
|
R1 |= 0b00000010000000000000000000000000;
|
|
|
|
//#define HUB75_D_R2_Pin 33
|
|
//#define HUB75_D_G2_Pin 14
|
|
//#define HUB75_D_B2_Pin 32
|
|
|
|
if(DD & vm[k*3 + 0])
|
|
// 33333333
|
|
// 98723532
|
|
S2 |= 0b00000010;
|
|
else
|
|
R2 |= 0b00000010;
|
|
|
|
if(DD & vm[k*3 + 1])
|
|
// 33322222222221111111111000000000
|
|
// 21098765432109876543210987654321
|
|
S1 |= 0b00000000000000000100000000000000;
|
|
else
|
|
R1 |= 0b00000000000000000100000000000000;
|
|
|
|
if(DD & vm[k*3 + 2])
|
|
// 33333333
|
|
// 98723532
|
|
S2 |= 0b00000001;
|
|
else
|
|
R2 |= 0b00000001;
|
|
|
|
REG_WRITE(GPIO_OUT_W1TS_REG, S1);
|
|
REG_WRITE(GPIO_OUT_W1TC_REG, R1);
|
|
|
|
REG_WRITE(GPIO_OUT1_W1TS_REG, S2);
|
|
REG_WRITE(GPIO_OUT1_W1TC_REG, R2);
|
|
|
|
gpio_set_level(HUB75_CLK_Pin, 1);
|
|
gpio_set_level(HUB75_CLK_Pin, 0);
|
|
}
|
|
}
|
|
/*
|
|
for(uint8_t p = 0; p < 48; p++)
|
|
{
|
|
if(p == AT_MIN) gpio_set_level(HUB75_OE_Pin, 0);
|
|
if(p == AT_MAX) gpio_set_level(HUB75_OE_Pin, 1);
|
|
|
|
AA = GUU[NVT[p + 0 + nnv * 48]];
|
|
BB = GUU[NVT[p + 384 + nnv * 48]];
|
|
CC = GDU[NVT[p + 0 + nnv * 48]];
|
|
DD = GDU[NVT[p + 384 + nnv * 48]];
|
|
|
|
for(int8_t k = 0; k < 8; k++)
|
|
{
|
|
uint32_t S1 = 0, R1 = 0;
|
|
uint8_t S2 = 0, R2 = 0;
|
|
|
|
//#define HUB75_U_R1_Pin 21
|
|
//#define HUB75_U_G1_Pin 22
|
|
//#define HUB75_U_B1_Pin 19
|
|
|
|
if(AA & vm[k*3 + 0])
|
|
// 33322222222221111111111000000000
|
|
// 21098765432109876543210987654321
|
|
S1 |= 0b00000000001000000000000000000000;
|
|
else
|
|
R1 |= 0b00000000001000000000000000000000;
|
|
|
|
if(AA & vm[k*3 + 1])
|
|
// 33322222222221111111111000000000
|
|
// 21098765432109876543210987654321
|
|
S1 |= 0b00000000010000000000000000000000;
|
|
else
|
|
R1 |= 0b00000000010000000000000000000000;
|
|
|
|
if(AA & vm[k*3 + 2])
|
|
// 33322222222221111111111000000000
|
|
// 21098765432109876543210987654321
|
|
S1 |= 0b00000000000010000000000000000000;
|
|
else
|
|
R1 |= 0b00000000000010000000000000000000;
|
|
|
|
//#define HUB75_U_R2_Pin 18
|
|
//#define HUB75_U_G2_Pin 23
|
|
//#define HUB75_U_B2_Pin 5
|
|
|
|
if(BB & vm[k*3 + 0])
|
|
// 33322222222221111111111000000000
|
|
// 21098765432109876543210987654321
|
|
S1 |= 0b00000000000001000000000000000000;
|
|
else
|
|
R1 |= 0b00000000000001000000000000000000;
|
|
|
|
if(BB & vm[k*3 + 1])
|
|
// 33322222222221111111111000000000
|
|
// 21098765432109876543210987654321
|
|
S1 |= 0b00000000100000000000000000000000;
|
|
else
|
|
R1 |= 0b00000000100000000000000000000000;
|
|
|
|
if(BB & vm[k*3 + 2])
|
|
// 33322222222221111111111000000000
|
|
// 21098765432109876543210987654321
|
|
S1 |= 0b00000000000000000000000000100000;
|
|
else
|
|
R1 |= 0b00000000000000000000000000100000;
|
|
|
|
|
|
//#define HUB75_D_R1_Pin 26
|
|
//#define HUB75_D_G1_Pin 27
|
|
//#define HUB75_D_B1_Pin 25
|
|
|
|
if(CC & vm[k*3 + 0])
|
|
// 33322222222221111111111000000000
|
|
// 21098765432109876543210987654321
|
|
S1 |= 0b00000100000000000000000000000000;
|
|
else
|
|
R1 |= 0b00000100000000000000000000000000;
|
|
|
|
if(CC & vm[k*3 + 1])
|
|
// 33322222222221111111111000000000
|
|
// 21098765432109876543210987654321
|
|
S1 |= 0b00001000000000000000000000000000;
|
|
else
|
|
R1 |= 0b00001000000000000000000000000000;
|
|
|
|
if(CC & vm[k*3 + 2])
|
|
// 33322222222221111111111000000000
|
|
// 21098765432109876543210987654321
|
|
S1 |= 0b00000010000000000000000000000000;
|
|
else
|
|
R1 |= 0b00000010000000000000000000000000;
|
|
|
|
//#define HUB75_D_R2_Pin 33
|
|
//#define HUB75_D_G2_Pin 14
|
|
//#define HUB75_D_B2_Pin 32
|
|
|
|
if(DD & vm[k*3 + 0])
|
|
// 33333333
|
|
// 98723532
|
|
S2 |= 0b00000010;
|
|
else
|
|
R2 |= 0b00000010;
|
|
|
|
if(DD & vm[k*3 + 1])
|
|
// 33322222222221111111111000000000
|
|
// 21098765432109876543210987654321
|
|
S1 |= 0b00000000000000000100000000000000;
|
|
else
|
|
R1 |= 0b00000000000000000100000000000000;
|
|
|
|
gpio_set_level(HUB75_CLK_Pin, 0);
|
|
|
|
if(DD & vm[k*3 + 2])
|
|
// 33333333
|
|
// 98723532
|
|
S2 |= 0b00000001;
|
|
else
|
|
R2 |= 0b00000001;
|
|
|
|
REG_WRITE(GPIO_OUT_W1TS_REG, S1);
|
|
REG_WRITE(GPIO_OUT_W1TC_REG, R1);
|
|
|
|
REG_WRITE(GPIO_OUT1_W1TS_REG, S2);
|
|
REG_WRITE(GPIO_OUT1_W1TC_REG, R2);
|
|
|
|
gpio_set_level(HUB75_CLK_Pin, 1);
|
|
}
|
|
}
|
|
*/
|
|
gpio_set_level(HUB75_LATCH_Pin, 1);
|
|
gpio_set_level(HUB75_LATCH_Pin, 0);
|
|
}
|
|
}
|
|
|