Byly zveřejněny prezentace a videozáznamy přednášek a fotografie z česko-slovenského setkání poskytovatelů přístupu k internetu, provozovatelů telekomunikačních sítí, registrátorů domén a provozovatelů počítačových sítí a technických nadšenců CSNOG 2023 (Czech and Slovak Network Operators Group) konaného 16. a 17. května ve Zlínu.
Soutěž amatérských robotů Robotický den 2023 proběhne v neděli 4. června v Kongresovém centru Praha.
V Tchaj-peji probíhá počítačový veletrh COMPUTEX 2023. Firmy představují své novinky. Nvidia například superpočítač DGX GH200 AI.
Vyšla nová verze XMPP (Jabber) klienta Gajim. Nejvýznamnější novinkou je integrace OMEMO pluginu přímo do jádra aplikace, takže již není třeba plugin samostatně instalovat. Přehled dalších novinek je dostupný na oficiálních stránkách. Gajim je vytvořen v jazyce Python s využitím knihovny GTK a vedle Linuxu jej lze vyzkoušet i na platformách MacOS a Windows.
Komunita KDE představila stránku KDE for Developers pro vývojáře používající KDE aplikace. Postupně byly představeny stránky pro umělce KDE for Creators, děti KDE for Kids a vědce KDE for Scientists.
Společnost ARM představila platformu Total Compute Solutions 2023 (TCS23) s 5. generací GPU Immortalis-G720, Mali-G720 a Mali-G620 a Armv9.2 CPU Cortex-X4, Cortex-A720 a Cortex-A520 s DSU-120.
Na konferenci Microsoft Build 2023 byl představen Azure Linux container host for Azure Kubernetes Service (AKS). Podrobnosti ve videu s otázkami a odpovědmi. Shrnutí v článku na DevClass.
Na itch.io probíhá Linux Game Jam 2023. Zapojit se a přihlásit hru běžící na Linuxu lze do 6. června do 01:59. Zahrát si lze hry z loňského ročníku.
Na Steamu lze získat zdarma počítačové hry Warhammer 40,000: Gladius - Relics of War a Hue. Na Epic Games Storu počítačovou hru Fallout: New Vegas - Ultimate Edition.
WordPress (Wikipedie), open source systém pro správu webového obsahu (CMS), zítra slaví 20 let. První verze byla vydána 27. května 2003.
uint8_t search_sensors(void) { uint8_t i; uint8_t id[OW_ROMCODE_SIZE]; uint8_t diff; bool akva1, akva2, lednice, mistnost; while(1) { //writestr("+4 NACITAM SENZORY"); //lfcr(); m_delay_ms(250); nSensors = 0; akva1_id = -1; akva2_id = -1; lednice_id = -1; mistnost_id = -1; for(uint8_t iN = 0; iN<MAXSENSORS; iN++) { // nemá vliv na chování for(uint8_t iN2 = 0; iN2<OW_ROMCODE_SIZE; iN2++) { gSensorIDs[iN][iN2] = 0; } } for(diff = OW_SEARCH_FIRST; diff != OW_LAST_DEVICE && nSensors < MAXSENSORS; ) { DS18X20_find_sensor( &diff, &id[0] ); if( diff == OW_PRESENCE_ERR ) break; if( diff == OW_DATA_ERR ) break; akva1 = true; akva2 = true; lednice = true; mistnost = true; for (i=0;i<OW_ROMCODE_SIZE;i++) { gSensorIDs[nSensors][i]=id[i]; if(akva1) { eeprom_busy_wait(); if( gSensorIDs[nSensors][i] != eeprom_read_byte((uint8_t*)(EEPROM_AKVA1_SENSOR+i)) ) akva1 = false; } if(akva2) { eeprom_busy_wait(); if( gSensorIDs[nSensors][i] != eeprom_read_byte((uint8_t*)(EEPROM_AKVA2_SENSOR+i)) ) akva2 = false; } if(lednice) { eeprom_busy_wait(); if( gSensorIDs[nSensors][i] != eeprom_read_byte((uint8_t*)(EEPROM_LEDNICE_SENSOR+i)) ) lednice = false; } if(mistnost) { eeprom_busy_wait(); if( gSensorIDs[nSensors][i] != eeprom_read_byte((uint8_t*)(EEPROM_MISTNOST_SENSOR+i)) ) mistnost = false; } } if(akva1 && !akva2 && !lednice && !mistnost) { akva1_id = nSensors; leds_add(port_led_akva1); } if(!akva1 && akva2 && !lednice && !mistnost) { akva2_id = nSensors; leds_add(port_led_akva2); } if(!akva1 && !akva2 && lednice && !mistnost) { lednice_id = nSensors; leds_add(port_led_lednice); } if(!akva1 && !akva2 && !lednice && mistnost) { mistnost_id = nSensors; } nSensors++; } if( nSensors ) return nSensors; leds_search(); leds_blink(LED_BLINK_FAST_INTERVAL); m_delay_s(1); } } void vypsat_senzory() { nSensors = search_sensors(); for ( int i=0; i<nSensors; i++ ) { writestr("#"); writestr_integer((int) i); if(i == akva1_id) writestr(":AKVA1:"); if(i == akva2_id) writestr(":AKVA2:"); if(i == lednice_id) writestr(":LEDNICE:"); if(i == mistnost_id) writestr(":MISTNOST:"); writestr(" "); writetemp(getTemp(i)); lfcr(); } } void uloz_senzor( uint8_t *id, uint8_t kam ) { for (int i=0; i<OW_ROMCODE_SIZE; i++) { eeprom_busy_wait(); eeprom_write_byte((uint8_t*)(kam+i),id[i]); } } void nastav_senzor(char cilselekt) { uint8_t sensT = (uint8_t)(rx_buffer[0]-48); writestr_integer((int) sensT); lfcr(); if ( sensT < nSensors ) { if(cilselekt == '1') uloz_senzor(&gSensorIDs[sensT][0], EEPROM_AKVA1_SENSOR); else if(cilselekt == '2') uloz_senzor(&gSensorIDs[sensT][0], EEPROM_AKVA2_SENSOR); else if(cilselekt == 'l') uloz_senzor(&gSensorIDs[sensT][0], EEPROM_LEDNICE_SENSOR); else if(cilselekt == 'm') uloz_senzor(&gSensorIDs[sensT][0], EEPROM_MISTNOST_SENSOR); else errorWrite(1); writestr("+1 OK"); lfcr(); nSensors = search_sensors(); vypsat_senzory(); } else errorWrite(1); } void eeprog_vstup_podprogram() { if(citac_ee > 0) { for (uint8_t i=RX_BUFFER_SIZE; i>0; i--) rx_buffer[i]=0; rs232enter=0; rs232ready=true; while(1) { if(rs232enter) { rs232ready=false; if(cmdtest('L','S',0)) vypsat_senzory(); else if(cmdtest('S','A',1)) nastav_senzor('1'); else if(cmdtest('S','B',1)) nastav_senzor('2'); else if(cmdtest('S','L',1)) nastav_senzor('l'); else if(cmdtest('S','M',1)) nastav_senzor('m'); else if(cmdtest('E','Q',0)) { writestr("+1 OK"); lfcr(); break; } else errorWrite(3); for (uint8_t i=RX_BUFFER_SIZE; i>0; i--) rx_buffer[i]=0; rs232enter=0; rs232ready=true; } } } else errorWrite(4); }Samotné search_sensors(void) funguje dobře, opravdu porovnává všechny bajty identifikace senzoru vs. uložená identifikace v eeprom. Problém nastává, pokud chci uložit nový senzor. Všechny se ukládají dobře, kromě 1.(senzor #0). Pokud se jednoduše snažím uložit senzor 0 jako cokoliv, tak je první bajt vždy 0x00. Takhle vypadá část eepromky: 00FBFA97020000A728D6F797020000B72820BA9702000072. Správně ale má být 28FBFA97020000A728D6F797020000B72820BA9702000072. Co mám špatně?
Řešení dotazu:
Tiskni
Sdílej: