面试时间:2017年8月17日

面试时长:约1小时

面试形式:面对面

面试公司:杭州某初创公司,致力于开发VR相关产品

面试职位:FPGA工程师(实习)

面试官:公司现任FPGA开发工程师,双控硕士毕业后约3年工作经验,有某研究所数字IC前端经验

面试问题:

  *从学校来公司大约多长时间?

  我骑单车过来的,大约十分钟,很近的

  *简短自我介绍?

  我叫***,正在**大学**系读研一,九月份马上升研二

  *研一学过哪几门课,系统辨识与滤波的大作业做的是什么内容?

  研一一年大约学过八门课,分别是线性系统理论、系统辨识与滤波、过程控制、计算机网络、CPS、过程控制、ICS安全等。系统辨识与滤波是在安全攻防博弈的背景下,去辨识本科自控实验中常见的水箱加热器环节;

  *辨识的参数有哪些?

  首先有被控对象的参数和一个PID环的控制参数

  *被控对象的参数有哪些?

  被控对象的复杂与否,全看辨识人员预设的模型是几阶的,我预设的是一阶惯性环节因此被控对象参数比较少

  *辨识算法用的是什么?

  用的是经典的最小二乘法

  闲聊结束,开始正经面试

  *用过FPGA吗?经验多少?

  在实验室依托老板的项目用过FPGA器件,型号是EP4CE115,逻辑资源115K,真正上手接触FPGA的时间大概是3个月,严格来说现在是always块搬运工。

  *谈谈你所做的项目?

  之前实验室一直在从事工业以太网协议栈的开发,有很强的技术积累,这次我做的是给这个协议栈多加一个协议/服务,代码量2k行,使用的IP核2 port ram

  *你这个协议是工作在OSI哪层的?

  整个工业以太网协议栈和OSI七层模型不是严格的一一对应关系,如果非要对应的话,我的实现的协议应该属于MAC层之上的

  *我对计算机网络的知识不熟悉,简单说一说你的CRC校验是怎么做的,你可以用白板讲解?

  收发报文两个部分都需要CRC模块,因此在recv和send层下面都需要加CRC子层(自顶向下),对于send而言,每一条报文也都需要加CRC,因此我把CRC做成了一个task。另外,CRC算法啊主要涉及的是位与位之间的异或运算,因此算法的主体都是a[]^a[]……

  *你只用到了一个RAM IP核?以后的如果需要的RAM空间不大,可以自己手写一个,不用非要占用片内RAM的宝贵资源

  嗯,好的,我回去尝试一下自己手写

  *我如果没猜错的话,你的硬件上应该是一个RJ45网口后面加一个PHY芯片是吧,说说PHY芯片和FPGA之间有哪些信号线?

  我配置的PHY芯片工作在RGMII模式,比较重要的信号线主要是MDC和MDIO的地址线和数据线

  *好,我正要问你RGMII的工作模式有什么特点?

  首先PHY芯片的工作模式有多种。。。有对光口的有对电口的(开始胡扯了,其实PHY初始化的工作是由实验室同学完成的,我也没认真读过芯片手册)

  *是否进行过时序分析乃至于时序约束的经验?

  在真正做项目的时候没有进行严谨的时序分析,综合的时候会出现warning,但是没有error,板级调试的功能实现没有问题,就没有管这块。

  *这块内容你要必须仔细实践掌握啊

  是的

  *对FIFO有什么理解?

  数据结构里面学过这一类数组组织形式,模块的输入输出信号比ram多了几个判断或指示标志吧,比如FIFO空不空,满不满等,设计逻辑时要考虑这些因素,以及可能触发异常导致不满足约束的情况

  *对常见的外围接口协议了解多少?

调试中接触过SPI

  *那你在白板上画出来SPI的时序图

  我画了片选、时钟、信号和四种工作模式,做了简单讲解

  (调试时间有点长,大概一年时间了,有点生疏了)

  *对于其他的接口电路uart、IIC是否熟悉?

  只在课上学过他们的时序,没有动手调试过。但是我认为常见接口电路都是一通百通的,可以在使用的时候翻手册去现学

  *这样是不行的,有一些接口还是比较复杂的,不信你看PCIe和serdes不拉不拉。。。另外建议你经常游览一下xilinx的官网,里面的文档、论坛和代码质量都很高

  (心想,这两个我都会了,那要多牛逼)

  *FPGA IO口的电平有哪几种?

  我记得pin planner里面大概有五种吧,3.3、1.5、2.5 、LVDS等等

  *你对计算机编程语言掌握如何?C/C++熟练吗?你必须在FPGA和软工中选一种啊,坚持一个领域深入钻研下去,过几年你就会看到收获的,至少对于普通人而言,很难把知识掌握的面面俱到

  我装作深思熟虑了一分钟,说我就是要选FPGA这个坑

  你还有什么想问我的吗?

  终于开始问答反转了,以下轮我提问了

  *公司对实习生的培养原则是什么?

  公司总之希望实习生在公司学到他们感兴趣的内容,如果实习生对工作内容或者业务不感兴趣,那么双方很难达到双赢

  *公司对开发是否有工期要求?

  首先公司是一个创业公司,到现在还没有一个完整的产品产出,近期是希望拼凑出一个demo来,所以会赶一些。但是也不是一天一天那么赶,只是需要开发把进度安排的紧凑高效一点,我也不能保证一天两天就能开发出来一个复杂的功能。对实习生而言,有适当的工期约束和压力我认为会促进你的学习和成长

  *公司通常对实习生的待遇情况?

  这个你要和老板谈

[面经]杭州某初创公司FPGA工程师实习的更多相关文章

  1. 夏宇闻教授谈FPGA工程师的入门学习

    1. 必须清楚自己究竟适合不适合做工程师. 看看自己的性格特点,是不是特别安静,又耐得住寂寞.因为FPGA工程师是一个辛苦的工作,不但要通过不断学习研究提升自己的设计水平,还要经常性的熬夜加班敲写代码 ...

  2. 转-----FPGA工程师:持守梦想or屈于现实

     昨晚无意间看到一段新闻频道对最近炒得火热的“史上最年轻教授”的专访,倒是他的一位同学对于梦想的“现实版”解说颇有些耐人寻味.大体意思是说“拼了老命考上一所梦寐以求的大学,父母辛辛苦苦交了学费,我们却 ...

  3. 阿里Java研发工程师实习面经

    十分幸运 拿到阿里云的offer,感谢周围无数人对我的支持和鼓励,所以写篇面经希望可以帮助大家. 面试中,运气占很大一部分的,所以你们若是没有通过,一定不要气馁,继续加油. 每个努力的人 都值得钦佩, ...

  4. 阿里Java研发工程师实习面经,附面试技巧

    作者:如何进阿里 链接:https://www.nowcoder.com/discuss/72899?type=0&order=0&pos=17&page=1 来源:牛客网 前 ...

  5. Java工程师修炼之路(校招总结)

    Java工程师修炼之路(校招总结) 前言 在下本是跨专业渣考研的985渣硕一枚,经历研究生两年的学习积累,有幸于2019秋季招聘中拿到几个公司的研发岗offer,包括百度,阿里,腾讯,今日头条,网易, ...

  6. Java工程师修炼之路(从小白到BAT的两年学习历程)

    ​ 作者:陆小凤 文章首发于:微信公众号[程序员江湖] 前言 在下本是跨专业渣考研的985渣硕一枚,经历研究生两年的学习积累,有幸于2019秋季招聘中拿到几个公司的研发岗offer,包括百度,阿里,腾 ...

  7. 皆在FPGA之外

    最近做电力方面的项目,由于跨行业,所以很长一段时间都在做前期准备工作. 项目设计前应尽量做到面面俱到,否则会在项目设计中遇到下面大概率问题: 性能不满足需求,然后为了提升性能,资源又成了瓶颈: 功能设 ...

  8. FPGA Timing笔记

    很多FPGA工程师都会遇到timing的问题,如何让FPGA跑到更快的处理频率是永久话题.决定FPGA的timing关键是什么?如何才能跑到更快的频率呢? A. 第一步需要了解FPGA的timing路 ...

  9. 基于FPGA的HDMI高清显示接口驱动

    HDMI是(High Definition Multimedia Interface)的缩写,意思是高清晰度多媒体接口,是一种数字化视频/音频接口技术,适合影像传输的专用型数字化接口,可同时传送音频和 ...

随机推荐

  1. 解决IE11安装时需要“获取更新”(IE11离线安装)

    方法一:说明:目前是针对Windows7 64位操作系统安装! 1. 在C盘下新建文件夹,取名为“IE11”. 2. 将官网下载的IE11离线包放到此文件夹中. 3. win + r 打开运行窗口,输 ...

  2. linux 修改普通用户的 max user process

    因为出现  fork: retry: No child processes 问题 , google了一下 , 大家说是要去修改 /etc/security/limits.conf 文件 , 然后我用r ...

  3. .NET Core通过过滤器和中间件两种方式实现全局异常捕获和日志记录

    1.一共有五类过滤器IAsyncAuthorizationFilter  IAsyncResourceFilter   IAsyncActonFilter  IAsyncExceptionFilter ...

  4. .net扩展方法

    http://www.cnblogs.com/landeanfen/p/4632467.html 看了博客才知道定义一个Util工具类并且在工具类里面写静态扩展方法并不是最好的选择.

  5. c#格林治时间实现

    C#时间戳的简单实现   Introduction: 在项目开发中,我们都经常会用到时间戳来进行时间的存储和传递,最常用的Unix时间戳(TimeStamp)是指格林尼治时间1970年1月1日0时(北 ...

  6. 使用Visual Studio Installer 2015打包WPF程序

    前言 做过WPF项目,就少不了要将程序打包部署到客户现场,因为一般长时间不会更新打包程序,每次变动较大需要重新配置打包程序时,就会有些生疏,不那么得心应手.为了方便记忆,记录到博客中. 准备 因为做过 ...

  7. jq里验证插件的自定义方法Jquery.validator.addMethod()示例

    最近写验证的时候感觉原生的验证谢了一遍又一遍,就想到了“不要重复造轮子,学会管理自己的工具库”这句名言,于是尝试用jq的validator. 用过又发现需要自定义方法去验证,于是去查官网,写了Jque ...

  8. vue整理

    安装 vue ui axios import axios from 'axios' // let curWwwPath = window.document.location.href // let p ...

  9. MySQL数据库再回首

    前言: 数据库是程序员的数据源泉,加上近期 要开发DB可视化.性能分析的功能 重新回顾一下MySQL知识,以下是笔记: MySQL架构 MySQL基础理论 1.什么是关系型数据库? 关系型数据库,这个 ...

  10. maven配置及使用

    配置maven工程.从官网下载maven工具,然后解压到磁盘某个目录下即可. 计算机->属性->高级系统设置->环境变量. 新建如下变量: 变量名:MAVEN_HOME 变量值:C: ...