mac安装linux双系统的吐槽

[First day]

尝试安装mac - linux 双系统
首先,尝试的是ubuntu16.06版本,要把双系统安装至电脑硬盘512G SSD中,
***

  1. 分盘
    1.1 打开实用工具中的磁盘管理工具

    1.2 分区
  2. command+R 进入安全模式 ,打开命令行,输入csrutil disable 放开系统分区读写操作权限
    PS:后面要记得enable回来
  3. 懒得写了,大致参考了
    https://blog.csdn.net/babytang008/article/details/70879634
    http://www.cnblogs.com/diligenceday/p/6103530.html
  4. 制作u盘引导盘
    1. 格式化优盘
    2. 下载ubuntu系统下载完毕后, 我们要把iso文件转化为dmg格式, 执行命令:
      hdiutil convert ubuntu-16.04-desktop-amd64.iso -format UDRW -o ubuntu.dmg
    3. 开始使用dd方式制作启动盘
      1.插入空白 U盘,运行下列命令查看你其序号
      diskutil list
      当然你直接用磁盘管理工具也可以直接看到

      2.运行下面的命令,把N改成你U盘的序号,通常是2。(我下面代码直接用2好了)
      diskutil unmountDisk /dev/disk2
      1. 运行下面的命令,把2改成你 U 盘的序号。
        sudo dd if=ubuntu.dmg of=/dev/rdisk2 bs=2m
        4.退出 U 盘,把2改成你 U 盘的序号
        diskutil eject /dev/disk2
  5. 安装引导工具rEFInd ,改一下界面还行,不然超级丑
    http://blog.csdn.net/xiaoshaxs/article/details/52016628 安装参考
    http://blog.csdn.net/xiaoshaxs/article/details/52016717 配置
    https://tieba.baidu.com/p/4383185951 美化

  6. ***

    [Second day]

    看完这么多,你可能会以为我操作好了,impossible
    Apple T2 芯片给你极致快乐,在第三方维修,第三方显卡坞,第三方系统本地磁盘安装用于启动,各种坑,反正你哭就完事了。
    本地磁盘自从2018 MacbookPro 15inch 可能不能安装吧,
    我比较菜,不会弄,有大佬请带带我,好吧
    ***

[Third day]

然后我以为是别的问题,换了很多个版本的linux系统
其中正常安装由于驱动问题,是需要外接鼠标键盘操作的
然后

ubuntu18是直接黑

ubuntu16 grub2 卡住,不知道是不是机械硬盘太慢的问题
嗯,新买了一个三星T5 500G SSD,安装成功,是真的好用

fedora 也会报错gg

manjaro 会在90%卡住,鼠标键盘gg,会卡住不能动,大致是fw_type这步
后来看里面官方文档的Guide,说是可能好像引导界面driver 改成no-free
刚开始鼠标键盘可以了好像,后来又gg,可能还是显卡驱动的问题,有的大佬好像说是去命令行卸驱动啥的?随缘吧,有空再试。

今天的感官是manjaro的界面好好看啊,和mac也挺像的感觉,但最后那步换了好几个版本还是会报错,不想看了,不管怎么说ubuntu双系统是安装完毕了,但是,鼠标键盘驱动还是没有.

内置的鼠标键盘通过spi总线连接好像是说只有2017的驱动,2018找不到还。
https://blog.csdn.net/Vince_/article/details/88772177
刚开时还以为19年博客标明最新版安装驱动有用,结果找出来最后人家18年7月1号从国外找的博客安装的17版的macbookpro,总之感觉好多博客都好老了,光看发布日期一点用都没有,以后还是多看看google吧,就是英文看起来有些疲劳。

最后附上部分T2芯片深深吐槽,和一些photo吧。。。
https://www.apple.com/mac/docs/Apple_T2_Security_Chip_Overview.pdf
https://liliputing.com/2018/11/you-cant-run-linux-on-apples-2018-macs-thanks-to-the-t2-security-chip.html

至于为什么mac 可以装windows ,

因为2018macbookpro 这类内置T2芯片的mac硬件。因为硬件级的安全,非具有苹果签名的系统无法安装。

目前,可能还是windows用的人多。Apple对于Windows的妥协是,增加了Windows的CA 2011 证书。可以通过bootcamp启动和安装,而且系统可以放置在内置硬盘和移动硬盘两种选择。驱动什么的bootcamp也都有,不像linux,不给你装。
而且T2芯片还有一点,就是说Mac的维修改造啥的,变化之后要通过T2芯片向官网申请什么的,总之智能官方维修了,加上官网维修动不动大换的,很贵,所以,

我在这里诚心推荐macbookpro 今年3月最新推出的apple Care+,不但延保至三年,还有外壳损坏和内部损坏意外险哦,不管你咋弄坏的,加一点钱,就能修,超级棒。

转载于:https://www.cnblogs.com/sduRJ/p/10744755.html

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Qt中实现热插拔需要使用系统级别的API,因为需要操作硬件设备。WindowsLinux系统的API不同,需要分别进行处理。 1. Windows系统 在Windows系统中,可以使用Windows API来实现热插拔。具体步骤如下: (1)使用SetupAPI来枚举设备 使用SetupAPI枚举设备的过程如下: ``` HDEVINFO hDevInfo; SP_DEVINFO_DATA DeviceInfoData; hDevInfo = SetupDiGetClassDevs(NULL, TEXT("USB"), NULL, DIGCF_PRESENT | DIGCF_ALLCLASSES); DeviceInfoData.cbSize = sizeof(SP_DEVINFO_DATA); for (DWORD i = 0; SetupDiEnumDeviceInfo(hDevInfo, i, &DeviceInfoData); i++) { // 处理设备信息 } ``` 其中,第一个参数为设备类型,这里为NULL表示枚举所有设备;第二个参数为设备类别,这里为USB;第三个参数为要枚举的父设备,这里为NULL表示枚举所有父设备;第四个参数为枚举标志,这里指定了DIGCF_PRESENT和DIGCF_ALLCLASSES,表示只枚举已经插入的设备并且包括所有设备类别。 (2)监听设备插拔事件 使用Windows API中的RegisterDeviceNotification函数来注册设备插拔事件,具体代码如下: ``` DEV_BROADCAST_DEVICEINTERFACE NotificationFilter; ZeroMemory(&NotificationFilter, sizeof(NotificationFilter)); NotificationFilter.dbcc_size = sizeof(DEV_BROADCAST_DEVICEINTERFACE); NotificationFilter.dbcc_devicetype = DBT_DEVTYP_DEVICEINTERFACE; HDEVNOTIFY hDevNotify = RegisterDeviceNotification((HWND)winId(), &NotificationFilter, DEVICE_NOTIFY_WINDOW_HANDLE); ``` 其中,第一个参数为窗口句柄,这里使用winId()获取当前窗口的句柄;第二个参数为要监听的设备类型,这里指定为设备接口类型;第三个参数为通知类型,这里指定为DEVICE_NOTIFY_WINDOW_HANDLE,表示使用窗口句柄来接收通知。 (3)处理设备插拔事件 当系统发生设备插拔事件时,会发送WM_DEVICECHANGE消息,可以在窗口消息处理函数中处理该消息。具体代码如下: ``` bool Widget::nativeEvent(const QByteArray &eventType, void *message, long *result) { MSG *msg = static_cast<MSG *>(message); if (msg->message == WM_DEVICECHANGE) { // 处理设备插拔事件 } return false; } ``` 其中,使用nativeEvent函数来获取底层窗口消息,判断消息类型是否为WM_DEVICECHANGE,如果是,则处理设备插拔事件。 2. Linux系统 在Linux系统中,可以使用udev来实现热插拔。具体步骤如下: (1)使用udev来枚举设备 使用udev来枚举设备的过程如下: ``` udev* udev_ctx; udev_enumerate* enumerate; udev_list_entry* devices, *dev_list_entry; udev_device* dev; udev_ctx = udev_new(); enumerate = udev_enumerate_new(udev_ctx); udev_enumerate_add_match_subsystem(enumerate, "usb"); udev_enumerate_scan_devices(enumerate); devices = udev_enumerate_get_list_entry(enumerate); udev_list_entry_foreach(dev_list_entry, devices) { const char* path = udev_list_entry_get_name(dev_list_entry); dev = udev_device_new_from_syspath(udev_ctx, path); // 处理设备信息 udev_device_unref(dev); } udev_enumerate_unref(enumerate); udev_unref(udev_ctx); ``` 其中,第二个参数为要枚举的子系统,这里指定为usb。 (2)监听设备插拔事件 使用udev_monitor来监听设备插拔事件,具体代码如下: ``` udev* udev_ctx; udev_monitor* mon; int fd; udev_ctx = udev_new(); mon = udev_monitor_new_from_netlink(udev_ctx, "udev"); udev_monitor_filter_add_match_subsystem_devtype(mon, "usb", NULL); udev_monitor_enable_receiving(mon); fd = udev_monitor_get_fd(mon); QSocketNotifier* notifier = new QSocketNotifier(fd, QSocketNotifier::Read, this); connect(notifier, SIGNAL(activated(int)), this, SLOT(onDeviceChanged())); ``` 其中,第二个参数为要监听的设备子系统,这里指定为usb;onDeviceChanged()为设备插拔事件的函数。 (3)处理设备插拔事件 当系统发生设备插拔事件时,会触发onDeviceChanged()函数。具体代码如下: ``` void Widget::onDeviceChanged() { udev* udev_ctx; udev_device* dev; udev_ctx = udev_new(); dev = udev_monitor_receive_device(mon); if (dev) { // 处理设备插拔事件 udev_device_unref(dev); } udev_unref(udev_ctx); } ``` 其中,mon为udev_monitor对象,dev为接收到的设备信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值