mirror of
https://github.com/MariaDB/server.git
synced 2025-01-16 12:02:42 +01:00
d8986fd6c3
-Change my_rnd() slightly to make it safer if two threads use it at the same time. -Avoid some sprintf and strmov in vio. -Changed thread_count to be automaticly incremented (instead of under LOCK_thread_count). -Thread cache now uses LOCK_thread_cache instead of LOCK_thread_count. -Moved delete thd out from LOCK_thread_count. -Save some mysql_cond_broadcast(&COND_thread_count) calls. -Removed call to getsockname() during connect. -Initialize random generator without locks. Other things: -Fixed test cases that depends on changes for LOCK_grant -Added thread_safe_decrement32() and thread_safe_increment32() -Removed sql_rnd_with_mutex() and get_thread_running() -In check_table_access() don't lock LOCK_grant if we can resolve the grant with user or db level grants (the normal case). -Don't use a lock for setting THD->query_id. -Fixed bug where thd->set_query_id() could be set to same value by multiple threads. Thanks to Yoshinori Matsunobu for the benchmark of connection speed and to Domas Mituzas for the inspiration for many of the fixes. include/violite.h: Change desc to a string pointer mysql-test/suite/perfschema/r/all_instances.result: Added new mutex mysql-test/suite/perfschema/t/func_mutex.test: Test for LOCK_system_variables_hash instead of LOCK_grant, as LOCK_grant is not anymore always taken for SELECT's. mysys/my_gethwaddr.c: More DBUG mysys/my_rnd.c: Change my_rnd() slightly to make it safer if two threads use it at the same time. sql/event_scheduler.cc: Changed thread_count to be automically incremented Moved some safe things out from LOCK_thread_count. Simplify deleting of THD for running thread. sql/mysqld.cc: Changed thread_count to be automically incremented Thread cache now uses LOCK_thread_cache instead of LOCK_thread_count Added delete_running_thd() Moved delete thd out from LOCK_thread_count More DBUG Only call mysql_cond_broadcast(&COND_thread_count) if thread_count is 0 Removed call to getsockname() (old not anymore needed check) sql/mysqld.h: Removed sql_rnd_with_mutex() (not needed anymore) Removed not used function get_thread_running() Added thread_safe_decrement32() and thread_safe_increment32() Simplified dec_thread_running() and inc_thread_running() next_query_id() should return the original value for global_query_id, not the next one. (Bug introduced with MySQL 5.5 merge). sql/sql_acl.cc: In check_table_access() don't lock LOCK_grant if we can resolve the grant with user or db level grants (the normal case). sql/sql_class.cc: Removed thd_lock_thread_count() and thd_unlock_thread_count() Initialize random generator without locks Don't use a lock for setting THD->query_id. (This is only accessed by thread owning the THD) sql/sql_class.h: Don't use a lock for setting THD->query_id. sql/sql_insert.cc: Changed thread_count to be automically incremented sql/sql_parse.cc: Changed thread_count to be automically incremented Fixed bug where thd->set_query_id() could be set to same value by multiple threads. vio/vio.c: Don't generate 'desc' with sprintf/strmov. Assign a pointer instead. (Good enough as this is just for debugging)
198 lines
4.4 KiB
C
198 lines
4.4 KiB
C
/*
|
|
Copyright (c) 2004, 2010, Oracle and/or its affiliates
|
|
Copyright (c) 2011, Monty Program Ab
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; version 2 of the License.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
|
|
|
|
/* get hardware address for an interface */
|
|
/* if there are many available, any non-zero one can be used */
|
|
|
|
#include "mysys_priv.h"
|
|
#include <m_string.h>
|
|
|
|
#ifndef MAIN
|
|
|
|
static my_bool memcpy_and_test(uchar *to, uchar *from, uint len)
|
|
{
|
|
uint i, res= 1;
|
|
|
|
for (i= 0; i < len; i++)
|
|
if ((*to++= *from++))
|
|
res= 0;
|
|
return res;
|
|
}
|
|
|
|
#if defined(__APPLE__) || defined(__FreeBSD__)
|
|
#include <net/ethernet.h>
|
|
#include <sys/sysctl.h>
|
|
#include <net/route.h>
|
|
#include <net/if.h>
|
|
#include <net/if_dl.h>
|
|
|
|
my_bool my_gethwaddr(uchar *to)
|
|
{
|
|
size_t len;
|
|
uchar *buf, *next, *end, *addr;
|
|
struct if_msghdr *ifm;
|
|
struct sockaddr_dl *sdl;
|
|
int res= 1, mib[6]= {CTL_NET, AF_ROUTE, 0, AF_LINK, NET_RT_IFLIST, 0};
|
|
|
|
if (sysctl(mib, 6, NULL, &len, NULL, 0) == -1)
|
|
goto err;
|
|
if (!(buf = alloca(len)))
|
|
goto err;
|
|
if (sysctl(mib, 6, buf, &len, NULL, 0) < 0)
|
|
goto err;
|
|
|
|
end = buf + len;
|
|
|
|
for (next = buf ; res && next < end ; next += ifm->ifm_msglen)
|
|
{
|
|
ifm = (struct if_msghdr *)next;
|
|
if (ifm->ifm_type == RTM_IFINFO)
|
|
{
|
|
sdl = (struct sockaddr_dl *)(ifm + 1);
|
|
addr= (uchar *)LLADDR(sdl);
|
|
res= memcpy_and_test(to, addr, ETHER_ADDR_LEN);
|
|
}
|
|
}
|
|
|
|
err:
|
|
return res;
|
|
}
|
|
|
|
#elif defined(__linux__) || defined(__sun__)
|
|
#include <net/if.h>
|
|
#include <sys/ioctl.h>
|
|
#include <net/if_arp.h>
|
|
#ifdef HAVE_SYS_SOCKIO_H
|
|
#include <sys/sockio.h>
|
|
#endif
|
|
|
|
#define ETHER_ADDR_LEN 6
|
|
|
|
my_bool my_gethwaddr(uchar *to)
|
|
{
|
|
int fd, res= 1;
|
|
struct ifreq ifr[32];
|
|
struct ifconf ifc;
|
|
DBUG_ENTER("my_gethwaddr");
|
|
|
|
ifc.ifc_req= ifr;
|
|
ifc.ifc_len= sizeof(ifr);
|
|
|
|
fd = socket(AF_INET, SOCK_DGRAM, 0);
|
|
if (fd < 0)
|
|
{
|
|
DBUG_PRINT("error", ("socket() call failed with %d", errno));
|
|
goto err;
|
|
}
|
|
|
|
if (ioctl(fd, SIOCGIFCONF, (char*)&ifc) >= 0)
|
|
{
|
|
uint i;
|
|
for (i= 0; res && i < ifc.ifc_len / sizeof(ifr[0]); i++)
|
|
{
|
|
#ifdef __linux__
|
|
if (ioctl(fd, SIOCGIFHWADDR, &ifr[i]) >= 0)
|
|
res= memcpy_and_test(to, (uchar *)&ifr[i].ifr_hwaddr.sa_data,
|
|
ETHER_ADDR_LEN);
|
|
#else
|
|
/*
|
|
A bug in OpenSolaris used to prevent non-root from getting a mac
|
|
address: {no url. Oracle killed the old OpenSolaris bug database}
|
|
|
|
Thus, we'll use an alternative method and extract the address from the
|
|
arp table.
|
|
*/
|
|
struct arpreq arpr;
|
|
arpr.arp_pa= ifr[i].ifr_addr;
|
|
|
|
if (ioctl(fd, SIOCGARP, (char*)&arpr) >= 0)
|
|
res= memcpy_and_test(to, (uchar *)&arpr.arp_ha.sa_data,
|
|
ETHER_ADDR_LEN);
|
|
#endif
|
|
}
|
|
}
|
|
|
|
close(fd);
|
|
err:
|
|
DBUG_RETURN(res);
|
|
}
|
|
|
|
#elif defined(_WIN32)
|
|
#include <winsock2.h>
|
|
#include <iphlpapi.h>
|
|
#pragma comment(lib, "iphlpapi.lib")
|
|
|
|
#define ETHER_ADDR_LEN 6
|
|
|
|
my_bool my_gethwaddr(uchar *to)
|
|
{
|
|
my_bool res= 1;
|
|
|
|
IP_ADAPTER_INFO *info= NULL;
|
|
ULONG info_len= 0;
|
|
|
|
if (GetAdaptersInfo(info, &info_len) != ERROR_BUFFER_OVERFLOW)
|
|
goto err;
|
|
|
|
info= (IP_ADAPTER_INFO *)alloca(info_len);
|
|
|
|
if (GetAdaptersInfo(info, &info_len) != NO_ERROR)
|
|
goto err;
|
|
|
|
while (info && res)
|
|
{
|
|
if (info->Type == MIB_IF_TYPE_ETHERNET &&
|
|
info->AddressLength == ETHER_ADDR_LEN)
|
|
{
|
|
res= memcpy_and_test(to, info->Address, ETHER_ADDR_LEN);
|
|
}
|
|
info = info->Next;
|
|
}
|
|
|
|
err:
|
|
return res;
|
|
}
|
|
|
|
#else /* unsupported system */
|
|
/* just fail */
|
|
my_bool my_gethwaddr(uchar *to __attribute__((unused)))
|
|
{
|
|
return 1;
|
|
}
|
|
#endif
|
|
|
|
#else /* MAIN */
|
|
int main(int argc __attribute__((unused)),char **argv)
|
|
{
|
|
uchar mac[6];
|
|
uint i;
|
|
MY_INIT(argv[0]);
|
|
if (my_gethwaddr(mac))
|
|
{
|
|
printf("my_gethwaddr failed with errno %d\n", errno);
|
|
exit(1);
|
|
}
|
|
for (i= 0; i < sizeof(mac); i++)
|
|
{
|
|
if (i) printf(":");
|
|
printf("%02x", mac[i]);
|
|
}
|
|
printf("\n");
|
|
return 0;
|
|
}
|
|
#endif
|
|
|