RENAME TABLE oldtablename TO newtablename
ระบบที่ทดสอบ
MySQL: 5.1.49
RENAME TABLE oldtablename TO newtablename
sudo apt-get install gpointing-device-settings
gpointing-device-settings
[2010-10-10 00:07:56 - Test] ERROR: Unable to open class file /path/to/androidproject/gen/com/example/androidproject/R.java: No such file or directory\R.java: No such file or directory
[2010-10-10 00:07:56 - Test] ERROR: Error generating final archive: Debug certificate expired on dd/MM/yyyy
%JAVA_HOME%\bin\keytool -genkey -keypass android -keystore debug.keystore -alias androiddebugkey -storepass android -validity 100000 -dname "CN=Android Debug,O=Android,C=US"
#bind-address = 127.0.0.1
sudo service mysql restart
mig python -python-classname=PrintfMsg printf.h printf_msg -o PrintfMsg.py
import tinyos.message.Message
import binascii
...
...
def getString_buffer(self):
carr = "";
#for i in range(0, 4000):
for i in range(0, 28):
if self.getElement_buffer(i) == chr(0):
break
c = "%x" % (self.getElement_buffer(i) & 0xFF)
if (len(c) < 2):
carr += "0" + c
else:
carr += c
return binascii.unhexlify(carr)
import PrintfMsg
self.mif.addListener(self, PrintfMsg.PrintfMsg)
และเวลาเรียกค่าออกมาให้ใช้
s = m.getString_buffer()
ก็จะได้ String ที่เกิดจากไลบรารี printf แล้วครับ แต่ว่าจะมีปัญหาเล็กน้อยคือถึงแม้เรา printf ออกมาเป็น String ยาวๆ แต่ว่าการส่งข้อมูลออกมาแต่ละครั้งจะเท่ากับความยาวที่กำหนดไว้เท่านั้น (ค่า default คือ 28) ดังนั้นมันจะตัดส่งออกมาทีละ 28 ตัวอักษร ถ้าต้องการให้มากกว่านั้นก็ลองไป compile ไลบรารี Printf กันใหม่ได้ครับ
ถ้าใครยังไม่เคยใช้ MoteLab เดี๋ยวว่างๆผมจะมาเขียนวิธีไว้ด้วยครับ
ระบบที่ทดสอบ
OS: Ubuntu 10.04
TinyOS: 2.1.1
Device: Harvard MoteLab
วันอาทิตย์ที่ 1 สิงหาคม พ.ศ. 2553
เพิ่ม System Call ใน Linux Kernel
อันนี้เป็นวิธีจากตำราเลยครับ แต่ว่าปรับให้ใช้กับ Kernel 2.6.34.1
(blog นี้ assume ว่าสามารถ compile kernel เป็นแล้ว)
สมมติว่าจะเพิ่ม system call ที่ชื่อ hellokernel ซึ่งทำหน้าที่ print คำว่า "hello kernel!" ออกมาเก็บใน log ไฟล์
1. สร้างไฟล์ hellokernel.c ไว้ใน /usr/src/linux-2.6.34.1/kernel
#include <linux/linkage.h>
#include <linux/kernel.h>
asmlinkage int sys_hellokernel() {
printk(KERN_EMERG "hello kernel!");
return 1;
}
2. เพิ่มเลขของ system call ใหม่ในไฟล์ /usr/src/linux-2.6.34.1/include/asm-generic/unistd.h
- ให้ค้นหาคำว่า "#undef __NR_syscalls" แล้วบรรทัดก่อนบรรทัดนี้ให้เติม
#define __NR_hellokernel 244
__SYSCALL(__NR_hellokernel, sys_hellokernel)
โดยตัวเลข 244 นั้นให้ดูว่า system call ตัวก่อนหน้านั้นเป็นเบอร์อะไร (ของผมเป็น __NR_recvmmsg 243) ก็ให้เอาเลขนั้นบวก 1
- และบรรทัดต่อจากนั้น #define __NR_syscalls นั้นให้บวก 1 เข้าไป (ของเดิมของผมเป็น 244 ก็เปลี่ยนเป็น 245)
3. แก้ไขไฟล์ /usr/src/linux-2.6.34.1/arch/x86/kernel/syscall_table_32.S (สำหรับกรณีเครื่อง x86 ถ้าเป็นเครื่องอื่นก็แก้ที่โฟลเดอร์ของ arch นั้นๆ)
- เพิ่ม .long sys_hellokernel ไว้ที่ท้ายสุดของไฟล์ต่อลงมา
4. แก้ไข Makefile ใน /usr/src/linux-2.6.34.1/kernel
- เพิ่ม hellokernel.o ให้กับ obj-y (ต่อท้ายสุดก็ได้)
เรียบร้อยแล้วให้ทำการคอมไพล์ Kernel ใหม่ แล้ว boot เข้า kernel ที่ใหม่นี้ แล้วทดสอบโดยการสร้างไฟล์ test.c ขึ้นมา
#include <linux/unistd.h>
#define __NR_hellokernel 244 // 244 แทนเลขของ system call ที่ประกาศไว้ข้างบน
main() {
syscall(__NR_hellokernel);
}
เสร็จแล้วก็ลอง compile แล้ว run ดู ถ้าสำเร็จจะมีข้อความ "hello kernel!" ปรากฏอยู่ใน log file ของ kernel ที่ /var/log/kernel/warnings
ระบบที่ทดสอบ
OS: Ubuntu 10.04
Kernel: Linux Kernel 2.6.34.1
อ้างอิงหนังสือ Operating System Concepts 8th Edition, A. Silberschatz, P. B. Galvin, and G. Gagne
Labels:
kernel,
linux,
os,
system call
วันเสาร์ที่ 31 กรกฎาคม พ.ศ. 2553
วิธี Compile Linux kernel 2.6 บน Ubuntu 10.04
ในบางคราวเราอาจจะต้องคอมไพล์ Linux Kernel เพื่อเพิ่มฟังก์ชันอะไรบางอย่าง หรือเพื่ออยากรู้อยากลองก็มีวิธีการดังต่อไปนี้ครับ (ผมทำบน Ubuntu 10.04)
1. ดาวน์โหลด source code ของ kernel มาก่อน โดยสามารถดาวน์โหลดได้ที่ http://www.kernel.org/ โดยที่ผมทำจะใช้เป็นรุ่น 2.6.34.1 ครับ
แตกไฟล์แล้วเอาโฟลเดอร์ linux-2.6.34.1 ไปไว้ใน /usr/src ซึ่งเป็นโฟลเดอร์ที่นิยมใช้เก็บ source ของ kernel
2. เตรียมเครื่องมือ ได้แก่ kernel-package, fakeroot, ncurses (อันไหนมีแล้วก็ไม่ต้องโหลดเพิ่ม แต่ถ้าอันไหนมันฟ้องว่ายังขาดก็โหลดเพิ่มนะครับ :P)
sudo apt-get install kernel-package fakeroot libncurses5-dev
3. ทำการ configure kernel
ไปที่โฟลเดอร์ source ของเรา /usr/src/linux-2.6.34.1 แล้วสั่ง configure โดยสั่งได้ 3 รูปแบบ
วิธีแรกเป็นแบบ text-based
make menuconfig
วิธีที่สองถ้ามี Qt
make xconfig
วิธีที่สามถ้ามี Gtk
make gconfig
ก็เลือกตามสะดวกครับ ถ้าคิดไม่ออกก็เลือกวิธีแรกก็ได้
โดยใน menu สำหรับ configure นั้นจะมีอะไรให้เราเลือกมากมายครับก็เลือกตามที่ต้องการ แต่ถ้าไม่แน่ใจว่าคืออะไรก็ปล่อยเป็นค่า default ก็ได้ครับ
4. Compile Kernel
ในกรณีถ้าเครื่องมีหลาย cpu และต้องการให้คอมไพล์เร็วขึ้นให้สั่ง
export CONCURRENCY_LEVEL=3
โดยตัวเลขให้ใช้ จำนวนcpuที่มี + 1 (ในกรณีนี้ผมมี 2 cpu (2 core) เลยเป็น 3)
แล้วสั่ง
make-kpkg clean
fakeroot make-kpkg --initrd --append-to-version=-some-string-here kernel-image kernel-headers
โดย -some-string-here ใส่เป็นอะไรก็ได้เพื่อบอก version ของเรา เช่นของผมจะใส่ว่า -ping2p (ต้องขึ้นต้นด้วยเครื่องหมาย - และห้ามมีเว้นวรรค)
แล้วก็รอมันคอมไพล์ไป ระหว่างนี้ก็ไปอาบน้ำ อ่านหนังสือ กินข้าว รอจนกว่ามันจะเสร็จนะครับ ถ้าเสร็จแล้วลองดูที่โฟลเดอร์ /usr/src จะมีไฟล์ 2 ไฟล์คือ linux-image-2.6.34.1-ping2p_2.6.34.1-ping2p-10.00.Custom_i386.deb และ linux-headers-2.6.34.1-ping2p_2.6.34.1-ping2p-10.00.Custom_i386.deb (ในกรณีที่ compile แล้ว error เพราะ permission denied ให้ลองเปลี่ยน permission ของโฟลเดอร์ /usr/src ให้สามารถ write ได้ แล้วลองคอมไพล์ใหม่อีกรอบ (แต่จะใช้เวลาไม่นานเหมือนครั้งแรก เพราะหลายๆอย่างคอมไพล์เสร็จแล้ว))
5. Install
คราวนี้ก็จะทำการ Install kernel ใหม่นี้ โดยทำเป็น Option ให้เลือกตอน boot เผื่อเกิดอะไรผิดพลาดจะได้เรียกของเก่ากลับมาได้
ไปที่โฟลเดอร์ /usr/src จะพบ kernel ใหม่ที่เราคอมไพล์ แล้วให้ทำการติดตั้งดังนี้
sudo dpkg -i linux-image-2.6.34.1-ping2p_2.6.34.1-ping2p-10.00.Custom_i386.deb
sudo dpkg -i linux-headers-2.6.34.1-ping2p_2.6.34.1-ping2p-10.00.Custom_i386.deb
*** ในกรณี Ubuntu 10.04 จะมี bug โดยไม่ยอม initramfs มาให้ ให้สร้างเอง โดยในโฟลเดอร์ /usr/src ให้สั่ง sudo update-initramfs -c -k 2.6.34.1-ping2p (ใส่ version และชื่อตามรุ่นที่เราคอมไพล์และตั้งชื่อไว้ตอนแรก) เสร็จแล้วให้ลองตรวจสอบใน /boot ดูจะมีไฟล์ initrd.img2.6.34.1-ping2p, System.map-2.6.34.1-ping2p และ vmlinuz-2.6.34.1-ping2p ออกมา
6. ตรวจสอบ Bootloader
เพื่อให้แน่ใจว่าตอน boot แล้วจะมี kernel ใหม่ให้เลือก ให้ลองตรวจสอบ bootloader ดู ซึ่งแล้วแต่ว่า bootloader เป็น grub หรือ lilo
ในกรณีของผมเป็น grub2 ก็ไปดูที่ไฟล์ /boot/grub/grub.cfg (แต่ถ้าเป็น grub 1 จะอยู่ใน /boot/grub/menu.lst) จะมี kernel ใหม่อยู่
*** ลองตรวจสอบว่าตรงรายการ kernel ใหม่นั้นมีบรรทัด initrd /boot/initrd.img-2.6.34.1-ping2p อยู่หรือไม่ ถ้าไม่มีให้ใส่เพิ่มเข้าไป (ตัวที่เป็น recovery mode ก็เช่นกันให้ใส่เข้าไปด้วย) ส่วนบรรทัดที่ขึ้นต้นด้วย linux /boot/vmlinuz-2.6.34.1-ping2p ให้ลองเปลี่ยนค่า root=/dev/sda5 เป็น root=UUID=..... โดยค่า UUID ให้ใช้ค่าที่อยู่ใน option --fs-uuid --set .... ที่อยู่ในบรรทัดข้างบน เช่นของผมจะเป็น
menuentry 'Ubuntu, with Linux 2.6.34.1-ping2p' --class ubuntu --class gnu-linux --class gnu --class os {
recordfail
insmod ext2
set root='(hd0,5)'
search --no-floppy --fs-uuid --set 54c8e93d-971f-4197-8a08-b9e131d1becf
linux /boot/vmlinuz-2.6.34.1-ping2p root=UUID=54c8e93d-971f-4197-8a08-b9e131d1becf ro quiet splash
initrd /boot/initrd.img-2.6.34.1-ping2p
}
เป็นอันเรียบร้อยครับ ลอง reboot ดู ตัว bootloader ของเราจะมี option kernel ตัวใหม่ของเราอยู่ด้วย
ระบบที่ทดสอบ
OS: Ubuntu 10.04
Kernel: Linux 2.6.34.1
sudo apt-get install php5-odbc libmdbodbc mdbtools unixodbc-bin
[mdbtoolsodbc]
Description = MDB Tools odbc drivers
Driver = /usr/lib/libmdbodbc.so.0
Setup =
FileUsage = 1
CPTimeout =
CPReuse =
UsageCount = 1
[TestDatabase]
Description = Miscrosoft Access Database of TestDatabase
Driver = mdbtoolsodbc
Database = /home/supasate/desktop/testdatabase.mdb
Servername = localhost
UserName =
Password =
port = 5432
if (!($conn = odbc_connect("TestDatabase", "", ""))) {
echo "Connection Falied.";
} else {
echo "Connection Success.";
$query = "SELECT ID, FirstName, LastName From EMPLOYEE";
$result = odbc_exec($conn, $query);
while ($row = odbc_fetch_array($result)) {
print $row['ID'].' '.$row['FirstName'].' '.$row['LastName'].'
';
}
php test.php
sudo apt-get install mdbtools-gmdb
for i in *.xwd; do
xwdtopnm $i | ppmtogif -interlace > `basename $i .xwd`.gif;
done
gifmerge -10 -2 -notransp *.gif > movie.gif
pdftotext filename.pdf
$for f in *.pdf
> do
> pdftotext "$f"
>done
"a10yy
:e /path/to/b.txt
"ap
:e#
git log -- filename
git diff commitid -- filename
ผมทดลอง run ด้วย safe mode แล้วกลับไม่พบอาการดังกล่าว จึงได้ลอง 2 วิธี 1. สร้าง profile ใหม่ 2. ถอด extension/add-on ทิ้งหมด แต่ปรากฏว่าอาการยังเป็นอยู่ครับ และไม่ได้ลองวิธีอื่นต่อ
ผมตัดสินใจลบ Firefox ทิ้งแล้วลงใหม่ครับ โดยเริ่มจากถอด firefox ออกด้วยsudo apt-get remove firefox
หลังจากนั้นลบโฟลเดอร์ที่เกี่ยวข้องออกครับsudo rm -r /usr/lib/firefox-3.6.3 /usr/lib/firefox-addons ~/.mozilla
หลังจากนั้นลงใหม่ด้วยsudo apt-get install firefox
ซึ่งทำให้กลับมาใช้ได้ครับ ผมยังไม่ได้ลงไล่ไปลึกกว่านี้ว่าสาเหตุจริงๆคืออะไรกันแน่ครับ
ระบบที่ทดสอบ
OS: Ubuntu 10.04 Lucid Lynx
Firefox: 3.6.3
ALTER TABLE ชื่อตาราง AUTO_INCREMENT=5
struct ABC {
...
};
typedef struct {
...
} ABC;
typedef struct ABC {
...
} ABC;
struct ABC v;
ABC v;
struct ABC x;
...
struct ABC {
...
};
ABC x;
struct ABC x;
...
typedef struct ABC {
...
} ABC;
// หลังจากนี้จึงเรียกแค่ ABC ได้
ABC y;