OCCT3D (Open CASCADE Technology) Open Source 8.0 bylo vydáno. OCCT3D (Wikipedie, GitHub) je objektově orientovaná knihovna pro 3D CAD, CAM nebo CAE. Používá se například v softwarech FreeCAD a KiCad.
Ve FreeBSD byla nalezena a již opravena 21letá zranitelnost CVE-2026-42511 v dhclient. Jedná se o vzdálené spuštění kódu (RCE). Útočník mající pod správou DHCP server může získat plnou kontrolu nad systémem FreeBSD pouze jeho připojením k místní síti.
Na čem aktuálně pracují vývojáři GNOME a KDE Plasma? Pravidelný přehled novinek v Týden v GNOME a Týden v KDE Plasma.
UBports, nadace a komunita kolem Ubuntu pro telefony a tablety Ubuntu Touch, vydala Ubuntu Touch 24.04-1.3. Současně oznámila, že nadcházející větší vydání 24.04-2.0 bude mít modernější webový prohlížeč.
Ploopy po DIY trackballech či sluchátkách představuje nový externí DIY trackpoint se čtyřmi tlačítky Bean. Obsahuje snímač Texas Instruments TMAG5273, spínače Omron D2LS-21 a řadič RP2040, používá firmware QMK. Schémata jsou na GitHubu; sadu lze předobjednat za 69 kanadských dolarů (bez dopravy a DPH).
Mozilla před dvěma týdny na svém blogu oznámila, že díky Claude Mythos Preview bylo ve Firefoxu nalezeno a opraveno 271 bezpečnostních chyb. Včera vyšel na Mozilla Hacks článek s podrobnějšími informacemi. Z 271 bezpečnostních chyb mělo 180 chyb vysokou závažnost, 80 chyb střední závažnost a 11 chyb nízkou závažnost. Celkově bylo v dubnu ve Firefoxu opraveno 423 bezpečnostních chyb. Čísla CVE nemusí být přiřazována jednotlivým chybám. CVE-2026-6784 například představuje 154 bezpečnostních chyb.
Před týdnem zranitelnost Copy Fail. Dnes zranitelnost Dirty Frag. Běžný uživatel může na Linuxu získat práva roota (lokální eskalaci práv). Na většině linuxových distribucí vydaných od roku 2017. Aktuálně bez oficiální záplaty a CVE čísla [oss-security mailing list].
Ačkoli je papež Lev XIV. hlavou katolické církve a stojí v čele více než miliardy věřících po celém světě, také on někdy řeší všední potíže. A kdo v životě neměl problémy se zákaznickou linkou? Krátce poté, co nastoupil do úřadu, musel papež se svou bankou řešit změnu údajů. Operátorka ale nechtěla uvěřit, s kým mluví, a Svatému otci zavěsila.
Incus, komunitní fork nástroje pro správu kontejnerů LXD, byl vydán ve verzi 7.0 LTS (YouTube). Stejně tak související LXC a LXCFS.
Google Chrome 148 byl prohlášen za stabilní. Nejnovější stabilní verze 148.0.7778.96 přináší řadu novinek z hlediska uživatelů i vývojářů. Vypíchnout lze Prompt API (demo) pro přímý přístup k AI v zařízení. Podrobný přehled v poznámkách k vydání. Opraveno bylo 127 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.
echo ahoj > /dev/ttyS2 tak potom jinde v konsoli dam cat /dev/ttyS2. Ale ten cat vypisuje porad dokola prazdne radky a obcas se tam objevi to ahoj i kdyz jsem ho poslal jen jednou. Myslim si ze mam neco blbe v kernelu ale netusim co. Nevite nekdo co s tim? Dik Vojta
cat /dev/ttyS2 se zapnou vsechny ale ja bych je chtel zapnout zvlast. Diky Vojta
#include <sys/ioctl.h>
#include <fcntl.h>
#include <unistd.h>
int main(int argc, char **argv) {
int fd;
int iFlags = TIOCM_DTR;
fd = open("/dev/ttyS0", O_RDWR | O_SYNC);
ioctl(fd, TIOCMBIC, &iFlags); /* Vynuluje DTR */
ioctl(fd, TIOCMBIS, &iFlags); /* Nastavi DTR */
close(fd);
return 0;
}
Proste aby to umelo nastavovat vystupy seriaku. Diky moc Vojta
staci ti jen toto
http://www.linuxsoft.cz/article.php?id_article=387
usage: setdtrrts.py [options]
options:
--version show program's version number and exit
-h, --help show this help message and exit
-d DEVICE, --device=DEVICE
serial port device (default /dev/ttyS0)
-R, --RTS set RTS
-D, --DTR set DTR
-t DELAY, --time=DELAY
time in seconds to quit (default 5)
Takže například
setdtrrts.py -d /dev/ttyS1 --RTS --DTR -t 3Zapne obě stavové linky u portu /dev/ttyS1 na dobu tří sekund. A tady je ten program:
#!/usr/bin/env python
import tty, os, fcntl, time, struct
from optparse import OptionParser
usage = "usage: %prog [options]"
parser = OptionParser(usage, version="%prog version 0.1")
parser.add_option("-d", "--device", action = "store",
default = "/dev/ttyS0", dest="device", help="serial port device (default /dev/ttyS0)")
parser.add_option("-R", "--RTS", action = "store_true",
default = False, dest="rts", help="set RTS")
parser.add_option("-D", "--DTR", action = "store_true",
default = False, dest="dtr", help="set DTR")
parser.add_option("-t", "--time", action = "store", type = "float",
default = 5, dest="delay", help="time in seconds to quit (default 5)")
(options, args) = parser.parse_args()
TIOCM_DTR_str = struct.pack('I', tty.TIOCM_DTR)
TIOCM_RTS_str = struct.pack('I', tty.TIOCM_RTS)
fd = os.open(options.device, os.O_RDWR | os.O_SYNC)
if options.dtr:
print "setting DTR"
fcntl.ioctl(fd, tty.TIOCMBIS, TIOCM_DTR_str)
else:
print "clearing DTR"
fcntl.ioctl(fd, tty.TIOCMBIC, TIOCM_DTR_str)
if options.rts:
print "setting RTS"
fcntl.ioctl(fd, tty.TIOCMBIS, TIOCM_RTS_str)
else:
print "clearing RTS"
fcntl.ioctl(fd, tty.TIOCMBIC, TIOCM_RTS_str)
time.sleep(options.delay)
... a měl bys začít programovat v nějakém kloudném programovacím jazyce, který není odkázaný na volání externích programů.
. Ten docela ovladam(alespon si to myslim). Ale v linuxu co napriklad? C nebo Python? C mi prijde dost tezky. Dik za pomoc Vojta
). Dik moc Vojta
#!/usr/bin/env python
import tty, os, fcntl, time, struct, subprocess
programname = 'date'
delay = 3
TIOCM_DTR_str = struct.pack('I', tty.TIOCM_DTR)
TIOCM_RTS_str = struct.pack('I', tty.TIOCM_RTS)
fd = os.open('/dev/ttyS0', os.O_RDWR | os.O_SYNC)
while True:
print "setting DTR"
fcntl.ioctl(fd, tty.TIOCMBIS, TIOCM_DTR_str)
print "setting RTS"
fcntl.ioctl(fd, tty.TIOCMBIS, TIOCM_RTS_str)
subprocess.Popen([programname])
time.sleep(delay)
print "clearing DTR"
fcntl.ioctl(fd, tty.TIOCMBIC, TIOCM_DTR_str)
print "clearing RTS"
fcntl.ioctl(fd, tty.TIOCMBIC, TIOCM_RTS_str)
subprocess.Popen([programname])
time.sleep(delay)
#!/usr/bin/env python
import tty, os, fcntl, time, struct, subprocess
def runcommand(command):
process = subprocess.Popen([command])
process.wait()
def wait_period(period):
sec = time.time()
time_to_wait = period - sec % period
print "Waiting for %g seconds" %time_to_wait
time.sleep(time_to_wait)
class Relay:
def __init__(self, devpath, initstate = True):
self.fd = os.open(devpath, os.O_RDWR | os.O_SYNC)
self.TIOCM_DTR_str = struct.pack('I', tty.TIOCM_DTR)
self.TIOCM_RTS_str = struct.pack('I', tty.TIOCM_RTS)
self.state = initstate
self.switch(self.state)
def switch(self, state):
if state:
print "setting DTR"
fcntl.ioctl(self.fd, tty.TIOCMBIS, self.TIOCM_DTR_str)
print "setting RTS"
fcntl.ioctl(self.fd, tty.TIOCMBIS, self.TIOCM_RTS_str)
else:
print "clearing DTR"
fcntl.ioctl(self.fd, tty.TIOCMBIC, self.TIOCM_DTR_str)
print "clearing RTS"
fcntl.ioctl(self.fd, tty.TIOCMBIC, self.TIOCM_RTS_str)
self.state = state
def negate(self):
self.state = not self.state #negate
self.switch(self.state)
rele = Relay('/dev/ttyS0', initstate = False)
while True:
wait_period(3)
rele.negate()
runcommand('date')
Je to trochu lepší verze než ta předchozí. Jednak je to objektové a pak to časování je udělané tak, že se systematicky nepředbíhá ani nezpožďuje. Navíc se čas počítá absolutně, takže lze předem říct, že se kamery budou přepínat vždy v celou minutu a v půl.
Tiskni
Sdílej: